@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: 3px;
}

.float-cv_prefix .image {
  width: min(204px, 54.4vw);
}

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

.float-cv_button {
  -webkit-flex-direction: column;
          flex-direction: column;
  gap: 4px;
}

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

.float-cv_button_anchor {
  height: 36px;
  padding: 0 34px 0 18px;
  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 {
  height: 27px;
  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: none;
  -webkit-align-items: center;
          align-items: center;
}

.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-cv_button_anchor.o-black .float-cv_button_anchor_text {
  font-size: 1.4rem;
}

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

.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 {
  max-width: 549px;
  width: 66.666666vw;
}

.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: 12px;
  width: 19px;
  height: 16px;
}

.cta-block_btn-reserve .cta-block_btn_anchor_text {
  font-size: 1.8rem;
  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: 19px;
  height: 16px;
}

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

.kv.-type_a {
  background: url(../img/kv/bg-kv_a_sp.webp) #fff no-repeat center top;
  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;
  height: -webkit-fit-content;
  height: -moz-fit-content;
  height: fit-content;
  z-index: 1100;
}

.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;
  z-index: 1200;
}

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

.float-bottom-conversion {
  height: 128px;
  padding-block: 8px 13px;
  padding-inline: 0;
}


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

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

@media screen and (min-width: 390px) {
  .reason_heading {
    padding-block: clamp(86px, 25vw, 120px) clamp(40px, 8vw, 64px);
  }
}

@media screen and (min-width: 450px) {
  .reason_heading {
    padding-block: clamp(160px, 36vw, 186px) clamp(40px, 8vw, 64px);
  }
}

@media screen and (min-width: 480px) {
  .reason_heading {
    padding-block: clamp(170px, 39vw, 320px) clamp(40px, 8vw, 64px);
  }
}

.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%;
  max-width: 980px;
  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: 56px;
}

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

.fair_inner {
  max-width: 89.33333%;
}

.fair_banner {
  margin-bottom: 0;
}

.fair_arrow {
  display: none;
}

.fair_image {
  width: 100%;
  margin: 51px auto 0;
  line-height: 0;
}

.fair_cta-area {
  margin-top: 0;
  padding-top: 95px;
}

.fair_cta-area::before {
  background-image: url(../img/share/bg-cta_sp.png);
}

.fair_cta {
  margin-top: 0;
}

.reservation {
  margin-top: 80px;
}

.reservation_inner {
  display: -webkit-flex;
  display: flex;
  -webkit-flex-direction: column;
          flex-direction: column;
  gap: 24px;
  width: 100%;
  margin-inline: auto;
  line-height: 0;
}

.reservation_texts {
  display: -webkit-flex;
  display: flex;
  -webkit-flex-direction: column;
          flex-direction: column;
  gap: 24px;
  width: 70.66667vw;
  max-width: 265px;
  margin-inline: auto;
}

.reservation_title {
  display: block;
  width: 100%;
}

.reservation_lead {
  display: block;
  width: 60.8vw;
  max-width: 100%;
  margin-inline: auto;
}

.area {
  display: -webkit-flex;
  display: flex;
  -webkit-flex-direction: column;
          flex-direction: column;
  gap: 24px;
  width: 87.2vw;
  margin-inline: auto;
}

.reservation_area-wrap::before {
  background-image:url(../img/share/bg-cta-02_sp.png);
}

.area_map {
  display: block;
  width: 100%;
}

.area_buttons {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 8px 1fr;
      grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.area_button {
  position: relative;
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
          align-items: center;
  -webkit-justify-content: center;
          justify-content: center;
  width: 100%;
  height: 64px;
  border: 0;
  padding: 20px 28px;
  color: #fff;
  font-family: "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
  font-size: 1.4rem;
  font-weight: 600;
  letter-spacing: 0.7px;
  line-height: 1.4;
  cursor: pointer;
}

.area_button::after {
  content: '';
  position: absolute;
  top: 50%;
  right: 12px;
  width: 10px;
  height: 8.332px;
  background: url(../img/share/ico-area_button_arrow.svg) no-repeat center/contain;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}

.area_button_break {
  display: block;
}

.area_button--oita {
  background-color: #e37733;
}

.area_button--beppu {
  background-color: #8c5e88;
}

.area_button--nakatsu {
  background-color: #e196a2;
}

.area_button--saeki {
  background-color: #e9bc6f;
}

.area_button--kitsuki {
  background-color: #9ecc84;
}

.area_button--bungo {
  background-color: #657ab5;
}

.shop-panels {
  max-width: 880px;
  width: 100%;
  margin: 51px auto 0;
  padding-bottom: 120px;
}

.shop-list {
  display: none;
}

.shop-list.is-active {
  display: -webkit-flex;
  display: flex;
  -webkit-flex-direction: column;
          flex-direction: column;
  -webkit-align-items: center;
          align-items: center;
  gap: 40px;
  width: 100%;
  -webkit-animation: area-panel-fade-in 0.35s ease forwards;
          animation: area-panel-fade-in 0.35s ease forwards;
}

.shop-list_title {
  margin: 0;
  line-height: 0;
}

.shop-list_title .image {
  width: auto;
}

.shop-list_cards {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr;
      grid-template-columns: 1fr;
  gap: 40px;
  width: 100%;
}

.shop-card {
  display: -webkit-flex;
  display: flex;
  -webkit-flex-direction: column;
          flex-direction: column;
  gap: 24px;
  min-width: 0;
  width: 100%;
}

.shop-card_image {
  width: 100%;
  height: clamp(207px, 55.2vw, 320px);
  overflow: hidden;
}

.shop-card_image .image {
  height: 100%;
  object-fit: cover;
}

.shop-card_info {
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: flex-start;
          align-items: flex-start;
  -webkit-justify-content: space-between;
          justify-content: space-between;
  gap: 12px;
  min-width: 0;
  width: 100%;
}

.shop-card_text {
  -webkit-flex: 1 1 auto;
          flex: 1 1 auto;
  width: auto;
  min-width: 0;
  color: #fff;
  text-align: left;
}

.shop-card_name {
  margin: 0;
  font-size: 2.0rem;
  font-weight: 700;
  line-height: 1.0;
}

.shop-card_address {
  font-size: 1.4rem;
  font-weight: 500;
  line-height: 1.4;
}

.shop-card_button {
  display: block;
  -webkit-flex: 0 0 auto;
          flex: 0 0 auto;
  width: 117px;
  max-width: 100%;
  height: auto;
  border: 0;
  padding: 0;
  background: transparent;
  cursor: pointer;
  text-decoration: none;
}

.instagram {
  margin-top: 40px;
}

.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: 105px;
}
