@charset "UTF-8";

body {
  font-family: "Noto Sans JP", sans-serif;
  color: #333333;
}
.campaign {
  overflow-x: hidden;
}
.campaign a {
  text-decoration: none;
}
.campaign img {
  display: block;
  width: 100%;
}
.is-sp {
  display: none;
}
@media only screen and (max-width: 768px) {
  .is-sp {
    display: block;
  }
}
.is-pc {
  display: block;
}
@media only screen and (max-width: 768px) {
  .is-pc {
    display: none;
  }
}
.campaign-inner {
  width: min(100%, 1240px);
  padding-inline: 20px;
  margin-inline: auto;
}
@media only screen and (max-width: 768px) {
  .campaign-inner {
    padding-inline: 10px;
  }
}
.campaign-inner-s {
  width: min(100%, 1120px);
  padding-inline: 20px;
  margin-inline: auto;
}
@media only screen and (max-width: 768px) {
  .campaign-inner-s {
    padding-inline: 10px;
  }
}
.campaign-inner-xs {
  width: min(100%, 1000px);
  padding-inline: 20px;
  margin-inline: auto;
}
@media only screen and (max-width: 768px) {
  .campaign-inner-xs {
    padding-inline: 10px;
  }
}
.font_pc22-sp22 {
  font-size: 22px !important;
}
.strength_headline {
  width: -moz-fit-content;
  width: fit-content;
  font-family: "Noto Sans JP";
  font-weight: bold;
  font-size: 42px;
  letter-spacing: 0.03em;
  text-align: center;
  color: #0e9352;
  margin-inline: auto;
  position: relative;
}
@media only screen and (max-width: 768px) {
  .strength_headline {
    font-size: 29px;
    line-height: 1.5517241379;
  }
}
.strength_headline::before, .strength_headline::after {
  position: absolute;
  content: "";
  width: 100px;
  height: 2px;
  bottom: 30px;
  background-color: #0e9352;
}
@media only screen and (max-width: 768px) {
  .strength_headline::before, .strength_headline::after {
    bottom: 45px;
  }
}
.strength_headline::before {
  left: -110px;
  rotate: 65deg;
}
@media only screen and (max-width: 768px) {
  .strength_headline::before {
    left: -75px;
    rotate: 74deg;
  }
}
.strength_headline::after {
  right: -110px;
  rotate: -65deg;
}
@media only screen and (max-width: 768px) {
  .strength_headline::after {
    right: -75px;
    rotate: -74deg;
  }
}
/* ================================================================================ */
/* kv  */
/* ================================================================================ */
.kv {
  overflow: hidden;
}
@media only screen and (max-width: 768px) {
  .kv {
    display: block;
    padding-inline: 10px;
    margin-top: 8px;
  }
}
.kv_banner {
  display: block;
  position: relative;
}
.kv_banner img {
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}
@media only screen and (max-width: 768px) {
  .kv_banner {
    width: 100vw;
    margin-inline: calc(50% - 50vw);
  }
}
.kv_text-wrap {
  margin-top: 10px;
}
.kv_text {
  font-family: "Noto Sans JP";
  font-weight: 500;
  font-size: 13px;
  letter-spacing: 0.03em;
  line-height: 20.8px;
  text-align: left;
  color: #333;
}
/* ================================================================================ */
/* おすすめのトラック  */
/* ================================================================================ */
.recommend-splide {
  overflow: visible !important;
}
.recommend-splide_controls {
  position: relative;
  margin-top: 24px;
  display: flex;
  align-items: center;
  height: 50px;
}
@media only screen and (max-width: 768px) {
  .recommend-splide_controls {
    position: relative;
    margin-top: 10px;
    height: 30px;
  }
}
.recommend-splide_pagination {
  display: flex;
  gap: 10px;
  position: static;
  margin: auto;
  cursor: pointer;
}
@media only screen and (max-width: 768px) {
  .recommend-splide_pagination {
    gap: 6px;
    position: absolute;
  }
}
.recommend-splide_pagination .splide_pagination_page {
  width: 14px;
  height: 14px;
  margin: 0;
}
@media only screen and (max-width: 768px) {
  .recommend-splide_pagination .splide_pagination_page {
    width: 10px;
    height: 10px;
  }
}
.recommend-splide_pagination .is-active {
  background: #0e9352;
  transform: scale(1);
}
.recommend-splide_arrows {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 32px;
  position: absolute;
  top: 0;
  right: 0;
}
@media only screen and (max-width: 768px) {
  .recommend-splide_arrows {
    gap: 8px;
  }
}
.recommend-splide_arrow {
  width: 50px;
  height: 50px;
  position: static;
  transform: translateY(0%);
  opacity: 1;
  cursor: pointer;
}
@media only screen and (max-width: 768px) {
  .recommend-splide_arrow {
    width: 30px;
    height: 30px;
  }
}
.recommend-splide_arrow[aria-label="Go to last slide"] {
  opacity: 0;
  visibility: hidden;
}
@media (any-hover: hover) {
  .recommend-splide_arrow:hover {
    opacity: 0.7;
  }
}
.recommend-splide_arrow.splide__arrow--prev {
  scale: -1;
}
.recommend-splide_description {
  margin-top: 15px;
  font-size: 13px;
  letter-spacing: 0.025em;
  line-height: 1.7066666667;
}
.recommend-splide_slide:nth-child(n+2) {
  border-left: 1px solid #cccccc;
}

/* ================================================================================ */
/* バナー  */
/* ================================================================================ */
.banner-rental {
  margin: 100px auto;
}
@media only screen and (max-width: 768px) {
  .banner-rental {
    margin: 60px 0;
  }
}
.banner-rental_link {
  display: flex;
  justify-content: center;
  align-items: center;
  margin-top: 15px;
}
@media only screen and (max-width: 768px) {
  .banner-rental_link {
    justify-content: end;
  }
}
.banner-rental_span {
  margin-left: 4px;
  font-weight: 700;
  vertical-align: middle;
}
/* ================================================================================ */
/* トラック市長岡店だから  */
/* ================================================================================ */
.strength {
  background-color: #eff7f2;
  padding-block: 116px 100px;
  overflow: hidden;
}
@media only screen and (max-width: 768px) {
  .strength {
    padding-block: 64px 70px;
  }
}
.strength_inner {
  width: min(100%, 1240px);
  padding-inline: 20px;
  margin-inline: auto;
}
@media only screen and (max-width: 768px) {
  .strength_inner {
    padding-inline: 10px;
  }
}
.strength-slider {
  margin-top: 76px;
  overflow: visible !important;
}
@media only screen and (max-width: 768px) {
  .strength-slider {
    margin-top: 50px;
  }
}
.strength-slider .splide__track {
  overflow: visible;
}
.strength-slider .splide__list {
  height: auto;
}
.strength-slider_slide {
  display: flex;
  flex-direction: column;
  background-color: #ffffff;
  padding: 46px 28px 30px;
  border-radius: 12px;
  border: none !important;
}
@media only screen and (max-width: 768px) {
  .strength-slider_slide {
    padding: 46px 18px 30px;
  }
}
.strength-slider_slide:hover {
  background-color: #ffffff;
}
.strength-slider_label {
  display: flex;
  align-items: center;
  gap: 10px;
  width: -moz-fit-content;
  width: fit-content;
  white-space: nowrap;
  background-color: #f6e929;
  border-radius: 100vh;
  padding: 6px 34px;
  position: absolute;
  top: 0;
  left: 50%;
  translate: -50% -50%;
}
@media only screen and (max-width: 768px) {
  .strength-slider_label {
    padding: 6px 28px;
  }
}
.strength-slider_label::before {
  content: "";
  display: block;
  width: 24px;
  height: 14px;
  background-color: #f6e929;
  clip-path: polygon(65% 0, 0 0, 100% 100%);
  position: absolute;
  top: 90%;
  left: 8px;
}
@media only screen and (max-width: 768px) {
  .strength-slider_label::before {
    width: 22px;
    height: 12px;
    top: 90%;
    left: 10px;
  }
}
.strength-slider_label .strength-slider_label_number {
  font-family: "Roboto", sans-serif;
  font-weight: 500;
  font-size: 21px;
  line-height: 1.3333333333;
  color: #0e9352;
}
@media only screen and (max-width: 768px) {
  .strength-slider_label .strength-slider_label_number {
    font-size: 21px;
  }
}
.strength-slider_slide_text {
  font-weight: bold;
  font-size: 18px;
  letter-spacing: 0.03em;
  line-height: 1.4;
  text-align: center;
  color: #333;
}
.strength-slider_slide_text .font_marker {
  font-weight: bold;
  font-size: 18px;
  letter-spacing: 0.03em;
  text-align: center;
  color: #333;
  text-decoration: underline;
  text-decoration-thickness: 12px;
  text-decoration-color: #f6e929;
  text-underline-offset: -5px;
  -webkit-text-decoration-skip-ink: none;
          text-decoration-skip-ink: none;
}
.strength-slider_slide_text .font_large {
  font-weight: bold;
  font-size: 32px;
  letter-spacing: 0.03em;
  text-align: center;
  color: #333;
}
@media only screen and (max-width: 768px) {
  .strength-slider_slide_text .font_large {
    font-size: 30px;
  }
}
.strength-slider_slide_text .font_large-sm {
  font-weight: bold;
  font-size: 30px;
  letter-spacing: 0.03em;
  text-align: center;
  color: #333;
}
.strength-slider_slide_text .font_pc22-sp22 {
  font-size: 22px;
}
.strength-slider_slide_text .font_pc26-sp26 {
  font-size: 26px;
}
.strength-slider_slide_text .font_middle-lg {
  font-weight: bold;
  font-size: 26px;
  line-height: 1.7;
  letter-spacing: 0.03em;
  text-align: center;
  color: #333;
}
.strength-slider_slide_text .font_middle {
  font-weight: bold;
  font-size: 26px;
  letter-spacing: 0.03em;
  text-align: center;
  color: #333;
}
@media only screen and (max-width: 768px) {
  .strength-slider_slide_text .font_middle {
    font-size: 26px;
  }
}
.strength-slider_slide_image {
  margin-top: 26px;
}
.strength-slider_slide_image img {
  aspect-ratio: auto;
  -o-object-fit: contain;
     object-fit: contain;
}
.strength-slider_slide_image.width_210 {
  width: min(100%, 210px);
  margin-inline: auto;
}
.strength-slider_slide_image.mt22 {
  margin-top: 22px;
}
.strength-slider_slide_image.mt_28 {
  margin-top: 28px;
}
.strength-slider_slide_image.mt_50 {
  margin-top: 50px;
}
.strength-slider_slide_detail {
  font-weight: 500;
  font-size: 16px;
  letter-spacing: 0.03em;
  line-height: 1.6;
  color: #333;
  margin-top: 20px;
}
.strength-slider_slide_slash {
  display: block;
  font-family: "Noto Sans JP";
  font-weight: 500;
  font-size: 13px;
  letter-spacing: 0.03em;
  line-height: 20.8px;
  text-align: center;
  color: #0e9352;
  margin: auto auto 0;
}
/* ボタン */
.strength-slider_slide_btn {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  width: min(100%, 290px);
  background-color: #0e9352;
  border-radius: 6px;
  box-shadow: 0px 4px 0px #0a6d3d;
  padding-block: 12px;
  padding-inline: 20px;
  transition: 0.3s ease;
  position: relative;
  margin-top: auto;
  cursor: pointer;
}
@media (any-hover: hover) {
  .strength-slider_slide_btn:hover {
    box-shadow: none;
    translate: 0 4px;
  }
}
@media only screen and (max-width: 768px) {
  .strength-slider_slide_btn {
    font-size: 18px;
  }
}
.strength-slider_slide_btn::after {
  content: "";
  display: block;
  width: 20px;
  height: 20px;
  background: url("/assets/img/campaign/common/icon_arrow-right-wh.svg") no-repeat center center/contain;
}
.strength-slider_slide_btn.--text-center {
  justify-content: center;
}
.strength-slider_slide_btn.--text-center::after {
  position: absolute;
  top: 0;
  bottom: 0;
  right: 16px;
  margin: auto;
}
.strength-slider_slide_btn.mt11 {
  margin-top: 11px;
}
.strength-slider_slide_btn.line_btn {
  gap: 3px;
  background-color: #4cc764;
  box-shadow: 0px 4px 0px #41ab55;
}
.strength-slider_slide_btn.line_btn::before {
  content: "";
  display: block;
  width: 26px;
  height: 25px;
  background: url("/assets/img/campaign/common/icon-line-white.svg") no-repeat center center/contain;
  position: static;
  margin: 0;
}
.strength-slider_slide_btn.line_btn::after {
  display: none;
}
.strength-slider_slide_btn .strength-slider_slide_btn_wrap {
  display: flex;
  align-items: center;
  gap: 10px;
}
.strength-slider_slide_btn .strength-slider_slide_btn_label {
  font-weight: bold;
  font-size: 14px;
  letter-spacing: 0.1em;
  text-align: center;
  color: #0e9352;
  background-color: #ffffff;
  border-radius: 6px;
  padding: 1px 6px;
}
.strength-slider_slide_btn .strength-slider_slide_btn_text {
  font-weight: bold;
  font-size: 16px;
  text-align: center;
  color: #ffffff;
}
.strength-slider_slide_btn .strength-slider_slide_btn_text.--small {
  font-size: 17px;
  letter-spacing: 0.05em;
}
.strength-slider_list {
  margin-left: 10px;
  margin-top: 20px;
}
.strength-slider_item {
  font-weight: bold;
  font-size: 16px;
  letter-spacing: 0.03em;
  line-height: 1.5;
  text-align: left;
  color: #333;
  padding-left: 12px;
  position: relative;
}
.strength-slider_item::before {
  content: "";
  display: block;
  width: 6px;
  height: 6px;
  background-color: #0e9352;
  border-radius: 100%;
  position: absolute;
  left: 0;
  top: 50%;
  translate: 0% -50%;
}
.strength-slider_item + .strength-slider_item {
  margin-top: 6px;
}
.strength-slider_slide_note {
  font-weight: 500;
  font-size: 13px;
  letter-spacing: 0.03em;
  line-height: 1.6;
  margin-top: 15px;
}

.strength-slider_slide:nth-child(3) .strength-slider_slide_note {
  margin-top: 10px;
}
.strength-slider_slide:nth-child(4) .strength-slider_slide_note {
  text-align: center;
  margin-top: 20px;
}
.strength-slider_slide_qa {
  display: flex;
  align-items: center;
  gap: 6px;
  background-color: #eff7f2;
  border-radius: 6px;
  padding: 12px 16px;
  margin-top: 24px;
  cursor: pointer;
}
.strength-slider_slide_qa_text {
  font-weight: bold;
  font-size: 13px;
  letter-spacing: 0.03em;
  line-height: 1.3846153846;
  text-align: left;
  color: #333;
}
@media only screen and (max-width: 768px) {
  .strength-slider_slide_qa_text {
    line-height: 1;
  }
}
.strength-slider_slide_qa_text .font_middle {
  font-weight: bold;
  font-size: 18px;
  letter-spacing: 0.03em;
  line-height: 1.6;
  text-align: left;
  color: #333;
}
.strength-slider_slide_qa_text .font_large {
  font-size: 24px;
}
.strength-slider_slide_qa_img img {
  aspect-ratio: auto;
  -o-object-fit: contain;
     object-fit: contain;
}
/*ページネーション*/
.strength-slider_controls {
  position: relative;
  margin-top: 34px;
  display: flex;
  align-items: center;
  height: 50px;
}
@media only screen and (max-width: 768px) {
  .strength-slider_controls {
    position: relative;
    margin-top: 20px;
    height: 30px;
  }
}
.strength-slider_pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 20px;
}
.strength-slider_pagination .splide__pagination__page {
  width: 10px;
  height: 10px;
  background-color: #ffffff;
  margin: 0;
}
.strength-slider_pagination .splide__pagination__page.is-active {
  background-color: #0e9352;
  transform: scale(1);
}
/*左右ボタン*/
.strength-slider_arrows {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 32px;
  position: absolute;
  top: 0;
  right: 0;
}
@media only screen and (max-width: 768px) {
  .strength-slider_arrows {
    gap: 8px;
  }
}
.strength-slider_arrows .strength-slider_arrow {
  width: 50px;
  height: 50px;
  position: static;
  transform: translateY(0%);
  opacity: 1;
  cursor: pointer;
}
@media only screen and (max-width: 768px) {
  .strength-slider_arrows .strength-slider_arrow {
    width: 30px;
    height: 30px;
  }
}
.strength-slider_arrows .strength-slider_arrow[aria-label="Go to last slide"] {
  opacity: 0;
  visibility: hidden;
}
@media (any-hover: hover) {
  .strength-slider_arrows .strength-slider_arrow:hover {
    opacity: 0.7;
  }
}
.strength-slider_arrows .strength-slider_arrow.splide__arrow--prev {
  scale: -1;
}
.line_btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: min(100%, 420px);
  font-weight: bold;
  font-size: 16px;
  letter-spacing: 0.03em;
  text-align: center;
  color: #ffffff;
  background-color: #4cc764;
  border-radius: 6px;
  box-shadow: 0px 4px 0px #41ab55;
  padding-block: 12px;
  transition: 0.3s ease;
  position: relative;
  cursor: pointer;
}
@media only screen and (max-width: 768px) {
  .line_btn {
    font-size: 18px;
    padding: 12px;
  }
}
@media (any-hover: hover) {
  .line_btn:hover {
    box-shadow: none;
    translate: 0 4px;
  }
}
.line_btn::before {
  content: "";
  display: block;
  width: 26px;
  height: 24px;
  background: url("/assets/img/campaign/common/icon-line-white.svg") no-repeat center center/contain;
  position: static;
  margin: 0;
}
@media only screen and (max-width: 768px) {
  .line_btn::before {
    width: 30px;
    width: 32px;
    height: 30px;
  }
}
.point_headline {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 100px 0 40px;
  font-size: 42px;
  font-weight: bold;
  letter-spacing: 0.025em;
  line-height: 1.4523809524;
}
@media only screen and (max-width: 768px) {
  .point_headline {
    flex-wrap: wrap;
    padding: 0px 20px;
    font-size: 36px;
    line-height: 0.5;
  }
}
.point_headline .maru {
  margin-top: -15px;
  display: inline-block;
  width: 128px;
  -o-object-fit: contain;
  object-fit: contain;
}
@media only screen and (max-width: 768px) {
  .point_headline .maru {
    width: 100px;
    margin-top: 0;
  }
}
/* ================================================================================ */
/* キャンペーン特典 適用の流れ  */
/* ================================================================================ */
.flow {
  background-color: #eff7f2;
  padding-block: 44px 100px;
}
@media only screen and (max-width: 768px) {
  .flow {
    padding-block: 26px 80px;
  }
}
.flow_inner {
  width: min(100%, 1240px);
  padding-inline: 20px;
  margin-inline: auto;
}
@media only screen and (max-width: 768px) {
  .flow_inner {
    padding-inline: 20px;
  }
}
.flow_header {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 14px;
}
.flow_subheadline {
  font-family: "Roboto", sans-serif;
  font-weight: bold;
  font-size: 15px;
  letter-spacing: 0.1em;
  text-align: center;
  color: #86c9a8;
}
@media only screen and (max-width: 768px) {
  .flow_subheadline {
    font-size: 13px;
  }
}
.flow_headline {
  font-weight: bold;
  font-size: 42px;
  letter-spacing: 0.03em;
  text-align: center;
  color: #333;
}
@media only screen and (max-width: 768px) {
  .flow_headline {
    font-size: 36px;
    line-height: 1.3;
  }
}
.flow_list {
  display: flex;
  justify-content: space-between;
  gap: 28px;
  margin-top: 90px;
}
@media only screen and (max-width: 768px) {
  .flow_list {
    flex-direction: column;
    gap: 56px;
    margin-top: 60px;
    margin-inline: -20px;
    padding-inline: 20px;
  }
}
.flow_item {
  width: 279px;
  background-color: #fff;
  border-radius: 12px;
  padding: 45px 24px 30px;
  position: relative;
  flex-shrink: 0;
}
@media only screen and (max-width: 768px) {
  .flow_item {
    width: 100%;
    padding: 22px 24px 22px;
  }
}
.flow_item:not(:first-child)::before {
  content: "";
  display: block;
  width: 14px;
  aspect-ratio: 8/16;
  background: url("/assets/img/campaign/search-service/search-service-flow_arrow.svg") no-repeat center center/contain;
  position: absolute;
  top: 47%;
  left: -8px;
  translate: -100% -50%;
}
@media only screen and (max-width: 768px) {
  .flow_item:not(:first-child)::before {
    top: -38px;
    left: 50%;
    translate: -50% -50%;
    rotate: 90deg;
  }
}
.flow_label {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 46px;
  aspect-ratio: 1;
  font-family: "Roboto", sans-serif;
  font-weight: 500;
  font-size: 16px;
  text-align: center;
  color: #fff;
  background-color: #0e9352;
  border-radius: 100%;
  position: absolute;
  top: 0;
  left: 20px;
  translate: 0% -50%;
}
@media only screen and (max-width: 768px) {
  .flow_label {
    width: 36px;
    left: 20px;
  }
}
.flow_item_wrap {
  display: flex;
  flex-direction: column;
  gap: 13px;
}
@media only screen and (max-width: 768px) {
  .flow_item_wrap {
    display: grid;
    grid-template-columns: 70px auto;
    gap: 0px 12px;
    grid-template-areas: "image title" "image text";
  }
}
.flow_item_image {
  width: 70px;
  aspect-ratio: 1;
  margin-inline: auto;
  grid-area: image;
}
.flow_item_title {
  font-family: "Noto Sans JP";
  font-weight: bold;
  font-size: 20px;
  letter-spacing: 0.03em;
  line-height: 30px;
  color: #333;
  text-align: center;
  grid-area: title;
}
@media only screen and (max-width: 768px) {
  .flow_item_title {
    font-size: 18px;
    text-align: left;
  }
}
.flow_item_text {
  font-family: "Noto Sans JP";
  font-weight: 500;
  font-size: 15px;
  letter-spacing: 0.03em;
  line-height: 1.6;
  text-align: left;
  color: #333;
  margin-top: 5px;
  grid-area: text;
}
@media only screen and (max-width: 768px) {
  .flow_item_text {
    font-size: 16px;
    margin-top: 10px;
  }
}
.flow_item_text .flow_item_link {
  font-weight: bold;
  text-decoration: underline;
}
/* ボタン */
.flow_item_btn {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  width: min(100%, 290px);
  background-color: #0e9352;
  border-radius: 6px;
  box-shadow: 0px 4px 0px #0a6d3d;
  padding-block: 12px;
  transition: 0.3s ease;
  position: relative;
  margin-top: auto;
  cursor: pointer;
  margin-top: 5px;
}
@media (any-hover: hover) {
  .flow_item_btn:hover {
    box-shadow: none;
    translate: 0 4px;
  }
}
@media only screen and (max-width: 768px) {
  .flow_item_btn {
    font-size: 18px;
    margin-top: 16px;
  }
}
.flow_item_btn::after {
  content: "";
  display: block;
  width: 20px;
  height: 20px;
  background: url("/assets/img/campaign/common/icon_arrow-right-wh.svg") no-repeat center center/contain;
}
.flow_item_btn.--text-center {
  justify-content: center;
  margin-inline: auto;
}
.flow_item_btn.--text-center::after {
  position: absolute;
  top: 0;
  bottom: 0;
  right: 16px;
  margin: auto;
}
.flow_item_btn.mt11 {
  margin-top: 11px;
}
.flow_item_btn.line_btn {
  gap: 3px;
  background-color: #4cc764;
  box-shadow: 0px 4px 0px #41ab55;
}
.flow_item_btn.line_btn::before {
  content: "";
  display: block;
  width: 26px;
  height: 25px;
  background: url("/assets/img/campaign/common/icon-line-white.svg") no-repeat center center/contain;
  position: static;
  margin: 0;
}
.flow_item_btn.line_btn::after {
  display: none;
}
.flow_item_btn .flow_item_btn_wrap {
  display: flex;
  align-items: center;
  gap: 10px;
}
.flow_item_btn .flow_item_btn_label {
  font-weight: bold;
  font-size: 14px;
  letter-spacing: 0.1em;
  text-align: center;
  color: #0e9352;
  background-color: #ffffff;
  border-radius: 6px;
  padding: 1px 6px;
}
.flow_item_btn .flow_item_btn_text {
  font-weight: bold;
  font-size: 16px;
  text-align: center;
  color: #ffffff;
}
.flow_item_btn .flow_item_btn_text.--small {
  font-size: 17px;
  letter-spacing: 0.05em;
}
.flow_item_strong {
  font-family: "Noto Sans JP";
  font-weight: bold;
  font-size: 13px;
  letter-spacing: 0.03em;
  line-height: 21px;
  text-align: center;
  color: #0e9352;
  background-color: #eff7f2;
  padding: 11px 12px 12px;
  margin-top: 18px;
}
.flow_item_strong .--middle {
  font-size: 18px;
}
.flow_item_strong .--large {
  font-size: 20px;
}
.flow_item_strong.mt12 {
  margin-top: 15px;
}
.flow_item_strong.m18 {
  margin: 18px 0;
}

.flow_item_note {
  font-family: "Noto Sans JP";
  font-weight: 500;
  font-size: 13px;
  letter-spacing: 0.03em;
  line-height: 20.8px;
  text-align: left;
  color: #333;
  margin-top: 15px;
}
.flow_container {
  display: flex;
  flex-direction: column;
  gap: 40px;
  width: min(100%, 1000px);
  padding-inline: 20px;
  margin-top: 60px;
  margin-inline: auto;
}
@media only screen and (max-width: 768px) {
  .flow_container {
    gap: 60px;
    padding-inline: 0px;
    margin-top: 60px;
  }
}
.flow_wrap {
  display: flex;
  gap: 5.2083333333%;
}
@media only screen and (max-width: 768px) {
  .flow_wrap {
    flex-direction: column;
    gap: 18px;
  }
}
.flow_title {
  flex: 0 0 145px;
  height: -moz-fit-content;
  height: fit-content;
  font-weight: bold;
  font-size: 18px;
  letter-spacing: 0.1em;
  line-height: 1.4222222222;
  text-align: center;
  color: #0e9352;
  background-color: #f6e929;
  border-radius: 100vh;
  padding: 5px;
}
@media only screen and (max-width: 768px) {
  .flow_title {
    flex: auto;
    width: 120px;
    font-size: 16px;
    padding: 5px;
    margin-inline: auto;
  }
}
.flow_period_wrap {
  margin-top: 8px;
}
@media only screen and (max-width: 768px) {
  .flow_period_wrap {
    margin-top: 0px;
  }
}
.flow_period_text {
  font-weight: bold;
  font-size: 16px;
  letter-spacing: 0.03em;
  line-height: 1.6;
}
.flow_period_text .font_small {
  font-weight: bold;
  font-size: 13px;
  letter-spacing: 0.03em;
  line-height: 1.9692307692;
}
@media only screen and (max-width: 768px) {
  .flow_period_text .font_small {
    display: block;
  }
}
.flow_period_text + .flow_period_text {
  margin-top: 10px;
}
@media only screen and (max-width: 768px) {
  .flow_period_text + .flow_period_text {
    margin-top: 30px;
  }
}
.flow_text {
  font-size: 20px;
  font-weight: bold;
  line-height: 1.44;
  letter-spacing: 0.025em;
}
@media only screen and (max-width: 768px) {
  .flow_text.sp_center {
    text-align: center;
  }
}
@media only screen and (max-width: 768px) {
  .flow_text.--center {
    width: -moz-fit-content;
    width: fit-content;
    margin-inline: auto;
  }
}
.flow_text .year {
  font-weight: bold;
  font-size: 16px;
  letter-spacing: 0.03em;
  line-height: 1.5625;
}
@media only screen and (max-width: 768px) {
  .flow_text .year {
    display: block;
    font-size: 19px;
    line-height: 1;
  }
}
.flow_text .year .font-number {
  font-weight: bold;
  font-size: 17px;
  letter-spacing: 0.03em;
  line-height: 1.4705882353;
}
.flow_text .year.is-pc {
  display: inline-block;
}
@media only screen and (max-width: 768px) {
  .flow_text .year.is-pc {
    display: none;
  }
}
.flow_text .month {
  font-weight: bold;
  font-size: 26px;
  letter-spacing: 0.03em;
  line-height: 1;
}
.flow_text .week {
  font-weight: bold;
  font-size: 14px;
  letter-spacing: 0.03em;
  line-height: 1.4705882353;
}
.flow_text .symbol {
  font-weight: bold;
  font-size: 16px;
  letter-spacing: 0.03em;
  line-height: 1.5625;
}
.flow_body {
  flex: 1;
}
.flow_btn-wrap {
  margin-top: 40px;
}
@media only screen and (max-width: 768px) {
  .flow_btn-wrap {
    display: flex;
    justify-content: center;
  }
}
.flow_btn_text {
  width: 47.0046082949%;
  font-family: "Noto Sans JP";
  font-weight: 500;
  font-size: 15px;
  letter-spacing: 0.03em;
  line-height: 24px;
  color: #333;
}
@media only screen and (max-width: 768px) {
  .flow_btn_text {
    display: flex;
    margin-top: 20px;
    margin-inline: auto;
    font-size: 13px;
    letter-spacing: 0.025em;
    line-height: 1.6;
    width: min(100%, 372px);
  }
}
/*吹き出し*/
.flow_bubble {
  display: block;
  position: relative;
  width: 200px;
  font-family: "Roboto", sans-serif;
  font-weight: bold;
  font-size: 13px;
  letter-spacing: 0.1em;
  text-align: center;
  color: #0e9352;
  text-transform: capitalize;
  margin: 15px auto 0;
}
.flow_bubble::before, .flow_bubble::after {
  position: absolute;
  display: block;
  content: "";
  width: 36px;
  height: 1px;
  top: 50%;
  background-color: #0e9352;
}
.flow_bubble::before {
  left: -15px;
  transform: translate(0, -50%) rotate(45deg);
}
@media only screen and (max-width: 768px) {
  .flow_bubble::before {
    left: -24px;
  }
}
.flow_bubble::after {
  left: auto;
  right: -15px;
  transform: translate(0, -50%) rotate(-45deg);
}
@media only screen and (max-width: 768px) {
  .flow_bubble::after {
    right: -24px;
  }
}
/* ================================================================================ */
/* CTA センター  */
/* ================================================================================ */
@media only screen and (max-width: 768px) {
  .cta-contact_footer {
    margin-bottom: 20px;
  }
}
.cta-contact_footer.--wide {
  padding-block: 70px;
}
@media only screen and (max-width: 768px) {
  .cta-contact_footer.--wide {
    padding: 20px 16px;
  }
}
.cta-contact_footer.--wide .new-member-contact_footer-img {
  width: 196px;
}
@media only screen and (max-width: 768px) {
  .cta-contact_footer.--wide .new-member-contact_footer-img {
    width: 111px;
  }
}
.cta-contact_footer.--wide .new-member-contact_footer-img img {
  width: 100%;
  bottom: -75px;
  height: 265px;
}
@media only screen and (max-width: 768px) {
  .cta-contact_footer.--wide .new-member-contact_footer-img img {
    height: auto;
  }
}
.cta-contact_footer-img {
  width: 157px;
  position: relative;
  align-self: flex-end;
}
@media only screen and (max-width: 768px) {
  .cta-contact_footer-img {
    display: none;
  }
}
.cta-contact_footer-img img {
  width: 100%;
  position: absolute;
  bottom: -30px;
  left: 0;
}
@media only screen and (max-width: 768px) {
  .cta-contact_footer-img img {
    width: 100%;
    position: static;
    bottom: 0;
  }
}
.cta-contact_phone {
  display: flex;
  align-items: center;
  gap: 26px;
  width: -moz-fit-content;
  width: fit-content;
  border-radius: 8px;
  position: relative;
  pointer-events: none;
}
@media only screen and (max-width: 768px) {
  .cta-contact_phone {
    background-color: #ffffff;
    border: 2px solid #0e9352;
    box-shadow: 0px 4px 0px 0px #0e9352;
    padding: 4px 44px 4px;
    padding-right: 12px;
    gap: 22px;
    margin-top: 0px;
    margin-inline: auto;
    pointer-events: auto;
    width: 100%;
    max-width: 360px;
    justify-content: space-between;
  }
}
@media screen and (max-width: 374px) {
  .cta-contact_phone {
    padding: 10px 20px;
  }
}
.cta-contact_phone::after {
  content: "";
  display: none;
  aspect-ratio: 1;
  background: url("../../img/campaign/2024registration/icon_arrow-right-green.svg") no-repeat center center/contain;
}
@media only screen and (max-width: 768px) {
  .cta-contact_phone::after {
    width: 22px;
    display: block;
  }
}
.cta-contact_phone.is-sp {
  display: none;
  visibility: hidden;
}
@media only screen and (max-width: 768px) {
  .cta-contact_phone.is-sp {
    display: flex;
    visibility: visible;
  }
}
.cta-contact_phone.is-pc {
  display: flex;
  visibility: visible;
}
@media only screen and (max-width: 768px) {
  .cta-contact_phone.is-pc {
    display: none;
    visibility: hidden;
  }
}
.cta-contact_phone-label {
  font-weight: 500;
  font-size: 16px;
  letter-spacing: 0.15em;
  color: #ffffff;
  background-color: #0e9352;
  border-radius: 100vh;
  padding: 3px 18px;
  position: absolute;
  top: 8px;
  left: 30px;
  translate: 0 -50%;
}
@media only screen and (max-width: 768px) {
  .cta-contact_phone-label {
    font-size: 10px;
    padding: 3px 8px;
    top: 0;
    left: 62px;
  }
}
.cta-contact_phone-label::before {
  content: "";
  display: block;
  width: 22px;
  height: 15px;
  background-color: #0e9352;
  -webkit-clip-path: polygon(50% 0, 0 0, 100% 100%);
          clip-path: polygon(50% 0, 0 0, 100% 100%);
  position: absolute;
  top: 74%;
  left: 2px;
}
@media only screen and (max-width: 768px) {
  .cta-contact_phone-label::before {
    width: 10px;
    height: 8px;
    top: 90%;
    left: 6px;
    -webkit-clip-path: polygon(86% 0, 0 0, 100% 100%);
            clip-path: polygon(86% 0, 0 0, 100% 100%);
  }
}
.cta-contact_phone-name {
  font-size: 15.68px;
  letter-spacing: 0.5em;
  font-weight: 500;
  line-height: 2;
  text-align: right;
  color: #0e9352;
}
@media only screen and (max-width: 768px) {
  .cta-contact_phone-name {
    font-size: 11px;
    letter-spacing: 0.07em;
    line-height: 1.5;
  }
}
.cta-contact_phone-text {
  display: flex;
  align-items: center;
  gap: 4px;
}
.cta-contact_phone-text .icon {
  width: 34px;
  flex-shrink: 0;
}
@media only screen and (max-width: 768px) {
  .cta-contact_phone-text .icon {
    width: 20px;
  }
}
.cta-contact_phone-text .icon img {
  width: 100%;
  height: 100%;
}
.cta-contact_phone-text .number {
  font-family: "Roboto", sans-serif;
  font-weight: bold;
  font-size: 60px;
  letter-spacing: -0.01em;
  line-height: 1;
  color: #0e9352;
}
@media only screen and (max-width: 768px) {
  .cta-contact_phone-text .number {
    font-size: 32px;
  }
}
@media screen and (max-width: 374px) {
  .cta-contact_phone-text .number {
    font-size: 24px;
  }
}
.cta-contact_phone-time {
  font-size: 18px;
  font-weight: 500;
}
@media only screen and (max-width: 768px) {
  .cta-contact_phone-time {
    font-size: 11px;
    letter-spacing: -0.07em;
    margin-top: 0px;
  }
}
.cta-contact_btn-wrap {
  margin-top: 80px;
  display: flex;
  justify-content: center;
}
@media only screen and (max-width: 768px) {
  .cta-contact_btn-wrap {
    margin-top: 60px;
  }
}
.cta-btn2_btn {
  width: 100%;
  max-width: 420px;
  flex: 1;
}
.cta-btn2 .cta_search_footer .search-service_btn {
  font-size: 24px;
  padding: 14px;
}
.cta-btn2_btn .cta-btn {
  border: 2px solid #0e9352;
  padding: 13px;
}
.search-service_btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: min(100%, 420px);
  font-weight: bold;
  font-size: 20px;
  letter-spacing: 0.03em;
  text-align: center;
  color: #ffffff;
  background-color: #0e9352;
  border-radius: 6px;
  box-shadow: 0px 4px 0px #0a6d3d;
  padding: 18px;
  transition: 0.3s ease;
  position: relative;
  cursor: pointer;
}
.cta-btn2 .cta_search_footer.--inner-btn .cta_search_btn {
  align-items: center;
  justify-content: flex-end;
  gap: 42px;
}
.cta_search_footer.--inner-btn .cta_search_btn {
  display: flex;
  gap: 18px;
  flex: 1;
}
@media screen and (max-width: 1100px) {
  .cta_search_footer.--inner-btn .cta_search_btn {
    flex-direction: column;
  }
}
.search-service_btn:nth-child(2) {
  margin-top:15px
}
.cta_search_footer.--inner-btn {
  padding: 24px 60px 24px 24px;
}
.cta-contact_container.--small {
  width: min(100%, 940px);
  margin-inline: auto;
}
.cta-contact_container {
  margin-top: 20px;
  border-radius: 12px;
  border: 6px solid #0e9352;
}
@media only screen and (max-width: 768px) {
  .cta-contact_container {
    all: unset;
  }
}
.cta-btn::before {
    content: "";
    display: block;
    width: 26px;
    height: 26px;
    background: url(/assets/img/campaign/common/icon_arrow-right-wh.svg) no-repeat center center / contain;
    position: absolute;
    top: 0;
    bottom: 0;
    right: 26px;
    margin: auto;
}
/* ================================================================================ */
/* お客様の声  */
/* ================================================================================ */
@media only screen and (max-width: 768px) {
  .voice {
    margin-top: 60px;
  }
}
/* ================================================================================ */
/* トラックのお悩み  */
/* ================================================================================ */
/*@media only screen and (max-width: 768px) {
  .cp2025winter-point {
    margin-top: 110px;
  }
}
@media only screen and (max-width: 768px) {
  .cp2025winter-point .point_worries {
    padding-right: 10px;
  }
}*/

.point_message_strong {
  display: block;
  font-weight: bold;
  font-size: 46px;
  letter-spacing: 0.03em;
  line-height: 1;
  text-align: center;
  color: #0e9352;
  width: -moz-fit-content;
  width: fit-content;
  margin-top: 106px;
  margin-inline: auto;
  position: relative;
}
@media only screen and (max-width: 768px) {
  .point_message_strong {
    font-size: 32px;
    line-height: 0.75;
    margin-top: 70px;
  }
}
@media screen and (max-width: 374px) {
  .point_message_strong {
    font-size: 28px;
  }
}
.point_message_strong::before, .point_message_strong::after {
  position: absolute;
  content: "";
  width: 70px;
  height: 2px;
  bottom: 22px;
  background-color: #0e9352;
}
@media only screen and (max-width: 768px) {
  .point_message_strong::before, .point_message_strong::after {
    display: none;
  }
}
.point_message_strong::before {
  left: -96px;
  rotate: 70deg;
}
@media only screen and (max-width: 768px) {
  .point_message_strong::before {
    left: -48px;
  }
}
.point_message_strong::after {
  right: -96px;
  rotate: -70deg;
}
@media only screen and (max-width: 768px) {
  .point_message_strong::after {
    right: -48px;
  }
}
.point_message_quotes {
  margin-top: 69px;
}
@media only screen and (max-width: 768px) {
  .point_message_quotes {
    margin-top: 43px;
  }
}
.point_message_quote {
  width: -moz-fit-content;
  width: fit-content;
  font-family: "Noto Sans JP";
  font-weight: 700;
  font-size: 24px;
  letter-spacing: 0.03em;
  line-height: 1.5;
  text-align: center;
  color: #fff;
  background-color: #0e9352;
  margin-inline: auto;
}
@media only screen and (max-width: 768px) {
  .point_message_quote {
    font-size: 16px;
  }
}
.point_message_quote + .point_message_quote {
  margin-top: 12px;
}
@media only screen and (max-width: 768px) {
  .point_message_quote + .point_message_quote {
    margin-top: 8px;
  }
}
.point_message_note {
  font-family: "Noto Sans JP";
  font-weight: 500;
  font-size: 24px;
  letter-spacing: 0.03em;
  line-height: 1.5;
  text-align: center;
  color: #333;
  margin-top: 20px;
}
@media only screen and (max-width: 768px) {
  .point_message_note {
    font-size: 16px;
    margin-top: 12px;
  }
}
/* ================================================================================ */
/* CTA ボトム  */
/* ================================================================================ */
.bottom-cta {
  padding-inline: 20px;
  margin-block: 57px 160px;
}
@media only screen and (max-width: 768px) {
  .bottom-cta {
    padding-inline: 10px;
    margin-block: 20px 100px;
  }
}
.bottom-cta .cta_search_note.is-sp {
  display: none;
}
@media only screen and (max-width: 768px) {
  .bottom-cta .cta_search_note.is-sp {
    display: block;
  }
}
.bottom-cta .cta_search_subtitle {
  font-family: "Noto Sans JP";
  font-weight: bold;
  font-size: 22px;
  letter-spacing: 0.1em;
  text-align: center;
  color: #fff;
  padding: 14px 16px 14px;
  padding-left: 122px;
}
@media screen and (max-width: 1100px) {
  .bottom-cta .cta_search_subtitle {
    font-size: 20px;
  }
}
@media only screen and (max-width: 768px) {
  .bottom-cta .cta_search_subtitle {
    font-size: 18px;
    text-align: left;
    padding: 16px 16px 20px;
  }
}
.bottom-cta .cta_search_note::before {
  left: -60px;
}
@media only screen and (max-width: 768px) {
  .bottom-cta .cta_search_note::before {
    bottom: 30px;
    left: -35px;
    rotate: 68deg;
  }
}
.bottom-cta .cta_search_note::after {
  right: -60px;
}
@media only screen and (max-width: 768px) {
  .bottom-cta .cta_search_note::after {
    bottom: 30px;
    right: -35px;
    rotate: 110deg;
  }
}
.bottom-cta .cta_search_footer {
  gap: 10%;
  padding: 10px 17% 18px 5%;
}
@media screen and (max-width: 880px) {
  .bottom-cta .cta_search_footer {
    gap: 2%;
    padding: 10px 5% 18px 5%;
  }
}
.bottom-cta .cta_search_footer-img {
  width: 160px;
}
@media only screen and (max-width: 768px) {
  .bottom-cta .cta_search_footer-img {
    width: 110px;
  }
}
.bottom-cta .cta_search_footer-img img {
  bottom: -24px;
  left: -36px;
}
@media only screen and (max-width: 768px) {
  .bottom-cta .cta_search_btn {
    width: 100%;
  }
}
.bottom-cta .cta_search_phone-label {
  font-size: 14px;
  top: 2px;
  left: 30px;
  padding: 3px 14px;
}
@media only screen and (max-width: 768px) {
  .bottom-cta .cta_search_phone-label {
    font-size: 10px;
    padding: 3px 8px;
    top: 4px;
    left: 44px;
    translate: 0 -50%;
  }
}
.bottom-cta .cta_search_phone-name {
  line-height: 1;
  letter-spacing: 0.3em;
}
@media only screen and (max-width: 768px) {
  .bottom-cta .cta_search_phone-name {
    letter-spacing: 0.1em;
    padding-right: 10px;
  }
}
.bottom-cta .cta_search_phone-text {
  margin-top: 14px;
}
@media only screen and (max-width: 768px) {
  .bottom-cta .cta_search_phone-text {
    margin-top: 4px;
  }
}
.bottom-cta .cta_search_phone-text .icon {
  width: 30px;
}
@media only screen and (max-width: 768px) {
  .bottom-cta .cta_search_phone-text .icon {
    width: 18px;
  }
}
.bottom-cta .cta_search_phone-text .number {
  font-size: 54px;
}
@media only screen and (max-width: 768px) {
  .bottom-cta .cta_search_phone-text .number {
    font-size: 32px;
  }
}
.bottom-cta .cta_search_phone-time {
  font-size: 13px;
  letter-spacing: 0.03em;
  text-align: right;
  margin-top: 4px;
}
@media only screen and (max-width: 768px) {
  .bottom-cta .cta_search_phone-time {
    font-size: 10px;
    text-align: center;
    margin-top: -2px;
  }
}
.bottom-cta .cta_search_phone {
  justify-content: center;
  margin-top: 12px;
}
@media only screen and (max-width: 768px) {
  .bottom-cta .cta_search_phone {
    justify-content: space-between;
    padding: 6px 12px 4px 40px;
    padding-inline: 20px;
    margin-top: 8px;
  }
}
.bottom-cta .cta_search_phone::after {
  position: absolute;
  top: 50%;
  right: 12px;
  translate: 0 -50%;
}
.cta_search-green_btn {
  margin-top: 15px;
}
.cta_search-green_btn .cta-btn {
  border: 2px solid #0e9352;
  padding: 20px;
}
.cta_search-green_btn .cta-btn::before {
  right: 26px;
}
@media only screen and (max-width: 768px) {
  .cta_search-green_btn .cta-btn::before {
    right: 14px;
  }
}


.cta_search-green_link {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: min(100%, 420px);
  font-weight: bold;
  font-size: 20px;
  letter-spacing: 0.03em;
  text-align: center;
  color: #ffffff;
  background-color: #0e9352;
  border-radius: 6px;
  box-shadow: 0px 4px 0px #0a6d3d;
  padding: 18px;
  transition: 0.3s ease;
  position: relative;
  cursor: pointer;
}
@media only screen and (max-width: 768px) {
  .cta_search-green_link {
    font-size: 18px;
  }
}
.cta_search-green_link::before {
  content: "";
  display: block;
  width: 26px;
  height: 26px;
  background: url(/assets/img/campaign/common/icon_arrow-right-wh.svg) no-repeat center center / contain;
  position: absolute;
  top: 0;
  bottom: 0;
  right: 20px;
  margin: auto;
}
@media only screen and (max-width: 768px) {
  .cta_search-green_link::before {
    width: 22px;
    right: 14px;
  }
}
/*# sourceMappingURL=2025winter.css.map */