body,
h1,
h2,
h3,
h4,
p,
figure,
blockquote,
dl,
dd {
  margin: 0;
}

ul,
ol {
  list-style: none;
  padding: 0;
  margin: 0;
}

a {
  text-decoration: none;
  color: #111;
}

img,
picture {
  max-width: 100%;
  display: block;
}

.pc_only {
  display: block;
}
.sp_only {
  display: none;
}


@font-face {
  font-family: "Local Noto Sans CJK JP";
  src: local("Noto Sans CJK JP");
}
@font-face {
  font-family: "Noto Sans CJK JP";
  font-style: normal;
  font-weight: 100 900;
  src: url("../font/NotoSansCJK-VF.ttf.Da4-PD0P.ttc") format("truetype");
  font-display: swap;
}
@font-face {
  font-family: "Noto Sans Mono CJK JP";
  font-style: normal;
  font-weight: 100 900;
  src: url("../font/NotoSansMonoCJK-VF.ttf.B20g0HkQ.ttc") format("truetype");
  font-display: swap;
}
@font-face {
  font-family: "Local Noto Sans JP";
  src: local("Noto Sans JP");
}
@font-face {
  font-family: "Royal Enfield Sans Text";
  font-weight: 300;
  src: url("../font/RoyalEnfieldSansText-Light.CRUwGQIZ.woff2") format("woff2");
  font-display: swap;
}
@font-face {
  font-family: "Royal Enfield Sans Text";
  font-weight: 400;
  src: url("../font/RoyalEnfieldSansText-Regular.WHQfkb_t.woff2") format("woff2");
  font-display: swap;
}
@font-face {
  font-family: "Royal Enfield Sans Text";
  font-weight: 600;
  src: url("../font/RoyalEnfieldSansText-Semibold.BTqe-wl-.woff2") format("woff2");
  font-display: swap;
}
@font-face {
  font-family: "Royal Enfield Sans Text";
  font-weight: 700;
  src: url("../font/RoyalEnfieldSansText-Bold.CQxBYAtk.woff2") format("woff2");
  font-display: swap;
}
:root {
  --view-size: 1440;
  /* inner */
  --inner: min(1100px, 100%);
  --inner-sp: min(600px, 100%);
  --padding-inner: 20px;
  /* z-index */
  --z-index-header: 900;
  /* color */
  --color-white: #fff;
  --color-text: #0d2936;
  --color-black: #000;
  --color-gray: #f0f0f0;
  --color-border-gray: #aaaaaf;
  --color-accent: #408f95;
  --color-primary: #234f5e;
  --color-secondary: #00f;
  --color-orange: #de8430;
  --color-brown-50: rgb(217 106 27 / 50%);
  /* font-weight */
  --fw-light: 300;
  --fw-regular: 400;
  --fw-medium: 500;
  --fw-bold: 700;
  /* font-family */
  --base-font-family: "Local Noto Sans CJK JP", "Noto Sans CJK JP", "Local Noto Sans JP", "Noto Sans JP", sans-serif;
  --mono-font-family: "Noto Sans Mono CJK JP", monospace;
  --title-font-family: "Royal Enfield Sans Text", "Lato", sans-serif;
  /* transition duration */
  --duration: 0.3s;
  /* header height */
  --header-height: 80px;
}

html {
  scroll-behavior: smooth;
}

body {
  font-family: var(--base-font-family);
  font-weight: var(--fw-regular);
  color: var(--color-text);
  background-color: var(--color-black);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

button {
  appearance: none;
  background-color: transparent;
  border-style: none;
  overflow: visible;
  cursor: pointer;
  text-transform: none;
}

button::-moz-focus-inner,
[type=button]::-moz-focus-inner {
  padding: 0;
  border-style: none;
}

.u-sp {
  display: none;
}

.u-pc {
  display: block;
}

.l-inner {
  max-width: calc(var(--inner) + var(--padding-inner) * 2);
  padding-inline: var(--padding-inner);
  margin-inline: auto;
}

.l-top {
  background-color: #000;
}

/* ======================================================
   footer
====================================================== */

.p-footer {
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: #004098;
  position: relative;
}

.p-footer__inner {
  display: flex;
  flex-direction: column;
  gap: 15px;
  align-items: center;
  padding-block: 15px;
}

.p-footer__logo {
  display: block;
}

.p-footer__logo img {
  display: block;
  width: 69px;
  height: 44px;
  object-fit: contain;
}

.p-footer__copy {
  font-family: Inter, sans-serif;
  font-size: 10px;
  font-weight: 400;
  line-height: 2.3;
  color: var(--color-white);
  text-align: center;
}

/* ======================================================
   header
====================================================== */

.p-header {
  position: fixed;
  top: 0;
  left: 0;
  z-index: var(--z-index-header);
  width: 100%;
  height: 90px;
  background-color: rgba(0, 0, 0, 0.5);
  transition: background-color var(--duration);
}
.p-header:has(.p-header__hamburger[aria-expanded=true]) {
  background-color: var(--color-black);
}

.p-header__inner {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 100%;
  padding-inline: 30px;
}

.p-header__logo {
  display: flex;
  flex-shrink: 0;
  align-items: center;
  height: 100%;
}
.p-header__logo img {
  width: auto;
  height: 60px;
  object-fit: contain;
}

.p-header__nav-list {
  display: flex;
  gap: 0;
  align-items: center;
  list-style: none;
}

.p-header__nav-item {
  display: flex;
  align-items: center;
}

.p-header__nav-item--sep::before {
  display: block;
  width: 1px;
  height: 34px;
  content: "";
  background-color: var(--color-white);
}

.p-header__nav-link {
  display: flex;
  align-items: center;
  padding-inline: 15px;
  font-size: 16px;
  font-weight: 900;
  line-height: 1.2;
  color: var(--color-white);
  text-decoration: none;
  white-space: nowrap;
  transition: opacity var(--duration);
}

@media (any-hover: hover) {
  .p-header__nav-link:hover {
    opacity: 0.75;
  }
}

.p-header__nav-num {
  font-family: var(--title-font-family);
  font-size: 18px;
  font-weight: 700;
}

.p-header__hamburger {
  display: none;
  flex-direction: column;
  justify-content: space-between;
  width: 20px;
  height: 17px;
  padding: 0;
  cursor: pointer;
  background: none;
  border: none;
}

.p-header__hamburger span {
  display: block;
  width: 100%;
  height: 2px;
  background-color: var(--color-white);
  border-radius: 1px;
  transition: transform var(--duration), opacity var(--duration);
}

.p-header__hamburger[aria-expanded=true] span:first-child {
  transform: translateY(7.5px) rotate(45deg);
}

.p-header__hamburger[aria-expanded=true] span:nth-child(2) {
  opacity: 0;
}

.p-header__hamburger[aria-expanded=true] span:last-child {
  transform: translateY(-7.5px) rotate(-45deg);
}

.p-header__drawer {
  position: fixed;
  top: 50px;
  left: 0;
  display: none;
  width: 100%;
  height: calc(100dvh - 50px);
  overflow-y: auto;
  visibility: hidden;
  background-color: rgba(0, 0, 0, 0.95);
  opacity: 0;
}

.p-header__drawer-list {
  display: flex;
  flex-direction: column;
  gap: 43px;
  padding: 85px 15px 40px;
  list-style: none;
}

.p-header__drawer-item {
  display: flex;
  align-items: stretch;
}
.p-header__drawer-item::before {
  display: block;
  flex-shrink: 0;
  width: 7px;
  content: "";
  background-color: #f7f3eb;
}

.p-header__drawer-link {
  padding-left: 15px;
  font-size: 20px;
  font-weight: 900;
  line-height: 1.5;
  color: #f7f3eb;
  text-decoration: none;
  letter-spacing: 0.4px;
  transition: opacity var(--duration);
}

@media (any-hover: hover) {
  .p-header__drawer-link:hover {
    opacity: 0.75;
  }
}

.p-header__drawer-link .p-header__nav-num {
  font-family: var(--title-font-family);
  font-size: 32px;
  font-weight: 700;
  letter-spacing: 0.64px;
}

/* ======================================================
   kv
====================================================== */

.p-kv {
  position: relative;
  width: 100%;
  overflow: hidden;
}

.p-kv__bg {
  z-index: 0;
}
.p-kv__bg picture,
.p-kv__bg img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.p-kv__content {
  position: absolute;
  inset: 0;
  z-index: 1;
  display: flex;
  justify-content: center;
  padding-top: 13%;
}

.p-kv__titles {
  display: block;
  text-align: center;
}

.p-kv__title-img {
  width: 64.375%;
  height: auto;
  object-fit: contain;
  margin-inline: auto;
}

/* ======================================================
   lineup
====================================================== */

.p-lineup {
  padding-block-start: 150px;
  color: #f7f3eb;
  background-color: var(--color-black);
}

.p-lineup__title-wrap {
  display: flex;
  justify-content: center;
}
.p-lineup__title-wrap picture {
  display: block;
  width: 100%;
}
.p-lineup__title-wrap img {
  display: block;
  width: 100%;
  height: auto;
  object-fit: contain;
}

.p-lineup__body {
  margin-block-start: 140px;
}

.p-lineup__tab-nav {
  position: relative;
  z-index: calc(var(--z-index-header) - 2);
  width: 100%;
  max-width: 775px;
  height: auto;
  margin-inline: auto;
  overflow-x: auto;
  background-color: var(--color-black);
  border: 1px solid #d96a1b;
  scrollbar-width: none;
  margin-block-start: 100px;
}

.p-lineup__tab-nav--follow {
  position: fixed;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  margin-block-start: 0;
  visibility: hidden;
  opacity: 0;
  transition: opacity var(--duration), visibility var(--duration);
}

.p-lineup__tab-nav--follow.is-visible {
  visibility: visible;
  opacity: 1;
}

.p-lineup__tab-nav--follow.is-hidden {
  visibility: hidden;
  opacity: 0;
}

.p-lineup__tab-nav::-webkit-scrollbar {
  display: none;
}

.p-lineup__tab-list {
  display: grid;
  grid-template-columns: 58fr 144fr 162fr 122fr 99fr 121fr;
  align-items: stretch;
  max-width: min(775px, 100%);
  padding-inline: 24px;
  margin-inline: auto;
  list-style: none;
}

.p-lineup__tab-item {
  display: flex;
  flex: 1;
}

.p-lineup__tab-item--top {
  position: relative;
}
.p-lineup__tab-item--top::after {
  position: absolute;
  top: 50%;
  right: -2px;
  width: 1px;
  height: 16px;
  content: "";
  background-color: #f7f3eb;
  transform: translateY(-50%);
}

.p-lineup__tab-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 60px;
  text-decoration: none;
}

.p-lineup__tab-btn img {
  height: 100%;
  width: auto;
}

.p-lineup__tab-btn-img--on {
  display: none;
}

.p-lineup__tab-btn.is-active .p-lineup__tab-btn-img--off {
  display: none;
}

.p-lineup__tab-btn.is-active .p-lineup__tab-btn-img--on {
  display: block;
}

/* ======================================================
   page-nav
====================================================== */

.p-page-nav {
  padding-block: 120px;
  background-color: var(--color-black);
  position: relative;
}

.p-page-nav__list {
  display: flex;
  flex-wrap: wrap;
  gap: 0;
  align-items: center;
  justify-content: center;
  list-style: none;
}

.p-page-nav__item {
  display: flex;
  align-items: center;
}

.p-page-nav__item--sep::before {
  display: block;
  width: 1px;
  height: 34px;
  content: "";
  background-color: var(--color-white);
}

.p-page-nav__link {
  display: flex;
  align-items: center;
  padding-inline: 15px;
  font-size: 16px;
  font-weight: 900;
  line-height: 1.2;
  color: var(--color-white);
  text-decoration: none;
  white-space: nowrap;
  transition: opacity var(--duration);
}

@media (any-hover: hover) {
  .p-page-nav__link:hover {
    opacity: 0.75;
  }
}

.p-page-nav__num {
  font-family: var(--title-font-family);
  font-size: 18px;
  font-weight: 700;
}

/* ======================================================
   topics
====================================================== */

.p-topics {
  padding-block-start: 150px;
  color: #f7f3eb;
}

.p-topics__title-wrap {
  display: flex;
  justify-content: center;
}

.p-topics__title-wrap picture {
  display: block;
  width: 100%;
}

.p-topics__title-wrap img {
  display: block;
  width: 100%;
  height: auto;
  object-fit: contain;
}

.p-topics__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 80px 40px;
  height: 100%;
  padding-block-start: 100px;
}
.p-topics__grid.swiper {
  overflow: visible;
}
.p-topics__grid .swiper-wrapper {
  display: contents;
}

.p-topics__pager {
  display: none;
}

.p-topics__pager-row {
  display: flex;
  gap: 15px;
  justify-content: center;
}

.p-topics__pager-row + .p-topics__pager-row {
  gap: 20px;
  margin-block-start: 15px;
}

.p-topics__pager-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  font-family: var(--title-font-family);
  font-size: 24px;
  font-weight: 700;
  color: var(--color-brown-50);
  cursor: pointer;
  transition: background-color var(--duration), border-color var(--duration);
}

.p-topics__pager-btn.is-active {
  color: var(--color-white);
}

.p-topics-card {
  position: relative;
  display: flex;
  flex-direction: column;
  color: #f7f3eb;
}

.p-topics-card__head {
  position: absolute;
  top: -52px;
  left: 10px;
  margin-block-end: 5px;
  background-color: var(--color-black);
}

.p-topics-card__num {
  display: block;
  padding-inline: 10px 5px;
  font-family: var(--title-font-family);
  font-size: 70px;
  font-weight: 700;
  line-height: 1.0142857143;
  color: #f7f3eb;
  background-color: var(--color-black);
  transform: translateX(-5px);
}

.p-topics-card__num-line {
  width: 98px;
  height: 10px;
  background-color: var(--color-black);
}

.p-topics-card__body {
  flex-grow: 1;
  min-height: 370px;
  padding: 20px 15px;
  border: 1px solid #f7f3eb;
}

.p-topics-card__img {
  margin-block-end: 16px;
  position: relative;
  z-index: 2;
}
.p-topics-card__img picture {
  display: block;
  width: 100%;
}
.p-topics-card__img img {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 310/174;
  object-fit: cover;
}

.p-topics-card__text {
  font-size: 16px;
  font-weight: 400;
  line-height: 1.8125;
  color: #f7f3eb;
}

/* ======================================================
   value
====================================================== */

.p-value {
  padding-block-start: 100px;
  color: #f7f3eb;
}

.p-value__title-wrap {
  display: flex;
  justify-content: center;
  margin-block-end: 60px;
}
.p-value__title-wrap picture {
  display: block;
  width: 100%;
}
.p-value__title-wrap img {
  display: block;
  width: 100%;
  height: auto;
  object-fit: contain;
}

.p-value__body {
  display: grid;
  grid-template-columns: 385px 1fr;
  gap: 100px;
  align-items: start;
}

.p-value__text {
  font-size: 16px;
  font-weight: 400;
  line-height: 1.8125;
  color: #f7f3eb;
}

.p-value__text p:not(:first-child) {
  margin-top: 29px;
}

.p-value__images {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px;
}

.p-value__images--sp {
  display: none;
}

.p-value__images--pc {
  display: grid;
}

.p-value__img-item {
  overflow: hidden;
}

.p-value__img-item picture {
  display: block;
  width: 100%;
}

.p-value__img-item img {
  display: block;
  width: 100%;
  height: auto;
  object-fit: cover;
}

/* ======================================================
   vehicle
====================================================== */

.p-vehicle {
  position: relative;
  color: #f7f3eb;
  background-color: var(--color-black);
}

.p-vehicle__bg {
  position: sticky;
  top: 0;
  width: 100%;
  height: 985px;
  z-index: 0;
}

.p-vehicle__bg img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  min-height: 100vh;
}

.p-vehicle__bg img {
}

.p-vehicle__layout {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 480fr 560fr;
  gap: 60px;
  margin-top: -985px;
  min-height: 985px;
}

.p-vehicle--even .p-vehicle__layout {
  grid-template-columns: 1fr 480px;
}

.p-vehicle__overlay-col {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-start;
  padding-block: 100px;
  padding-inline: 20px;
  background-color: rgba(0, 0, 0, 0.5);
}

.p-vehicle__img-col {
  position: sticky;
  top: 0;
  align-self: start;
  box-sizing: border-box;
  height: 985px;
  padding-block: 100px;
}

.p-vehicle__title {
  display: block;
  width: 100%;
  margin-inline: auto;
}

.p-vehicle__title--himalayan {
  max-width: 520px;
}

.p-vehicle__title--bear {
  max-width: 513px;
}

.p-vehicle__title-img {
  max-width: 100%;
  height: auto;
  object-fit: contain;
}

.p-vehicle__picture {
  display: block;
  margin-block-start: 40px;
}

.p-vehicle__picture--himalayan {
  margin-block-start: 50px;
}

.p-vehicle__picture--goan {
  margin-block-start: 35px;
}

.p-vehicle__picture--bear {
  margin-block: 0 -36px;
}

.p-vehicle__picture--classic650 {
  margin-block-start: 85px;
}

.p-vehicle__picture-img {
  display: block;
  width: 100%;
  max-width: 560px;
  height: auto;
  object-fit: contain;
}

.p-vehicle__content-wrap {
  position: relative;
  z-index: 1;
}

.p-vehicle--even .p-vehicle__content-layout {
  grid-template-columns: 1fr 440px;
}

.p-vehicle__desc {
  font-size: 20px;
  font-weight: 400;
  line-height: 1.9;
  color: #f7f3eb;
}

.p-vehicle__box--sp {
  display: none;
}

.p-vehicle__spec {
  margin-block-start: 40px;
  background-color: rgba(0, 0, 0, 0.5);
}

.p-vehicle__spec-inner {
  display: flex;
  gap: 10px;
  justify-content: center;
  padding: 10px;
}

.p-vehicle__spec-col p {
  margin: 0;
  font-size: 12px;
  font-weight: 400;
  line-height: 1.45;
  color: #f7f3eb;
}

.p-vehicle__reserve-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 560px;
  height: 60px;
  margin-block-start: 40px;
  font-size: 24px;
  font-weight: 900;
  line-height: 1.2;
  color: #f7f3eb;
  text-align: center;
  text-decoration: none;
  background-color: #d96a1b;
  box-shadow: 0 4px 4px rgba(0, 0, 0, 0.5);
  transition: opacity var(--duration);
}

@media (any-hover: hover) {
  .p-vehicle__reserve-btn:hover {
    opacity: 0.85;
  }
}

.p-vehicle--even .p-vehicle__reserve-btn {
  margin-inline-start: 170px;
}

.p-vehicle__img-col .p-vehicle__spec {
  margin-inline: 0;
}

.p-vehicle__img-col .p-vehicle__reserve-btn {
  width: 100%;
  margin-inline-start: 0;
}

.p-vehicle__graph {
  margin-block-start: 50px;
}

.p-vehicle__graph-title {
  font-size: 24px;
  font-weight: 900;
  line-height: 1.4;
  color: #f7f3eb;
  text-align: center;
  text-shadow: 0 0 5px #000;
}

.p-vehicle__gauge-items {
  display: grid;
  gap: 30px;
  margin-block-start: 30px;
}

.p-vehicle__gauge-item img {
  display: block;
  width: 338px;
  margin-inline: auto;
  object-fit: contain;
}

.p-vehicle__food {
  margin-block-start: 83px;
  text-align: center;
}

.p-vehicle__food-title {
  font-size: 24px;
  font-weight: 900;
  line-height: 1.4;
  color: #f7f3eb;
  text-align: center;
  text-shadow: 0 0 5px #000;
}

.p-vehicle__food-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 160px;
  height: 160px;
  margin-block-start: 35px;
  margin-inline: auto;
}

.p-vehicle__food-icon img {
  object-fit: contain;
  width: 100%;
  height: auto;
}

.p-vehicle__food-name {
  margin-block-start: 24px;
  font-size: 20px;
  font-weight: 900;
  line-height: 1.9;
  color: #f7f3eb;
  text-align: center;
}

.p-vehicle__food-desc {
  margin-block-start: 22px;
  font-size: 20px;
  font-weight: 400;
  line-height: 1.9;
  color: #f7f3eb;
  text-align: left;
}

/* ======================================================
   可変 (781px〜1440px)
====================================================== */

@media (min-width: 781px) and (max-width: 1440px) {
  :root {
    --inner: min(calc(1100 / var(--view-size) * 100vw), 100%);
    --padding-inner: calc(20 / var(--view-size) * 100vw);
    --header-height: calc(80 / var(--view-size) * 100vw);
  }

  /* footer */
  .p-footer__inner {
    gap: calc(15 / var(--view-size) * 100vw);
    padding-block: calc(15 / var(--view-size) * 100vw);
  }
  .p-footer__logo img {
    width: calc(69 / var(--view-size) * 100vw);
    height: calc(44 / var(--view-size) * 100vw);
  }
  .p-footer__copy {
    font-size: calc(10 / var(--view-size) * 100vw);
  }

  /* header */
  .p-header {
    height: calc(90 / var(--view-size) * 100vw);
  }
  .p-header__inner {
    padding-inline: calc(30 / var(--view-size) * 100vw);
  }
  .p-header__logo img {
    height: calc(60 / var(--view-size) * 100vw);
  }
  .p-header__nav-item--sep::before {
    height: calc(34 / var(--view-size) * 100vw);
  }
  .p-header__nav-link {
    padding-inline: calc(15 / var(--view-size) * 100vw);
    font-size: calc(16 / var(--view-size) * 100vw);
  }
  .p-header__nav-num {
    font-size: calc(18 / var(--view-size) * 100vw);
  }
  .p-header__hamburger {
    width: calc(20 / var(--view-size) * 100vw);
    height: calc(17 / var(--view-size) * 100vw);
  }
  .p-header__hamburger[aria-expanded=true] span:first-child {
    transform: translateY(calc(7.5 / var(--view-size) * 100vw)) rotate(45deg);
  }
  .p-header__hamburger[aria-expanded=true] span:last-child {
    transform: translateY(calc(-7.5 / var(--view-size) * 100vw)) rotate(-45deg);
  }
  .p-header__drawer {
    top: calc(50 / var(--view-size) * 100vw);
    height: calc(100dvh - 50 / var(--view-size) * 100vw);
  }
  .p-header__drawer-list {
    gap: calc(43 / var(--view-size) * 100vw);
    padding: calc(85 / var(--view-size) * 100vw) calc(15 / var(--view-size) * 100vw) calc(40 / var(--view-size) * 100vw);
  }
  .p-header__drawer-item::before {
    width: calc(7 / var(--view-size) * 100vw);
  }
  .p-header__drawer-link {
    padding-left: calc(15 / var(--view-size) * 100vw);
    font-size: calc(20 / var(--view-size) * 100vw);
  }
  .p-header__drawer-link .p-header__nav-num {
    font-size: calc(32 / var(--view-size) * 100vw);
  }

  /* lineup */
  .p-lineup {
    padding-block-start: calc(150 / var(--view-size) * 100vw);
  }
  .p-lineup__body {
    margin-block-start: calc(140 / var(--view-size) * 100vw);
  }
  .p-lineup__tab-nav {
    max-width: calc(775 / var(--view-size) * 100vw);
    margin-block-start: calc(170 / var(--view-size) * 100vw);
  }
  .p-lineup__tab-nav--follow {
    margin-block-start: 0;
  }
  .p-lineup__tab-list {
    padding-inline: calc(24 / var(--view-size) * 100vw);
  }
  .p-lineup__tab-item--top::after {
    height: calc(16 / var(--view-size) * 100vw);
    right: calc(-2 / var(--view-size) * 100vw);
  }
  .p-lineup__tab-btn {
    height: calc(60 / var(--view-size) * 100vw);
  }

  /* page-nav */
  .p-page-nav {
    padding-block: calc(120 / var(--view-size) * 100vw);
  }
  .p-page-nav__item--sep::before {
    height: calc(34 / var(--view-size) * 100vw);
  }
  .p-page-nav__link {
    padding-inline: calc(15 / var(--view-size) * 100vw);
    font-size: calc(16 / var(--view-size) * 100vw);
  }
  .p-page-nav__num {
    font-size: calc(18 / var(--view-size) * 100vw);
  }

  /* topics */
  .p-topics {
    padding-block-start: calc(150 / var(--view-size) * 100vw);
  }
  .p-topics__grid {
    gap: calc(80 / var(--view-size) * 100vw) calc(40 / var(--view-size) * 100vw);
    padding-block-start: calc(100 / var(--view-size) * 100vw);
  }
  .p-topics__pager-row {
    gap: calc(15 / var(--view-size) * 100vw);
  }
  .p-topics__pager-row + .p-topics__pager-row {
    gap: calc(20 / var(--view-size) * 100vw);
    margin-block-start: calc(15 / var(--view-size) * 100vw);
  }
  .p-topics__pager-btn {
    font-size: calc(24 / var(--view-size) * 100vw);
  }
  .p-topics-card__head {
    top: calc(-52 / var(--view-size) * 100vw);
    left: calc(10 / var(--view-size) * 100vw);
    margin-block-end: calc(5 / var(--view-size) * 100vw);
  }
  .p-topics-card__num {
    padding-inline: calc(10 / var(--view-size) * 100vw) calc(5 / var(--view-size) * 100vw);
    font-size: calc(70 / var(--view-size) * 100vw);
    transform: translateX(calc(-5 / var(--view-size) * 100vw));
  }
  .p-topics-card__num-line {
    width: calc(98 / var(--view-size) * 100vw);
    height: calc(10 / var(--view-size) * 100vw);
  }
  .p-topics-card__body {
    min-height: calc(370 / var(--view-size) * 100vw);
    padding: calc(20 / var(--view-size) * 100vw) calc(15 / var(--view-size) * 100vw);
  }
  .p-topics-card__img {
    margin-block-end: calc(16 / var(--view-size) * 100vw);
  }
  .p-topics-card__text {
    font-size: calc(16 / var(--view-size) * 100vw);
  }

  /* value */
  .p-value {
    padding-block-start: calc(100 / var(--view-size) * 100vw);
  }
  .p-value__title-wrap {
    margin-block-end: calc(60 / var(--view-size) * 100vw);
  }
  .p-value__body {
    grid-template-columns: calc(385 / var(--view-size) * 100vw) 1fr;
    gap: calc(100 / var(--view-size) * 100vw);
  }
  .p-value__text {
    font-size: calc(16 / var(--view-size) * 100vw);
  }
  .p-value__text p:not(:first-child) {
    margin-top: calc(29 / var(--view-size) * 100vw);
  }
  .p-value__images {
    gap: calc(10 / var(--view-size) * 100vw);
  }

  /* vehicle */
  .p-vehicle__bg {
    height: calc(985 / var(--view-size) * 100vw);
  }
  .p-vehicle__layout {
    gap: calc(60 / var(--view-size) * 100vw);
    margin-top: calc(-985 / var(--view-size) * 100vw);
    min-height: calc(985 / var(--view-size) * 100vw);
  }
  .p-vehicle--even .p-vehicle__layout {
    grid-template-columns: 1fr calc(480 / var(--view-size) * 100vw);
  }
  .p-vehicle__overlay-col {
    padding-block: calc(100 / var(--view-size) * 100vw);
    padding-inline: calc(20 / var(--view-size) * 100vw);
  }
  .p-vehicle__img-col {
    height: calc(985 / var(--view-size) * 100vw);
    padding-block: calc(100 / var(--view-size) * 100vw);
  }
  .p-vehicle__title--himalayan {
    max-width: calc(520 / var(--view-size) * 100vw);
  }
  .p-vehicle__title--bear {
    max-width: calc(513 / var(--view-size) * 100vw);
  }
  .p-vehicle__picture {
    margin-block-start: calc(40 / var(--view-size) * 100vw);
  }
  .p-vehicle__picture--himalayan {
    margin-block-start: calc(50 / var(--view-size) * 100vw);
  }
  .p-vehicle__picture--goan {
    margin-block-start: calc(35 / var(--view-size) * 100vw);
  }
  .p-vehicle__picture--bear {
    margin-block: 0 calc(-36 / var(--view-size) * 100vw);
  }
  .p-vehicle__picture--classic650 {
    margin-block-start: calc(85 / var(--view-size) * 100vw);
  }
  .p-vehicle__picture-img {
    max-width: calc(560 / var(--view-size) * 100vw);
  }
  .p-vehicle--even .p-vehicle__content-layout {
    grid-template-columns: 1fr calc(440 / var(--view-size) * 100vw);
  }
  .p-vehicle__desc {
    font-size: calc(20 / var(--view-size) * 100vw);
  }
  .p-vehicle__spec {
    margin-block-start: calc(40 / var(--view-size) * 100vw);
  }
  .p-vehicle__spec-inner {
    gap: calc(10 / var(--view-size) * 100vw);
    padding: calc(10 / var(--view-size) * 100vw);
  }
  .p-vehicle__spec-col p {
    font-size: calc(12 / var(--view-size) * 100vw);
  }
  .p-vehicle__reserve-btn {
    width: calc(560 / var(--view-size) * 100vw);
    height: calc(60 / var(--view-size) * 100vw);
    margin-block-start: calc(40 / var(--view-size) * 100vw);
    font-size: calc(24 / var(--view-size) * 100vw);
  }
  .p-vehicle--even .p-vehicle__reserve-btn {
    margin-inline-start: initial;
  }
  .p-vehicle__graph {
    margin-block-start: calc(50 / var(--view-size) * 100vw);
  }
  .p-vehicle__graph-title {
    font-size: calc(24 / var(--view-size) * 100vw);
  }
  .p-vehicle__gauge-items {
    gap: calc(30 / var(--view-size) * 100vw);
    margin-block-start: calc(30 / var(--view-size) * 100vw);
  }
  .p-vehicle__gauge-item img {
    width: calc(338 / var(--view-size) * 100vw);
  }
  .p-vehicle__food {
    margin-block-start: calc(83 / var(--view-size) * 100vw);
  }
  .p-vehicle__food-title {
    font-size: calc(24 / var(--view-size) * 100vw);
  }
  .p-vehicle__food-icon {
    width: calc(160 / var(--view-size) * 100vw);
    height: calc(160 / var(--view-size) * 100vw);
    margin-block-start: calc(35 / var(--view-size) * 100vw);
  }
  .p-vehicle__food-name {
    margin-block-start: calc(24 / var(--view-size) * 100vw);
    font-size: calc(20 / var(--view-size) * 100vw);
  }
  .p-vehicle__food-desc {
    margin-block-start: calc(22 / var(--view-size) * 100vw);
    font-size: calc(20 / var(--view-size) * 100vw);
  }
}

/* ======================================================
   SP (max-width: 780px)
====================================================== */

@media (max-width: 780px) {
  :root {
    --view-size: 375;
    --padding-inner: calc(20 / var(--view-size) * 100vw);
    --header-height: calc(64 / var(--view-size) * 100vw);
  }

  .pc_only {
    display: none;
  }
  .sp_only {
    display: block;
  }

  .u-sp {
    display: block;
  }
  .u-pc {
    display: none;
  }

  .l-inner {
    max-width: calc(var(--inner-sp) + var(--padding-inner) * 2);
    margin-inline: auto;
  }

  /* footer SP */
  .p-footer {
    padding-block: 0;
  }
  .p-footer__inner {
    gap: calc(8 / var(--view-size) * 100vw);
    padding-block: calc(8 / var(--view-size) * 100vw);
  }
  .p-footer__logo img {
    width: calc(37 / var(--view-size) * 100vw);
    height: calc(23 / var(--view-size) * 100vw);
  }
  .p-footer__copy {
    font-size: calc(8 / var(--view-size) * 100vw);
    line-height: normal;
  }

  /* header SP */
  .p-header {
    height: calc(50 / var(--view-size) * 100vw);
  }
  .p-header__inner {
    padding-inline: calc(15 / var(--view-size) * 100vw);
  }
  .p-header__logo img {
    height: calc(27 / var(--view-size) * 100vw);
  }
  .p-header__nav {
    display: none;
  }
  .p-header__hamburger {
    display: flex;
    width: calc(20 / var(--view-size) * 100vw);
    height: calc(17 / var(--view-size) * 100vw);
  }
  .p-header__hamburger span {
    height: calc(2 / var(--view-size) * 100vw);
  }
  .p-header__hamburger[aria-expanded=true] span:first-child {
    transform: translateY(calc(7.5 / var(--view-size) * 100vw)) rotate(45deg);
  }
  .p-header__hamburger[aria-expanded=true] span:last-child {
    transform: translateY(calc(-7.5 / var(--view-size) * 100vw)) rotate(-45deg);
  }
  .p-header__drawer {
    display: block;
    top: calc(50 / var(--view-size) * 100vw);
    height: calc(100dvh - calc(50 / var(--view-size) * 100vw));
  }
  .p-header__drawer-list {
    gap: calc(43 / var(--view-size) * 100vw);
    padding: calc(85 / var(--view-size) * 100vw) calc(15 / var(--view-size) * 100vw) calc(40 / var(--view-size) * 100vw);
  }
  .p-header__drawer-item::before {
    width: calc(7 / var(--view-size) * 100vw);
  }
  .p-header__drawer-link {
    display: block;
    padding-left: calc(15 / var(--view-size) * 100vw);
    font-size: calc(20 / var(--view-size) * 100vw);
    letter-spacing: calc(0.4 / var(--view-size) * 100vw);
  }
  .p-header__drawer-link .p-header__nav-num {
    font-size: calc(32 / var(--view-size) * 100vw);
    letter-spacing: calc(0.64 / var(--view-size) * 100vw);
  }

  /* kv SP */
  .p-kv {
    min-height: 0;
  }
  .p-kv__content {
    padding-top: 48%;
  }
  .p-kv__title-img {
    width: 73.0666666667%;
  }

  /* lineup SP */
  .p-lineup {
    padding-block-start: calc(80 / var(--view-size) * 100vw);
  }
  .p-lineup__body {
    margin-block-start: 0;
  }
  .p-lineup__tab-nav {
    width: calc(373 / var(--view-size) * 100vw);
    margin-block-start: calc(30 / var(--view-size) * 100vw);
  }
  .p-lineup__tab-nav--follow {
    margin-block-start: 0;
  }

  .p-lineup__tab-list {
    grid-template-columns: 45fr 61fr 61fr 61fr 61fr 61fr;
    justify-content: center;
    width: auto;
    min-width: max-content;
    padding-block: calc(3 / var(--view-size) * 100vw);
    padding-inline: 0;
  }

  .p-lineup__tab-item--top::after {
    height: calc(20 / var(--view-size) * 100vw);
    right: calc(3 / var(--view-size) * 100vw);
  }

  .p-lineup__tab-item {
    flex: 0 0 auto;
  }
  .p-lineup__tab-btn {
    width: fit-content;
    height: auto;
    padding-inline: 0;
  }
  .p-lineup__tab-btn img {
    height: calc(42 / var(--view-size) * 100vw);
    width: auto;
  }

  /* page-nav SP */
  .p-page-nav {
    padding-block: calc(40 / var(--view-size) * 100vw);
  }
  .p-page-nav__list {
    flex-direction: column;
    gap: 0;
    align-items: center;
  }
  .p-page-nav__item {
    justify-content: center;
    width: 100%;
  }
  .p-page-nav__item--sep::before {
    display: none;
  }
  .p-page-nav__link {
    justify-content: center;
    width: 100%;
    padding-block: calc(15 / var(--view-size) * 100vw);
    padding-inline: calc(20 / var(--view-size) * 100vw);
    font-size: calc(16 / var(--view-size) * 100vw);
  }
  .p-page-nav__num {
    font-size: calc(18 / var(--view-size) * 100vw);
  }

  /* topics SP */
  .p-topics {
    padding-block-start: calc(75 / var(--view-size) * 100vw);
  }
  .p-topics__title-wrap {
    padding-inline: calc(20 / var(--view-size) * 100vw);
  }
  .p-topics__inner {
    padding-inline: 0;
  }
  .p-topics__grid {
    display: block;
    padding-block-start: calc(80 / var(--view-size) * 100vw);
    padding-inline: calc(20 / var(--view-size) * 100vw);
    margin-inline: calc(50% - 50vw);
  }
  .p-topics__grid.swiper {
    overflow: hidden;
  }
  .p-topics__grid .swiper-wrapper {
    display: flex;
  }
  .p-topics__pager {
    display: block;
    padding-inline: calc(20 / var(--view-size) * 100vw);
    margin-block-start: calc(16 / var(--view-size) * 100vw);
  }
  .p-topics-card {
    flex-shrink: 0;
    width: calc(275 / var(--view-size) * 100vw);
  }
  .p-topics-card__head {
    top: calc(-52 / var(--view-size) * 100vw);
    left: calc(10 / var(--view-size) * 100vw);
    margin-block-end: calc(5 / var(--view-size) * 100vw);
  }
  .p-topics-card__num {
    padding-inline: calc(10 / var(--view-size) * 100vw) calc(5 / var(--view-size) * 100vw);
    font-size: calc(70 / var(--view-size) * 100vw);
    transform: translateX(calc(-5 / var(--view-size) * 100vw));
  }
  .p-topics-card__num-line {
    width: calc(98 / var(--view-size) * 100vw);
    height: calc(10 / var(--view-size) * 100vw);
  }
  .p-topics-card__body {
    min-height: calc(370 / var(--view-size) * 100vw);
    padding: calc(20 / var(--view-size) * 100vw) calc(15 / var(--view-size) * 100vw);
  }
  .p-topics-card__img {
    margin-block-end: calc(16 / var(--view-size) * 100vw);
  }
  .p-topics-card__text {
    font-size: calc(14 / var(--view-size) * 100vw);
  }
  .p-topics__pager-row {
    gap: calc(15 / var(--view-size) * 100vw);
  }
  .p-topics__pager-row + .p-topics__pager-row {
    gap: calc(20 / var(--view-size) * 100vw);
    margin-block-start: calc(15 / var(--view-size) * 100vw);
  }
  .p-topics__pager-btn {
    font-size: calc(24 / var(--view-size) * 100vw);
  }

  /* value SP */
  .p-value {
    padding-block-start: calc(53 / var(--view-size) * 100vw);
  }
  .p-value__title-wrap {
    margin-block-end: calc(35 / var(--view-size) * 100vw);
  }
  .p-value__body {
    grid-template-columns: 1fr;
    gap: calc(30 / var(--view-size) * 100vw);
  }
  .p-value__text {
    font-size: calc(16 / var(--view-size) * 100vw);
  }
  .p-value__text p:not(:first-child) {
    margin-top: calc(29 / var(--view-size) * 100vw);
  }
  .p-value__images {
    grid-template-columns: repeat(2, 1fr);
    gap: 1px;
  }
  .p-value__images--sp {
    display: grid;
    margin-block-start: calc(30 / var(--view-size) * 100vw);
  }
  .p-value__images--pc {
    display: none;
  }

  /* vehicle SP */
  .p-vehicle__bg {
    height: calc(814 / var(--view-size) * 100vw);
  }

  .p-vehicle__layout {
    display: flex;
    flex-direction: column-reverse;
    align-items: center;
    max-width: calc(600 / var(--view-size) * 100vw);
    height: auto;
    margin-top: 0;
    min-height: 0;
    padding-block-start: calc(40 / var(--view-size) * 100vw);
    padding-inline: calc(10 / var(--view-size) * 100vw);
    position: sticky;
    margin-top: calc(-814 / var(--view-size) * 100vw);
  }
  .p-vehicle--even .p-vehicle__layout {
    flex-direction: column;
  }
  .p-vehicle__overlay-col {
    width: 100%;
    padding-block: calc(44 / var(--view-size) * 100vw) calc(50 / var(--view-size) * 100vw);
    padding-inline: 0;
    overflow: visible;
    margin-block-start: calc(-620 / var(--view-size) * 100vw);
    z-index: 2;
  }
  .p-vehicle__img-col {
    flex-direction: column-reverse;
    align-items: center;
    align-self: auto;
    box-sizing: content-box;
    width: 100%;
    height: auto;
    padding-block: 0;
    padding-inline-start: 0;
    top: calc(40 / var(--view-size) * 100vw);
    /* padding-block-end: calc(580 / var(--view-size) * 100vw); */
    padding-block-end: calc(580 / var(--view-size) * 100vw);
  }
  .p-vehicle__title {
    width: fit-content;
    max-width: calc(420 / var(--view-size) * 100vw);
    max-height: calc(45 / var(--view-size) * 100vw);
    padding-inline: calc(0 / var(--view-size) * 100vw);
    text-align: center;
  }
  .p-vehicle__title--himalayan {
    max-width: calc(420 / var(--view-size) * 100vw);
  }
  .p-vehicle__title--classic650 {
    width: 89.552238806%;
  }
  .p-vehicle__title--classic350 {
    width: 89.8507462687%;
  }
  .p-vehicle__title--bear {
    width: 65.3731343284%;
    max-width: calc(420 / var(--view-size) * 100vw);
  }
  .p-vehicle__title-img {
    margin-inline-start: 0;
    object-position: left center;
  }
  .p-vehicle__title--bear img {
    width: fit-content;
    max-height: calc(45 / var(--view-size) * 100vw);
  }
  .p-vehicle__picture {
    width: 70.4225352113%;
    margin-inline: auto;
  }
  .p-vehicle__picture--himalayan {
    margin-block-start: calc(20 / var(--view-size) * 100vw);
  }
  .p-vehicle__picture--goan {
    margin-block-start: calc(15 / var(--view-size) * 100vw);
  }
  .p-vehicle__picture--bear {
    margin-block-end: calc(-17 / var(--view-size) * 100vw);
  }
  .p-vehicle__picture--classic650 {
    margin-block-start: calc(20 / var(--view-size) * 100vw);
  }
  .p-vehicle__picture--classic350 {
    margin-block-start: calc(20 / var(--view-size) * 100vw);
  }
  .p-vehicle__picture-img {
    max-width: 100%;
  }
  .p-vehicle__content-wrap {
    padding-inline: calc(10 / var(--view-size) * 100vw);
  }
  .p-vehicle__content-layout {
    grid-template-columns: 1fr;
    gap: calc(30 / var(--view-size) * 100vw);
    padding-inline: calc(20 / var(--view-size) * 100vw);
    margin-inline: 0;
  }
  .p-vehicle__desc {
    font-size: calc(16 / var(--view-size) * 100vw);
    line-height: 1.8;
  }
  .p-vehicle__box--pc {
    display: none;
  }
  .p-vehicle__box--sp {
    display: block;
  }
  .p-vehicle__spec {
    margin-block-start: calc(40 / var(--view-size) * 100vw);
    background-color: transparent;
  }
  .p-vehicle__spec-inner {
    flex-direction: column;
    gap: 0;
    padding-block: 0;
    padding-inline: calc(20 / var(--view-size) * 100vw);
  }
  .p-vehicle__spec-col p {
    white-space: normal;
    font-size: calc(12 / var(--view-size) * 100vw);
  }
  .p-vehicle__reserve-btn {
    width: 100%;
    max-width: calc(335 / var(--view-size) * 100vw);
    height: calc(40 / var(--view-size) * 100vw);
    margin-block-start: calc(45 / var(--view-size) * 100vw);
    font-size: calc(16 / var(--view-size) * 100vw);
  }
  .p-vehicle--even .p-vehicle__reserve-btn {
    margin-inline: auto;
  }
  .p-vehicle__img-col .p-vehicle__reserve-btn {
    padding-inline: 0;
  }
  .p-vehicle__graph {
    margin-block-start: calc(50 / var(--view-size) * 100vw);
  }
  .p-vehicle__graph-title {
    font-size: calc(20 / var(--view-size) * 100vw);
  }
  .p-vehicle__gauge-items {
    gap: calc(30 / var(--view-size) * 100vw);
    max-width: calc(300 / var(--view-size) * 100vw);
    margin-block-start: calc(14 / var(--view-size) * 100vw);
    margin-inline: auto;
  }
  .p-vehicle__gauge-item img {
    width: 100%;
  }
  .p-vehicle__food {
    margin-block-start: calc(83 / var(--view-size) * 100vw);
    padding-inline: calc(0 / var(--view-size) * 100vw);
  }
  .p-vehicle__food-icon {
    width: calc(160 / var(--view-size) * 100vw);
    height: calc(160 / var(--view-size) * 100vw);
    margin-block-start: calc(35 / var(--view-size) * 100vw);
  }
  .p-vehicle__food-title {
    font-size: calc(18 / var(--view-size) * 100vw);
  }
  .p-vehicle__food-name {
    margin-block-start: calc(24 / var(--view-size) * 100vw);
    font-size: calc(16 / var(--view-size) * 100vw);
  }
  .p-vehicle__food-desc {
    margin-block-start: calc(22 / var(--view-size) * 100vw);
    font-size: calc(16 / var(--view-size) * 100vw);
  }
}
