@charset "UTF-8";
/*

 日の出タクシー
----------------------------------------------- */
/* ページタイトル英語画像 */
@media (width > 768px) {
  .page_header .en {
    width: 9.0643274854vw;
  }
}
@media (width <= 768px) {
  .page_header .en {
    width: 23.9361702128vw;
  }
}

/* 車両ラインナップ */
@media (width > 768px) {
  .vehicle_lineup {
    padding-inline: 8.0409356725vw;
  }
}
@media (width <= 768px) {
  .vehicle_lineup {
    padding-inline: 5.3191489362vw;
  }
}
@media (width > 768px) {
  .vehicle_lineup {
    margin-top: 8.7719298246vw;
  }
}
@media (width <= 768px) {
  .vehicle_lineup {
    margin-top: 15.9574468085vw;
  }
}
@media (width > 768px) {
  .vehicle_lineup .title-underline img {
    width: 9.283625731vw;
  }
}
@media (width <= 768px) {
  .vehicle_lineup .title-underline img {
    width: 23.9361702128vw;
  }
}
.vehicle_lineup .lead {
  line-height: 1.625;
}
.vehicle_lineup-list {
  display: grid;
}
@media (width > 768px) {
  .vehicle_lineup-list {
    margin-top: 4.3859649123vw;
    gap: 2.1929824561vw;
    grid-template-columns: repeat(3, 1fr);
  }
}
@media (width <= 768px) {
  .vehicle_lineup-list {
    margin-top: 7.9787234043vw;
    gap: 5.3191489362vw;
    grid-template-columns: repeat(2, 1fr);
  }
}
.vehicle_lineup-list .card {
  display: grid;
  background: url(../img/common/mrk-down.svg) no-repeat;
  background-color: #fff;
  border: 1px solid #494A4D;
  aspect-ratio: 1;
}
.vehicle_lineup-list .card .label {
  position: relative;
}
.vehicle_lineup-list .card .label::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 1px;
  background: var(--color-border);
  background-color: currentColor;
  transform: scale(0, 1);
  transform-origin: right;
  transition: transform 0.4s;
}
.vehicle_lineup-list .card:hover .label::after {
  transform-origin: left;
  transform: scale(1, 1);
}
.vehicle_lineup-list .card {
  text-decoration: none;
}
@media (width > 768px) {
  .vehicle_lineup-list .card {
    grid-template-rows: 10.5994152047vw auto;
    gap: 1.4619883041vw;
    background-size: 2.0467836257vw;
    background-position: center bottom 0.9502923977vw;
    padding: 1.4619883041vw;
  }
}
@media (width <= 768px) {
  .vehicle_lineup-list .card {
    grid-template-rows: 18.6170212766vw auto;
    gap: 2.6595744681vw;
    background-size: 4.2553191489vw;
    background-position: center bottom 2.1276595745vw;
    padding: 3.9893617021vw;
  }
}
.vehicle_lineup-list .image img {
  object-fit: cover;
  width: 100%;
  height: 100%;
  max-width: inherit;
  max-height: inherit;
  object-fit: contain;
}
.vehicle_lineup-list .label {
  align-self: flex-start;
  justify-self: center;
  font-weight: 500;
  line-height: 1.35;
  text-align: center;
  line-height: 1.5;
}
@media (width > 768px) {
  .vehicle_lineup-list .label {
    font-size: clamp(12px, 1.3157894737vw, 20px);
  }
}
/* 車両詳細エリア */
@media (width > 768px) {
  .vehicles_detail {
    padding-inline: 8.0409356725vw;
  }
}
@media (width <= 768px) {
  .vehicles_detail {
    padding-inline: 5.3191489362vw;
  }
}
.vehicles_detail {
  background-color: #fff;
}
@media (width > 768px) {
  .vehicles_detail {
    margin-top: 7.3099415205vw;
    padding-block: 2.9239766082vw 7.3099415205vw;
  }
}
@media (width <= 768px) {
  .vehicles_detail {
    margin-top: 15.9574468085vw;
    padding-block: 0vw 15.9574468085vw;
  }
}

/* 車両情報 */
.vehicle {
  display: grid;
}
@media (width > 768px) {
  .vehicle {
    gap: 2.9239766082vw 0;
    grid-template-columns: 1fr min(50%, 600px);
    grid-auto-flow: dense;
    padding-top: 5.8479532164vw;
  }
}
@media (width <= 768px) {
  .vehicle {
    gap: 7.9787234043vw 0;
    padding-top: 21.2765957447vw;
  }
}
.vehicle-name {
  grid-column: 1/-1;
  background-color: var(--color-blue);
  border-radius: 0.2em;
  padding: 0.6em 1em;
  color: #fff;
  line-height: 1.3;
}
@media (width > 768px) {
  .vehicle-name {
    font-size: clamp(12px, 1.7543859649vw, 20px);
  }
}
@media (width <= 768px) {
  .vehicle-name {
    font-size: min(5.3191489362vw, 20px);
  }
}
.vehicle-image img {
  width: 100%;
}
@media (width > 768px) {
  .vehicle-image {
    grid-column: 2;
    padding-inline: 1.8274853801vw;
  }
}
@media (width <= 768px) {
  .vehicle-image {
    padding-inline: 2.6595744681vw;
  }
}
.vehicle-desc {
  line-height: 1.5;
}
.vehicle-capacity {
  display: flex;
  align-items: center;
  border: 1px solid #494A4D;
  border-radius: 999px;
  overflow: hidden;
  width: fit-content;
}
@media (width > 768px) {
  .vehicle-capacity {
    margin-top: 2.5584795322vw;
  }
}
@media (width <= 768px) {
  .vehicle-capacity {
    margin-top: 5.3191489362vw;
  }
}
.vehicle-capacity dt {
  display: flex;
  align-items: center;
  background-color: var(--color-blue);
  padding-inline: 1.8em 1.2em;
  color: #fff;
  font-weight: 500;
}
@media (width > 768px) {
  .vehicle-capacity dt {
    gap: 0.4385964912vw;
    height: 2.5584795322vw;
    font-size: clamp(12px, 1.0964912281vw, 20px);
  }
  .vehicle-capacity dt img {
    width: 1.1695906433vw;
  }
}
@media (width <= 768px) {
  .vehicle-capacity dt {
    gap: 1.5957446809vw;
    height: 6.6489361702vw;
    font-size: min(3.4574468085vw, 20px);
  }
  .vehicle-capacity dt img {
    width: 3.1914893617vw;
  }
}
.vehicle-capacity dd {
  padding-inline: 1.6em 1.8em;
  font-weight: 600;
}
.vehicle-note {
  line-height: 1.42;
}
@media (width > 768px) {
  .vehicle-note {
    margin-top: 2.1929824561vw;
    font-size: clamp(12px, 1.0233918129vw, 20px);
  }
}
@media (width <= 768px) {
  .vehicle-note {
    margin-top: 5.3191489362vw;
    font-size: min(3.1914893617vw, 20px);
  }
}

/* クレジットカード・電子マネー */
.cashless_payment {
  border: 2px solid var(--color-blue);
}
@media (width > 768px) {
  .cashless_payment {
    margin-top: 14.6198830409vw;
    margin-inline: 2.1929824561vw;
    padding: 4.3859649123vw 5.8479532164vw 5.4824561404vw;
    border-radius: 1.4619883041vw;
  }
}
@media (width <= 768px) {
  .cashless_payment {
    margin-top: 21.2765957447vw;
    padding: 5.3191489362vw 5.3191489362vw 5.3191489362vw;
    border-radius: 3.9893617021vw;
  }
}
.cashless_payment h3 {
  display: flex;
  justify-content: center;
  align-items: center;
  color: var(--color-blue);
  font-family: var(--font-min);
  font-weight: 400;
  text-align: center;
  line-height: 1.4;
}
@media (width > 768px) {
  .cashless_payment h3 {
    gap: 1.6812865497vw;
    font-size: clamp(12px, 1.8274853801vw, 20px);
  }
  .cashless_payment h3 img:nth-of-type(1) {
    width: 4.0204678363vw;
  }
  .cashless_payment h3 img:nth-of-type(2) {
    width: 5.3362573099vw;
  }
}
@media (width <= 768px) {
  .cashless_payment h3 {
    margin-inline: -2.6595744681vw;
    font-size: min(4.7872340426vw, 20px);
    gap: 2.6595744681vw;
  }
  .cashless_payment h3 img:nth-of-type(1) {
    width: 9.3085106383vw;
  }
  .cashless_payment h3 img:nth-of-type(2) {
    width: 11.9680851064vw;
  }
}
.cashless_payment ul {
  display: grid;
}
@media (width > 768px) {
  .cashless_payment ul {
    grid-template-columns: repeat(5, 1fr);
    gap: min(2.9239766082vw, 30px);
    margin-top: 4.3859649123vw;
  }
}
@media (width <= 768px) {
  .cashless_payment ul {
    grid-template-columns: repeat(4, 1fr);
    gap: 5.3191489362vw;
    margin-top: 7.9787234043vw;
  }
}
@media (width <= 520px) {
  .cashless_payment ul {
    grid-template-columns: repeat(3, 1fr);
  }
}
.cashless_payment li {
  display: flex;
  justify-content: center;
  align-items: center;
}
@media (width <= 768px) {
  .cashless_payment li img {
    width: 17.2872340426vw;
    max-width: 100%;
  }
}

/* よくある質問 */
@media (width > 768px) {
  .faq {
    padding-inline: 8.0409356725vw;
  }
}
@media (width <= 768px) {
  .faq {
    padding-inline: 5.3191489362vw;
  }
}
@media (width > 768px) {
  .faq {
    padding-block: 7.3099415205vw 0;
  }
}
@media (width <= 768px) {
  .faq {
    padding-block: 15.9574468085vw 0;
  }
}
.faq details {
  overflow: hidden;
}
.faq details summary {
  list-style-type: none;
  position: relative;
  cursor: pointer;
}
.faq details summary::-webkit-details-marker {
  display: none;
}
.faq details {
  background-color: #fff;
  border: 1px solid var(--color-blue);
}
@media (width > 768px) {
  .faq details {
    border-radius: 0.365497076vw;
  }
  .faq details + details {
    margin-top: 1.0964912281vw;
  }
}
@media (width <= 768px) {
  .faq details {
    border-radius: 1.329787234vw;
  }
  .faq details + details {
    margin-top: 2.6595744681vw;
  }
}
.faq details[open] summary::after {
  content: "\f077";
}
.faq details summary {
  display: flex;
  align-items: center;
  gap: 0.6em;
  padding-block: 0.9em;
  color: var(--color-blue);
  font-weight: 500;
  line-height: 1.4;
  position: relative;
}
.faq details summary::before, .faq details summary::after {
  font-family: "Font Awesome 7 Free";
  font-weight: 600;
  -webkit-font-smoothing: antialiased;
  line-height: 1;
  text-rendering: auto;
  flex-shrink: 0;
}
@media (width > 768px) {
  .faq details summary {
    padding-inline: 3.6549707602vw;
  }
}
@media (width <= 768px) {
  .faq details summary {
    padding-inline: 10.6382978723vw;
  }
}
.faq details summary::before {
  position: absolute;
  top: 0.63em;
  content: "Q";
  font-family: var(--font-min);
  font-size: 137.5%;
}
@media (width > 768px) {
  .faq details summary::before {
    left: 1.4619883041vw;
  }
}
@media (width <= 768px) {
  .faq details summary::before {
    left: 3.9893617021vw;
  }
}
.faq details summary::after {
  content: "\f078";
  font-size: 115%;
  position: absolute;
}
@media (width > 768px) {
  .faq details summary::after {
    right: 1.4619883041vw;
  }
}
@media (width <= 768px) {
  .faq details summary::after {
    right: 3.9893617021vw;
  }
}
.faq details .detailsContent {
  display: flex;
  border-top: solid #000;
  position: relative;
}
@media (width > 768px) {
  .faq details .detailsContent {
    margin-inline: 1.4619883041vw;
    padding-inline: 2.1929824561vw;
    border-width: 0.0365497076vw;
    font-size: clamp(12px, 1.0233918129vw, 20px);
  }
}
@media (width <= 768px) {
  .faq details .detailsContent {
    margin-inline: 3.9893617021vw;
    padding-inline: 5.3191489362vw;
    border-width: 0.1329787234vw;
    font-size: min(3.1914893617vw, 20px);
  }
}
.faq details .detailsContent::before {
  position: absolute;
  left: 0;
  top: 0.88em;
  content: "A";
  font-family: var(--font-min);
  font-size: 128.5%;
  color: var(--color-blue);
}
.faq details .detailsContent p {
  padding-block: 0.9em 1.1em;
  line-height: 1.8;
}