@charset "UTF-8";

[class~="js-fade_in"] {
  opacity: 0;
  -webkit-transform: translateY(40px);
          transform: translateY(40px);
  transition: opacity 0.7s ease, -webkit-transform 0.7s ease;
  transition: opacity 0.7s ease, transform 0.7s ease;
  transition: opacity 0.7s ease, transform 0.7s ease, -webkit-transform 0.7s ease;
}

[class~="js-fade_in"].is-visible {
  opacity: 1;
  -webkit-transform: translateY(0);
          transform: translateY(0);
}

.float-cv_prefix {
  line-height: 1;
  margin-bottom: 8px;
}

.float-cv_prefix::before, .float-cv_prefix::after {
  display: none;
}

.float-cv_button {
  gap: 7px;
}

.float-cv_button_inner {
  -webkit-flex: none;
          flex: none;
  width: 48.99135%;
}

.float-cv_button_anchor {
  height: 64px;
  padding: 20px 18px 20px 0;
  letter-spacing: 0.8px;
}

.float-cv_button_anchor_text {
  font-size: 1.6rem;
  line-height: 1.2;
  text-align: center;
}

.float-cv_button_anchor::after {
  right: 12px;
  width: 15px;
  height: 13px;
}

.float-cv_button_anchor.o-black {
  padding-inline: 16px 24px;
}

.float-cv_button_anchor.o-reserve .float-cv_button_anchor_text {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 24px auto;
      grid-template-columns: 24px auto;
  gap: 0 4px;
  max-width: 112px;
}

.float-cv_button_anchor.o-reserve .float-cv_button_anchor_text::before {
  display: block;
  -ms-grid-column: 1;
      grid-column: 1;
  grid-row: 1 / -1;
  -webkit-align-self: center;
              -ms-grid-row-align: center;
          align-self: center;
  width: 24px;
  height: 23px;
  margin-right: 0;
}

.float-banner {
  max-width: calc(100% - 30px);
}

.float-banner .cv-button {
  -webkit-flex-direction: row;
          flex-direction: row;
  -webkit-justify-content: space-between;
          justify-content: space-between;
  gap: 0;
}

.float-banner .cv-button__item {
  width: 49.31507%;
}

.float-banner .cv-button__anchor {
  height: 76px;
  padding: 0 15px 0 18px;
}

.float-banner .cv-button__anchor-text {
  display: inline-block;
  text-align: center;
  font-size: 1.4rem;
  line-height: 1.5;
  margin-left: 16px;
}

.float-banner .cv-button__anchor-inner::after {
  width: 10px;
  height: 10px;
}

.float-banner .cv-button__anchor.o-red .cv-button__anchor-inner::before {
  width: 39px;
  padding-top: 16px;
}

.float-banner .cv-button__anchor.o-blue .cv-button__anchor-inner::before {
  width: 31px;
  padding-top: 31px;
}

.cta-block {
  width: 97.10145%;
  margin-inline: auto;
  padding: 28px 19px 24px;
  gap: 23px;
}

.cta-block::before {
  top: 4px;
  left: 4px;
  border-width: 16px 16px 0 0;
}

.cta-block::after {
  border-width: 0 0 16px 16px;
}

.cta-block_txt {
  width: 53.86666666666666vw;
}

.cta-block_btns {
  gap: 10px;
}

.cta-block_btn-row {
  gap: 10px;
}

.cta-block_btn_anchor {
  padding-inline: 16px;
  letter-spacing: 0.8px;
}

.cta-block_btn-reserve .cta-block_btn_anchor {
  height: 80px;
  padding: 20px 24px 20px 32px;
  letter-spacing: 1.1px;
}

.cta-block_btn-reserve .cta-block_btn_anchor::after {
  right: 20px;
  width: 19px;
  height: 16px;
}

.cta-block_btn-reserve .cta-block_btn_anchor_text {
  font-size: 2.2rem;
  margin-left: -38px;
}

.cta-block_btn_anchor_text {
  font-size: 1.6rem;
  margin-left: -16px;
}

.cta-block_btn_anchor.o-black .cta-block_btn_anchor_text {
  margin-left: -8px;
}

.cta-block_btn_anchor::after {
  right: 12px;
  width: 15px;
  height: 13px;
}

.cta-block_btn_anchor.o-reserve .cta-block_btn_anchor_text::before {
  width: 30px;
  height: 30px;
}

.kv.-type_a {
  background: url(../img/kv/bg-kv_a_sp.webp) #fff no-repeat center -13vw;
  background-size: 100% auto;
}

.kv.-type_b {
  background: url(../img/kv/bg-kv_b_sp.webp) #fff no-repeat center top;
  background-size: 100% auto;
}

.kv.-type_b .kv_cta {
  margin-top: 14.32836%;
}

.kv_cta {
  margin-top: 8.79vw;
}

.reason_heading::before {
  display: none;
}

.reason_nav_list {
  width: 89.33333%;
  max-width: 335px;
  padding-inline: 0;
  gap: 0;
}

.reason_nav_item {
  padding-block: 16px;
}

.reason_nav_link {
  padding-right: 34px;
}

.reason_nav_link::before {
  width: 26px;
  height: 26px;
}

.exterior {
  padding-top: 2.13333vw;
}

.exterior_inner {
  max-width: 100%;
  width: 100%;
}

.exterior::before {
  height: 100%;
  -webkit-clip-path: polygon(0 0, 100% 20.53333vw, 100% 100%, 0 100%);
          clip-path: polygon(0 0, 100% 20.53333vw, 100% 100%, 0 100%);
}

.exterior_title {
  width: 90.4%;
  margin-left: 6.93333vw;
  margin-bottom: 6.4vw;
}

.exterior_main {
  width: 100%;
  margin-inline: 0;
  margin-bottom: 6.4vw;
}

.body-color {
  margin-top: 10.66667vw;
  padding-bottom: 14.4vw;
}

.body-color::before {
  padding-top: 80.8%;
}

.body-color_heading {
  -webkit-flex-direction: column;
          flex-direction: column;
  -webkit-align-items: flex-start;
          align-items: flex-start;
  gap: 3.2vw;
  margin-bottom: 1.33333vw;
}

.body-color_title {
  width: 39.46667vw;
}

.body-color_sub {
  font-size: 1.5rem;
  white-space: normal;
}

.body-color_slider-area {
  width: calc(100% + get_vw(10));
  margin-inline: -1.33333vw;
}

.body-color-slide_inner {
  width: 100%;
}

.body-color_nav {
  top: calc(50% - 3px);
}

.body-color_nav::before {
  width: 4vw;
  padding-top: 8vw;
}

.body-color_nav-prev {
  left: 0;
}

.body-color_nav-next {
  right: 0;
}

.body-color_info {
  width: 93.62319%;
  margin-inline: auto;
  gap: 6.93333vw;
  margin-top: 6.66667vw;
}

.body-color_name {
  font-size: 1.5rem;
  padding-inline: 0;
}

.body-color-slider {
  max-width: 100%;
  width: 100%;
}

.body-color-pagination {
  -webkit-flex-wrap: wrap;
          flex-wrap: wrap;
  -webkit-align-content: center;
          align-content: center;
  gap: 5.33333vw;
  min-height: 21.33333vw;
}

.body-color-dot {
  width: 8vw;
  height: 8vw;
}

.grade-tab_menu-item {
  display: -webkit-flex;
  display: flex;
}

.grade-tab_menu-item::after {
  bottom: -12px;
  border-width: 12px 9px 0;
}

.grade-tab_panels {
  padding-block: 40px 22px;
  padding-inline: 5.97015%;
}

.grade-tab_menu-btn {
  -webkit-flex: 1;
          flex: 1;
  font-size: 1.4rem;
  padding: 20px 8px 28px;
}

.grade-tab_menu-btn::after {
  right: auto;
  top: auto;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  bottom: 8px;
  left: 50%;
  width: 18px;
  height: 14px;
}

.grade-box_heading {
  gap: 12px;
}

.grade-box_title {
  font-size: 2.4rem;
}

.grade-box_heading_text {
  font-size: 1.5rem;
}

.grade-box_car {
  gap: 12px;
}

.grade-box_car_caption {
  padding: 10px;
}

.grade-box_bvc {
  margin-top: 12px;
}

.reason-set {
  max-width: 93.62319%;
  margin-inline: auto;
  -webkit-flex-direction: column;
          flex-direction: column;
  gap: 6.93333vw;
}

.reason-set--exterior {
  max-width: 100%;
  margin-inline: 0;
  padding-inline: 6.93333vw;
}

.reason-set_item_txt {
  font-size: 1.8rem;
  padding: 1.8rem 1rem;
}

.side-nav {
  position: fixed;
  right: 8px;
  top: 8px;
  bottom: auto;
  z-index: 100;
  height: fit-content; 
}

.side-nav_panel {
  display: -webkit-flex;
  display: flex;
  -webkit-flex-direction: column;
          flex-direction: column;
  width: 72px;
  padding-block: 10px;
  border-radius: 4px;
  transition: background 0.5s, border-radius 0.5s, -webkit-filter 0.5s;
  transition: background 0.5s, filter 0.5s, border-radius 0.5s;
  transition: background 0.5s, filter 0.5s, border-radius 0.5s, -webkit-filter 0.5s;
}

.side-nav_item {
  display: -webkit-flex;
  display: flex;
  -webkit-flex-direction: column;
          flex-direction: column;
  -webkit-align-items: center;
          align-items: center;
  -webkit-justify-content: center;
          justify-content: center;
  gap: 4px;
  padding: 0;
  text-decoration: none;
  color: #000;
  max-height: 0;
  overflow: hidden;
  opacity: 0;
  transition: opacity 0.5s, max-height 0.5s ease, padding 0.5s;
}

.side-nav_item_icon {
  width: 26px;
  height: 26px;
}

.side-nav_item_txt {
  font-size: 1.1rem;
  font-weight: 700;
  line-height: 1.4;
  text-align: center;
}

.side-nav_divider {
  display: block;
  width: 52px;
  height: 0;
  background: #d9d9d9;
  margin: 0 auto;
  opacity: 0;
  transition: opacity 0.5s, height 0.5s;
}

.side-nav.is-open .side-nav_panel {
  background: #fff;
  border-radius: 4px;
  -webkit-filter: drop-shadow(-4px 4px 15px rgba(9, 6, 58, 0.2));
          filter: drop-shadow(-4px 4px 15px rgba(9, 6, 58, 0.2));
}

.side-nav.is-open .side-nav_item {
  max-height: 100px;
  opacity: 1;
  padding: 10px 0 14px;
}

.side-nav.is-open .side-nav_item:last-child {
  padding-bottom: 4px;
}

.side-nav.is-open .side-nav_divider {
  height: 1px;
  opacity: 1;
}

.side-nav_toggle {
  display: -webkit-flex;
  display: flex;
  -webkit-flex-direction: column;
          flex-direction: column;
  -webkit-align-items: center;
          align-items: center;
  -webkit-justify-content: center;
          justify-content: center;
  gap: 8px;
  width: 52px;
  height: 52px;
  padding: 0;
  border: none;
  border-radius: 4px;
  background: #158cb9;
  cursor: pointer;
  -webkit-flex-shrink: 0;
          flex-shrink: 0;
  -webkit-align-self: flex-end;
          align-self: flex-end;
  margin: 0 auto;
}

.side-nav_toggle_lines {
  display: -webkit-flex;
  display: flex;
  -webkit-flex-direction: column;
          flex-direction: column;
  gap: 7px;
  width: 28px;
}

.side-nav_toggle_lines_bar {
  display: block;
  height: 2px;
  background: #fff;
  border-radius: 1px;
  transition: opacity 0.5s, -webkit-transform 0.5s;
  transition: transform 0.5s, opacity 0.5s;
  transition: transform 0.5s, opacity 0.5s, -webkit-transform 0.5s;
  -webkit-transform-origin: center;
          transform-origin: center;
}

.side-nav.is-open .side-nav_toggle_lines_bar:nth-child(1) {
  -webkit-transform: translateY(4.5px) rotate(25deg);
          transform: translateY(4.5px) rotate(25deg);
}

.side-nav.is-open .side-nav_toggle_lines_bar:nth-child(2) {
  -webkit-transform: translateY(-4.5px) rotate(-25deg);
          transform: translateY(-4.5px) rotate(-25deg);
}

.side-nav_toggle_txt {
  position: relative;
  display: block;
  width: 100%;
  height: 11px;
  line-height: 1;
}

.side-nav_toggle_txt_menu, .side-nav_toggle_txt_close {
  position: absolute;
  top: 0;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  transition: opacity 0.5s;
}

.side-nav_toggle_txt_close {
  opacity: 0;
}

.side-nav.is-open .side-nav_toggle_txt_menu {
  opacity: 0;
}

.side-nav.is-open .side-nav_toggle_txt_close {
  opacity: 1;
}

.section_inner {
  width: 92%;
}

.pagetop {
  bottom: 161px;
  right: 15px;
}

.pagetop_anchor {
  width: 38px;
  padding-top: 38px;
}

.float-bottom-conversion {
  height: auto;
  padding-inline: 0;
}


.reason_heading {
  padding-block: 25.333vw 12.8vw;
}

.reason_title {
  width: 53.33333vw;
  margin: 0 auto 4.8vw;
}

.comfortable {
  padding-block: 6.93333vw 35.46667vw;
}

.comfortable_inner {
  max-width: 100%;
  width: 100%;
}

.comfortable_title {
  width: 90.4%;
  margin-inline: 2.66667% 6.93333%;
  padding-top: 0;
  margin-bottom: 2.6rem;
}

.comfortable_heading {
  width: 93.62319%;
  margin-inline: auto;
  gap: 1.2rem;
  margin-bottom: 2rem;
}

.comfortable_heading_title {
  width: 80.49536%;
}

.comfortable_heading_sub {
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 1.5;
  margin-top: 0;
}

.comfortable_car {
  width: 108.69565%;
  margin-inline: -4.34783%;
}

.e-power {
  padding-bottom: 17.06667vw;
  margin-top: -20.53333vw;
}

.e-power::before {
  height: 100%;
  -webkit-clip-path: polygon(0 0, 100% 20.53333vw, 100% 100%, 0 100%);
          clip-path: polygon(0 0, 100% 20.53333vw, 100% 100%, 0 100%);
}

.e-power_inner {
  max-width: 100%;
  width: 100%;
  padding-top: 2.13333vw;
}

.e-power_title {
  width: 90.4%;
  margin-left: 6.93333vw;
  margin-bottom: 6.4vw;
}

.e-power_sets {
  margin-top: -4.8vw;
}

.safety {
  padding-bottom: 12.8vw;
  margin-top: 0;
  background: url(../img/share/bg-gradation_bottom_sp.png) #ddf0f4 no-repeat center bottom;
  background-size: 100% auto;
}

.safety_inner {
  max-width: 100%;
  width: 100%;
  padding-top: 6.93333vw;
}

.safety_title {
  width: 90.4%;
  margin-inline: 2.66667vw 6.93333vw;
  margin-bottom: 6.4vw;
}

.safety_heading {
  width: 93.62319%;
  margin-inline: auto;
  gap: 1.2rem;
  margin-bottom: 4rem;
  margin-top: 0;
}

.safety_heading_title {
  width: 84.21053%;
}

.safety_heading_sub {
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 1.5;
  white-space: nowrap;
  margin-top: 0;
}

.safety_cta {
  margin-top: 17.86667vw;
}

.grade {
  background: url(../img/share/bg-grade_top_sp.png) #f2f2f2 no-repeat center top;
  background-size: 100% auto;
}

.grade_inner {
  padding-bottom: 48px;
  background: url(../img/share/bg-gradation_bottom_sp.png) no-repeat center bottom;
  background-size: 100% auto;
  padding-top: 64px;
}

.grade_inner .section_inner {
  width: 89.33333%;
}

.grade_title {
  width: 88.0597%;
  margin: 0 auto 32px;
}

.campaign_title {
  width: 94.2029%;
  margin-bottom: 24px;
}

.campaign_bnr {
  width: 97.10145%;
  margin-inline: auto;
  margin-bottom: 24px;
}

.campaign_btn_anchor {
  width: 88.98551%;
  height: 80px;
  padding: 15px 5.86319% 15px 8.46906%;
}

.campaign_btn_anchor::after {
  right: 24px;
  width: 19px;
  height: 16px;
}

.campaign_btn_anchor_text {
  display: inline-block;
  width: 86.69202%;
}

.bottom-contents {
  margin-top: 48px;
  padding-bottom: 60px;
}

.bottom-contents::before {
  background-image: url(../img/share/bg-bottom_contents_sp.jpg);
}

.fair_inner {
  max-width: 89.33333%;
}

.instagram_title {
  width: 97.10145%;
  margin-bottom: 30px;
}

.instagram_content {
  width: 97.10145%;
  margin-inline: auto;
  gap: 1.86667vw 2.08955%;
}

.instagram_post {
  width: 48.95522%;
  padding: 2.68657%;
  gap: 10px;
  border-radius: 6px;
}

.instagram_post_image {
  aspect-ratio: 278 / 348;
}

.instagram_post_link {
  font-size: 1.2rem;
}

.dummy {
  margin-top: 40px;
}

.dummy_title {
  margin-bottom: 30px;
}

.dummy_cta:not(:last-child) {
  margin-bottom: 40px;
}

.header_name_image {
  width: 71px;
  height: auto;
}