@charset "UTF-8";
/* CSS Document */
/* カラー
*******************/
.c-white {
  color: #ffffff !important; }
.c-black {
  color: #333333 !important; }
.c-blue {
  color: #508ed9 !important; }
.c-yellow {
  color: #fff582 !important; }
.c-red {
  color: #e60012 !important; }
.c-green {
  color: #81bd16 !important; }
.c-green2 {
  color: #00B0AE !important; }
.c-orange {
  color: #ff9020 !important; }
.c-gray {
  color: #f5f5f5 !important; }
.c-gray2 {
  color: #e9e9e9 !important; }
.c-pink {
  color: #f88072 !important; }
.c-cream {
  color: #fffde5 !important; }

/* bgカラー
*******************/
.bg-white {
  background-color: #ffffff !important; }
.bg-black {
  background-color: #333333 !important; }
.bg-blue {
  background-color: #508ed9 !important; }
.bg-yellow {
  background-color: #fff582 !important; }
.bg-red {
  background-color: #e60012 !important; }
.bg-green {
  background-color: #81bd16 !important; }
.bg-orange {
  background-color: #ff9020 !important; }
.bg-gray {
  background-color: #f5f5f5 !important; }
.bg-gray2 {
  background-color: #e9e9e9 !important; }
.bg-pink {
  background-color: #f88072 !important; }
.bg-cream {
  background-color: #fffde5 !important; }

/* border color
*******************/
.bc-white {
  border-color: #ffffff !important; }
.bc-black {
  border-color: #333333 !important; }
.bc-blue {
  border-color: #508ed9 !important; }
.bc-yellow {
  border-color: #fff582 !important; }
.bc-red {
  border-color: #e60012 !important; }
.bc-green {
  border-color: #81bd16 !important; }
.bc-orange {
  border-color: #ff9020 !important; }
.bc-gray {
  border-color: #f5f5f5 !important; }
.bc-gray2 {
  border-color: #e9e9e9 !important; }
.bc-pink {
  border-color: #f88072 !important; }
.bc-cream {
  border-color: #fffde5 !important; }

img {
  pointer-events: none; }

.cm-mv {
  background-image: url("../../images/new-sell/promotion/mv-bg.jpg"); }
  .cm-mv .img img {
    margin-left: -2.5rem; }

.cm-problem {
  padding: 8rem 0; }
  .cm-problem .cm-ribbon-ttl {
    margin-bottom: 5rem; }
  .cm-problem-list {
    flex-wrap: wrap; }
    .cm-problem-list .item {
      display: flex;
      align-items: center;
      width: 49%;
      margin-right: 2%;
      margin-bottom: 2%;
      border: 2px solid #e60012;
      border-radius: .5rem; }
      .cm-problem-list .item:nth-child(2n) {
        margin-right: 0; }
      .cm-problem-list .item:nth-child(n + 3) {
        margin-bottom: 0; }
      .cm-problem-list .item .num {
        font-size: 4.5rem;
        font-weight: 600;
        width: 11rem;
        height: 11rem;
        margin-right: 2rem;
        background-color: #e60012;
        color: #ffffff;
        display: flex;
        align-items: center;
        justify-content: center; }
      .cm-problem-list .item .cont {
        font-size: 1.75rem;
        font-weight: 600;
        color: #e60012;
        width: calc(100% - 22rem); }
      .cm-problem-list .item .ico {
        width: 8rem;
        margin-right: 1rem; }
  .cm-problem .arrow {
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 3rem 3rem 0 3rem;
    border-color: #e60012 transparent transparent transparent;
    margin: 3rem auto; }
  .cm-problem .bottom {
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 4.2rem;
    font-weight: 600;
    letter-spacing: .06em; }
    .cm-problem .bottom .img {
      width: 20rem;
      line-height: 0;
      margin-right: 1.5rem; }
    .cm-problem .bottom .border {
      border-bottom: 3px dotted #e60012;
      padding-bottom: .3rem; }

.cm-strengths {
  padding: 8rem 0;
  background-color: #fffde5; }
  .cm-strengths .cm-ribbon-ttl {
    margin-bottom: 5rem; }
    .cm-strengths .cm-ribbon-ttl .catch {
      letter-spacing: 0; }
  .cm-strengths .col-3 .item {
    margin-right: inherit; }
    .cm-strengths .col-3 .item h3 {
      font-size: 2.8rem;
      font-weight: 500;
      text-align: center; }
      .cm-strengths .col-3 .item h3 i {
        margin-right: 1rem;
        line-height: 0;
        display: inline-block;
        vertical-align: bottom; }
      .cm-strengths .col-3 .item h3 .material-symbols-outlined {
        font-size: 2.8rem; }
    .cm-strengths .col-3 .item-inbox {
      display: flex;
      align-items: center;
      background-color: #ffffff;
      border: 2px solid #e60012;
      border-radius: .5rem;
      margin-bottom: 2rem;
      position: relative; }
      .cm-strengths .col-3 .item-inbox::before, .cm-strengths .col-3 .item-inbox::after {
        content: "";
        display: inline-block;
        width: 4rem;
        height: .4rem;
        position: absolute;
        top: calc(50% - .2rem); }
      .cm-strengths .col-3 .item-inbox::before {
        background: url("../../images/new-sell/promotion/ico-dotted-red.png") no-repeat center;
        background-size: 100%;
        left: -4rem; }
      .cm-strengths .col-3 .item-inbox::after {
        background: url("../../images/new-sell/promotion/ico-dotted-arrow-red.png") no-repeat center;
        background-size: 100%;
        right: -3.1rem;
        width: 3.1rem;
        height: 2rem; }
      .cm-strengths .col-3 .item-inbox:last-child {
        margin-bottom: 0; }
      .cm-strengths .col-3 .item-inbox.bc-green::before {
        background-image: url("../../images/new-sell/promotion/ico-dotted-green.png");
        left: inherit;
        right: -4rem; }
      .cm-strengths .col-3 .item-inbox.bc-green::after {
        background-image: url("../../images/new-sell/promotion/ico-dotted-arrow-green.png");
        right: inherit;
        left: -3.1rem; }
      .cm-strengths .col-3 .item-inbox .num {
        display: flex;
        align-items: center;
        justify-content: center;
        background-color: #e60012;
        width: 7rem;
        min-height: 14rem; }
        .cm-strengths .col-3 .item-inbox .num-inner {
          text-align: center; }
          .cm-strengths .col-3 .item-inbox .num-inner p {
            color: #ffffff;
            font-size: 4rem;
            font-weight: 600; }
            .cm-strengths .col-3 .item-inbox .num-inner p.ico {
              line-height: 0; }
              .cm-strengths .col-3 .item-inbox .num-inner p.ico .material-symbols-outlined {
                font-size: 2.4rem; }
      .cm-strengths .col-3 .item-inbox .txt {
        width: calc(100% - 7rem);
        padding: 0 1rem 0 2rem; }
        .cm-strengths .col-3 .item-inbox .txt h3 {
          text-align: left;
          font-size: 2rem;
          color: #e60012;
          margin-bottom: 1.5rem; }
        .cm-strengths .col-3 .item-inbox .txt p {
          font-size: 1.5rem;
          font-weight: 500;
          line-height: 1.54; }
  .cm-strengths .col-3 .centerItem {
    width: calc(100% - 63rem);
    margin: 0 3.5rem;
    align-self: center; }
  .cm-strengths .col-3 .leftItem {
    border: 8px solid #e60012;
    padding: 2rem;
    width: 28rem;
    background-color: #ffffff; }
    .cm-strengths .col-3 .leftItem h3 {
      color: #e60012;
      margin-bottom: 7rem; }
  .cm-strengths .col-3 .rightItem {
    border: 8px solid #81bd16;
    padding: 2rem;
    width: 28rem;
    background-color: #ffffff; }
    .cm-strengths .col-3 .rightItem h3 {
      color: #81bd16;
      margin-bottom: 3rem; }
    .cm-strengths .col-3 .rightItem .flex {
      flex-wrap: wrap; }
      .cm-strengths .col-3 .rightItem .flex .item {
        width: 48%;
        margin-right: 4%;
        margin-bottom: 1.5rem;
        padding: .5rem; }
        .cm-strengths .col-3 .rightItem .flex .item:nth-child(2n) {
          margin-right: 0; }
        .cm-strengths .col-3 .rightItem .flex .item:nth-child(n + 5) {
          margin-bottom: 0; }
        .cm-strengths .col-3 .rightItem .flex .item.active {
          background-color: #fffde5;
          border: 2px dotted #e60012;
          position: relative; }
          .cm-strengths .col-3 .rightItem .flex .item.active .ico {
            position: absolute;
            left: -.9rem;
            top: -.9rem; }
            .cm-strengths .col-3 .rightItem .flex .item.active .ico .material-symbols-outlined {
              font-size: 1.6rem;
              font-weight: 600;
              background-color: #e60012;
              color: #ffffff;
              border-radius: 100%;
              border: 2px solid #fffde5; }
        .cm-strengths .col-3 .rightItem .flex .item p {
          text-align: center;
          font-size: 1.4rem; }

.cm-advantages {
  padding: 8rem 0; }
  .cm-advantages .cm-ribbon-ttl {
    margin-bottom: 5rem; }
  .cm-advantages-item02 .item {
    background-color: #ffffff;
    border-radius: .5rem;
    padding: 2rem 2.5rem 2.5rem;
    margin-bottom: 4%; }
    .cm-advantages-item02 .item:nth-child(n + 3) {
      margin-bottom: 0; }
  .cm-advantages-item02 .ttl {
    display: flex;
    align-items: center;
    margin-bottom: 2rem;
    margin-left: -5rem; }
    .cm-advantages-item02 .ttl h3 {
      font-size: 2.2rem;
      font-weight: 600;
      color: #e60012;
      line-height: 1.35; }
  .cm-advantages-item02 .icowrap {
    display: flex;
    align-items: center;
    background-color: #e60012;
    color: #ffffff;
    border-radius: .5rem;
    margin-right: 2rem; }
    .cm-advantages-item02 .icowrap .num {
      font-size: 2.4rem;
      color: #ffffff;
      padding: .5rem 1rem;
      border-right: 2px dotted #ffffff; }
    .cm-advantages-item02 .icowrap .ico {
      color: #ffffff;
      padding: 0 1rem;
      line-height: 0; }
      .cm-advantages-item02 .icowrap .ico .material-symbols-outlined {
        font-size: 2.4rem; }
  .cm-advantages-item02 .cont {
    display: flex; }
    .cm-advantages-item02 .cont .img {
      width: 15rem;
      margin-left: 2rem; }
      .cm-advantages-item02 .cont .img img {
        width: 100%; }
    .cm-advantages-item02 .cont p {
      width: calc(100% - 17rem);
      line-height: 1.75;
      font-weight: 500;
      text-align: justify; }

.un-item02 .item {
  background-color: #ffffff;
  border-radius: .5rem; }
  .un-item02 .item a {
    display: block;
    line-height: 1;
    height: 100%;
    transition: .3s; }
    .un-item02 .item a:hover {
      box-shadow: 0 0 1rem rgba(0, 0, 0, 0.3); }
.un-item02 .img img {
  width: 100%; }
.un-item02 .txt {
  padding: 2.5rem; }
.un-item02 .ttl {
  text-align: center;
  font-size: 1.7rem;
  font-weight: 600;
  line-height: 1.35;
  color: #e60012;
  margin-bottom: 2.5rem; }
.un-item02 .cont {
  font-size: 1.4rem;
  font-weight: 500; }

@media (min-width: 1001px) and (max-width: 1100px) {
  .cm-strengths .cm-ribbon-ttl .catch {
    font-size: 3.4rem; }
  .cm-strengths .col-3 .item-inbox .txt h3 {
    font-size: 1.8rem; }
  .cm-strengths .col-3 .item-inbox .txt p {
    font-size: 1.4rem; }

  .un-item02 .txt {
    padding: 2.5rem 1.5rem; } }
@media (min-width: 769px) and (max-width: 1000px) {
  .cm-problem-list .item .num {
    font-size: 3.4rem;
    width: 6rem;
    height: 10rem;
    margin-right: 1.5rem; }
  .cm-problem-list .item .cont {
    width: calc(100% - 17.5rem);
    margin-right: 1rem;
    font-size: 1.6rem; }

  .cm-strengths .col-3 .item {
    position: relative;
    z-index: 1; }
    .cm-strengths .col-3 .item h3 {
      font-size: 2rem; }
      .cm-strengths .col-3 .item h3 i {
        margin-right: 0.5rem; }
      .cm-strengths .col-3 .item h3 .material-symbols-outlined {
        font-size: 2rem; }
    .cm-strengths .col-3 .item-inbox .txt {
      width: calc(100% - 5rem);
      padding: 0 1rem; }
      .cm-strengths .col-3 .item-inbox .txt h3 {
        font-size: 1.8rem; }
    .cm-strengths .col-3 .item-inbox .num {
      width: 5rem;
      min-height: 14rem; }
      .cm-strengths .col-3 .item-inbox .num-inner p {
        font-size: 3.2rem; }
    .cm-strengths .col-3 .item-inbox::before {
      width: 3.5vw;
      height: 0.3vw;
      left: -3vw;
      top: calc(50% - 0.15vw); }
    .cm-strengths .col-3 .item-inbox::after {
      width: 2.5vw;
      height: 1.6vw;
      right: -2.5vw;
      top: calc(50% - 0.8vw); }
    .cm-strengths .col-3 .item-inbox.bc-green::before {
      right: -3.5vw; }
    .cm-strengths .col-3 .item-inbox.bc-green::after {
      left: -2.5vw; }
  .cm-strengths .col-3 .leftItem {
    width: 26%;
    padding: 2rem 1rem; }
  .cm-strengths .col-3 .centerItem {
    width: 42%;
    margin: 0 3%; }
  .cm-strengths .col-3 .rightItem {
    width: 26%;
    padding: 2rem 1rem; }

  .cm-advantages-item02 .ttl {
    margin-left: -4rem; }
    .cm-advantages-item02 .ttl h3 {
      font-size: 2rem; }
  .cm-advantages-item02 .cont .img {
    width: 32%;
    margin-left: 4%; }
  .cm-advantages-item02 .cont p {
    width: 64%; }

  .un-item02 .ttl {
    font-size: 1.6rem;
    margin-bottom: 1.5rem; }
  .un-item02 .txt {
    padding: 1.5rem; } }
@media (min-width: 481px) and (max-width: 768px) {
  .cm-strengths .col-3 .item h3 {
    font-size: 1.8rem; }
    .cm-strengths .col-3 .item h3 .material-symbols-outlined {
      font-size: 1.8rem; }
  .cm-strengths .col-3 .item-inbox::before {
    width: 2.3rem;
    height: 0.2rem;
    left: -2.3rem; }
  .cm-strengths .col-3 .item-inbox::after {
    right: -2.1rem;
    width: 2.1rem;
    height: 1.5rem; }
  .cm-strengths .col-3 .item-inbox.bc-green::before {
    right: -2.3rem; }
  .cm-strengths .col-3 .item-inbox.bc-green::after {
    left: -2.1rem; }
  .cm-strengths .col-3 .item-inbox .num {
    min-height: 11rem; }
    .cm-strengths .col-3 .item-inbox .num-inner p {
      font-size: 3rem; }
  .cm-strengths .col-3 .item-inbox .txt {
    width: calc(100% - 6rem);
    padding: 0 1rem; }
    .cm-strengths .col-3 .item-inbox .txt h3 {
      font-size: 1.5rem;
      margin-bottom: 1rem; }
    .cm-strengths .col-3 .item-inbox .txt p {
      font-size: 1.2rem;
      line-height: 1.5; }
  .cm-strengths .col-3 .leftItem {
    width: 18rem;
    border-width: .8rem;
    padding: 1.5rem; }
  .cm-strengths .col-3 .centerItem {
    width: calc(100% - 40rem);
    margin: 0 2rem; }
  .cm-strengths .col-3 .rightItem {
    width: 18rem;
    border-width: .8rem;
    padding: 1.5rem; }
    .cm-strengths .col-3 .rightItem .flex .item.active {
      border-width: .2rem; } }
@media screen and (max-width: 768px) {
  .sp-parrent {
    overflow: scroll; }

  .cm-problem-list .item .num {
    font-size: 3.2rem;
    width: 7rem;
    height: 12rem;
    margin-right: 1rem; }
  .cm-problem-list .item .cont {
    font-size: 1.55rem;
    width: calc(100% - 15rem);
    margin-right: 1rem; }
  .cm-problem-list .item .ico {
    width: 6rem; }
  .cm-problem .bottom {
    font-size: 3.6rem; }
    .cm-problem .bottom .img {
      width: 20rem;
      margin-right: 1rem; }
    .cm-problem .bottom .border {
      border-width: .3rem; }

  .cm-advantages-item02 .icowrap {
    margin-right: 1.5rem; }
  .cm-advantages-item02 .item {
    margin-bottom: 3rem;
    padding: 2rem 2rem 2.5rem; }
    .cm-advantages-item02 .item:nth-child(n + 3) {
      margin-bottom: 0; }
  .cm-advantages-item02 .ttl {
    margin-left: -3.5rem; }
  .cm-advantages-item02 .cont .img {
    width: 10rem;
    margin-left: 1.5rem; }
  .cm-advantages-item02 .cont p {
    width: calc(100% - 11.5rem); }

  .un-item02 .ttl {
    margin-bottom: 1.5rem; }
  .un-item02 .txt {
    padding: 1.5rem 1.5rem 2rem; } }
@media screen and (max-width: 480px) {
  .cm-mv .img img {
    margin-left: -1.5rem; }

  .cm-problem-list .item {
    width: 100%;
    margin-right: 0;
    margin-bottom: 1.5rem; }
    .cm-problem-list .item:nth-child(n + 3) {
      margin-bottom: 1.5rem; }
    .cm-problem-list .item:last-child {
      margin-bottom: 0; }
    .cm-problem-list .item .num {
      font-size: 2.8rem;
      width: 6rem;
      height: 9rem;
      margin-right: 1rem; }
    .cm-problem-list .item .cont {
      width: calc(100% - 15rem);
      margin-right: 1rem; }
    .cm-problem-list .item .ico {
      width: 6rem; }
  .cm-problem .bottom {
    font-size: 2.4rem; }
    .cm-problem .bottom .img {
      width: 15rem;
      margin-right: 1rem; }
    .cm-problem .bottom .border {
      border-width: .3rem; }

  .cm-advantages-item02 .item {
    margin-bottom: 2rem; }
    .cm-advantages-item02 .item:nth-child(n + 3) {
      margin-bottom: 2rem; }
    .cm-advantages-item02 .item:last-child {
      margin-bottom: 0; }
  .cm-advantages .flex.col-2 .item {
    width: 100%;
    margin-right: 0; }

  .cm-strengths .col-3 {
    width: 80rem; }
    .cm-strengths .col-3 .item h3 {
      font-size: 2.2rem; }
      .cm-strengths .col-3 .item h3 .material-symbols-outlined {
        font-size: 2.2rem; }
    .cm-strengths .col-3 .leftItem {
      width: 20rem;
      border-width: .8rem; }
    .cm-strengths .col-3 .centerItem {
      width: calc(100% - 46rem);
      margin: 0 3rem; }
    .cm-strengths .col-3 .rightItem {
      width: 20rem;
      border-width: .8rem;
      padding: 2rem 1rem; }
      .cm-strengths .col-3 .rightItem .flex .item {
        padding: 2px; }
        .cm-strengths .col-3 .rightItem .flex .item .active {
          border-width: .2rem; } }
