@charset "UTF-8";
/*
    Theme Name: Strategy
    Description: Strategy様オリジナルテーマ
    Version: 1.0
    Author: BigBang（Ichimizu）
    Tags: HTML5, CSS3, Bootstrap

    License: MIT
    License URI: http://opensource.org/licenses/mit-license.php
*/
:root {
  --primary-color: #c6158d;
  --primary-lightest-color: #fddde6;
}
*, *:before, *:after {
  box-sizing: border-box;
}
html {
  font-size: 16px;
}
body {
  width: 100%;
  font-family: "Roboto", "Noto Sans JP", sans-serif;
  line-height: 1.7;
  letter-spacing: 0.05rem;
  color: #333;
  font-size: 0.875rem;
}
body.no-scroll {
  position: fixed;
}
h1 {
  position: relative;
  padding-bottom: 0.5rem;
  border-bottom: 4px solid #ccc;
  font-size: 1.75rem;
  line-height: 1.3;
  color: #111;
}
h1::after {
  position: absolute;
  bottom: -4px;
  left: 0;
  z-index: 2;
  content: "";
  width: 20%;
  height: 4px;
  background-color: #c6158d;
}
h1.h1-top {
  margin-top: 4px;
}
h2 {
  position: relative;
  padding: 12px 12px;
  line-height: 1.3;
  border-left: 5px solid #cacaca;
  background: #f1f1f1;
  font-size: 1.25rem;
  color: #000;
}
h3 {
  position: relative;
  padding-left: 24px;
  line-height: 1;
  color: #111;
}
h3::before {
  position: absolute;
  top: 0;
  left: 0.2em;
  z-index: 2;
  content: "";
  width: 12px;
  height: 12px;
  background-color: #c6158d;
  transform: rotate(45deg);
}
table {
  border-spacing: 0;
}
p {
  margin: 0 0 2px;
}
a {
  color: #c6158d;
}
img {
  max-width: 100%;
  vertical-align: bottom;
}
iframe {
  max-width: 100%;
}
textarea, input[type=text] {
  border: 1px solid #ddd;
}
br.sp-br {
  display: inline;
}
br.pc-br {
  display: none;
}
.main .ngg-albumoverview {
  display: grid !important;
  grid-template-columns: 100%;
  gap: 1em;
}
.main .ngg-albumoverview.default-view .ngg-album-compact {
  margin: 0 !important;
}
.main .ngg-album-compactbox {
  padding: 0 !important;
}
.main .ngg-album-compact h4 .ngg-album-desc {
  display: flex;
  align-items: center;
  justify-content: center;
  height: auto;
  width: 100%;
  text-decoration: none;
  max-width: none !important;
}
.main .ngg-album-compact a {
  display: block;
}
.main .ngg-album-compact .Thumb {
  width: 100%;
  object-fit: cover;
}
.main .ngg-galleryoverview.default-view {
  display: grid !important;
  grid-template-columns: 100%;
  gap: 8px;
}
.main .ngg-galleryoverview.default-view .ngg-gallery-thumbnail-box {
  display: block;
}
.main .ngg-galleryoverview.default-view .ngg-gallery-thumbnail a {
  margin: 0;
}
.main .ngg-galleryoverview.default-view .ngg-gallery-thumbnail img {
  width: 100%;
}
@media (min-width: 768px) {
  .main .ngg-albumoverview {
    grid-template-columns: repeat(2, 1fr);
  }
  .main .ngg-galleryoverview.default-view {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (min-width: 992px) {
  .main .ngg-albumoverview {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
  }
  .main .ngg-galleryoverview.default-view {
    grid-template-columns: repeat(3, 1fr);
  }
}
header {
  display: flex;
  flex-direction: column;
}
header .header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  height: 72px;
  padding: 0 16px 0 8px;
}
header .header .logo a {
  display: flex;
  text-decoration: none;
}
header .header .logo a img {
  height: 48px;
}
header .header .logo h1 {
  color: #333;
}
header .header .header-widget-area {
  display: none;
}
header .header .sp-nav-btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 0;
  background-color: #fff;
  border: none;
  color: #c6158d;
}
header .header .sp-nav-btn .material-symbols-outlined {
  font-size: 1.75rem;
}
header .header .sp-nav-btn-text {
  font-size: 0.625rem;
  line-height: 1;
}
header .sp-global-nav {
  position: fixed;
  top: 0;
  bottom: 0;
  left: 0;
  z-index: 1000;
  width: 100%;
  background-color: #c6158d;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.2s, visibility 0.2s;
}
header .sp-global-nav.is-active {
  opacity: 1;
  visibility: visible;
}
header .sp-global-nav .sp-global-nav--close {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  height: 72px;
  padding-right: 16px;
}
header .sp-global-nav .sp-global-nav--close .sp-global-nav--control {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 0;
  background-color: transparent;
  border: none;
  color: #fff;
}
header .sp-global-nav .sp-global-nav--close .sp-global-nav--control .material-symbols-outlined {
  font-size: 1.75rem;
}
header .sp-global-nav .sp-global-nav--close .sp-global-nav--control-text {
  font-size: 0.625rem;
  line-height: 1;
}
header .sp-global-nav .sp-global-menu {
  list-style: none;
  padding: 0;
  margin: 0;
}
header .sp-global-nav .sp-global-menu li {
  text-align: center;
}
header .sp-global-nav .sp-global-menu li a {
  display: inline-block;
  padding: 10px 8px;
  color: #fff;
  line-height: 1.4;
  text-decoration: none;
}
header .mobile-global-image {
  height: auto;
  aspect-ratio: 1.414;
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
}
header .lg-slider {
  display: none;
}
header .global-nav {
  display: none;
}
header .l-header__mv {
  width: 100%;
}
header .l-header__mv-inner {
  display: none;
}
header .l-header__mv-inner.is-front {
  display: block;
}
@media (min-width: 992px) {
  header .header {
    height: 96px;
    width: 100%;
    max-width: 1600px;
    margin-left: auto;
    margin-right: auto;
  }
  header .header .logo a img {
    height: auto;
    width: 280px;
  }
  header .header .header-widget-area {
    display: block;
    width: 600px;
  }
  header .header .header-widget-area .header-makers {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-end;
  }
  header .header .header-widget-area .header-makers a {
    width: calc(20% - 8px);
  }
  header .header .header-widget-area .header-makers a + a {
    margin-left: 8px;
  }
  header .header .header-widget-area .header-makers img {
    opacity: 0.6;
  }
  header .header .header-widget-area .header-makers img:hover {
    opacity: 1;
  }
  header .header .header-widget-area .header-card {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
  }
  header .header .header-widget-area .header-card img {
    height: 40px;
  }
  header .header .header-widget-area .header-card img + img {
    margin-left: 8px;
  }
  header .header .sp-nav-btn {
    display: none;
  }
  header .sp-global-nav {
    display: none;
  }
  header .mobile-global-image {
    display: none;
  }
  header .lg-slider {
    display: flex;
    justify-content: center;
    width: 100%;
  }
  header .lg-slider .slider {
    width: 100%;
    max-width: 1600px;
  }
  header .lg-slider .slider-list {
    height: auto;
    width: 100%;
  }
  header .lg-slider .slider-list .slider-item {
    display: none;
    position: relative;
    aspect-ratio: 2;
    background-repeat: no-repeat;
    background-size: cover;
    background-position: 50% 50%;
  }
  header .lg-slider .slider-list .slider-image {
    visibility: hidden;
    width: 100%;
  }
  header .lg-slider .slider-list .slick-slide {
    display: block !important;
  }
  header .global-nav {
    display: flex;
    justify-content: space-between;
    height: 200px;
    width: 100%;
    max-width: 1200px;
    padding: 24px 0;
    margin-top: 24px;
    margin-right: auto;
    margin-left: auto;
  }
  header .global-nav .nav-item {
    position: relative;
    width: 300px;
  }
  header .global-nav .nav-item .hexagon {
    position: absolute;
    left: 0;
    right: 0;
    width: 60px;
    height: 100px;
    background-color: #c6158d;
    margin: 0 auto;
  }
  header .global-nav .nav-item .hexagon::before, header .global-nav .nav-item .hexagon::after {
    content: "";
    position: absolute;
    width: 0;
    border-top: 50px solid transparent;
    border-bottom: 50px solid transparent;
  }
  header .global-nav .nav-item .hexagon::before {
    right: 100%;
    border-right: 30px solid #c6158d;
  }
  header .global-nav .nav-item .hexagon::after {
    left: 100%;
    width: 0;
    border-left: 30px solid #c6158d;
  }
  header .global-nav .nav-item .hexagon img {
    position: absolute;
    z-index: 1;
    left: -25px;
    top: -5px;
    width: 110px;
    max-width: none;
  }
  header .global-nav .nav-item .name {
    position: absolute;
    width: 100%;
    text-align: center;
    color: #c6158d;
    font-size: 1.125rem;
    font-weight: 900;
    letter-spacing: 0;
  }
  header .global-nav .nav-item-top .hexagon {
    top: 0;
  }
  header .global-nav .nav-item-top .name {
    bottom: 10px;
  }
  header .global-nav .nav-item-bottom .hexagon {
    bottom: 0;
  }
  header .global-nav .nav-item-bottom .name {
    top: 10px;
  }
  header .l-header__mv {
    display: flex;
    justify-content: center;
    width: 100%;
  }
  header .l-header__mv-inner {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    max-width: 1600px;
    aspect-ratio: 2;
    overflow: hidden;
  }
  header .l-header__mv-image {
    width: 100%;
    height: auto;
    object-fit: cover;
    object-position: center;
  }
}
.content-wall {
  display: grid;
  grid-template-columns: 1fr;
  grid-template-rows: auto auto;
}
.content-wall .main {
  grid-column: 1 / 2;
  grid-row: 1 / 2;
  width: 100%;
  padding: 16px 16px 0 16px;
  margin-bottom: 40px;
}
.content-wall .sidebar {
  grid-column: 1 / 2;
  grid-row: 2 / 3;
  width: 100%;
  padding: 0 16px;
}
.content-wall .sidebar .sidebar-widget div {
  text-align: center;
}
.content-wall .sidebar .sidebar-widget > div + div {
  margin-top: 32px;
}
.content-wall .sidebar .sidebar-widget > div::after {
  content: "";
  display: block;
  clear: both;
}
.content-wall .sidebar .sidebar-widget .sidebar-sns {
  display: flex;
  justify-content: space-between;
}
.content-wall .sidebar .sidebar-widget .sidebar-sns img {
  width: 40px;
}
@media (min-width: 992px) {
  .content-wall {
    grid-template-columns: 240px 1fr;
    grid-template-rows: auto;
    column-gap: 56px;
    max-width: 1200px;
    padding: 0 16px;
    margin-top: 40px;
    margin-left: auto;
    margin-right: auto;
    /* サイドバー */
    /* メインコンテンツ */
  }
  .content-wall--one {
    grid-template-columns: 1fr;
    column-gap: 0;
  }
  .content-wall .sidebar {
    grid-column: 1 / 2;
    grid-row: 1 / 2;
    padding: 0;
  }
  .content-wall .sidebar .sidebar-sns {
    display: flex;
    justify-content: space-between;
    padding: 0;
  }
  .content-wall .sidebar .sidebar-sns a {
    display: inline-block;
  }
  .content-wall .sidebar .sidebar-sns a img {
    vertical-align: bottom;
  }
  .content-wall .sidebar * {
    max-width: 100%;
  }
  .content-wall .sidebar .sidebar-widget > div::after {
    content: "";
    display: block;
    clear: both;
  }
  .content-wall .main {
    grid-column: 2 / 3;
    grid-row: 1 / 2;
    padding: 0;
  }
  .content-wall .main .page > *:first-child {
    margin-top: 0;
  }
}
.c-button {
  position: relative;
  display: flex;
  justify-content: center;
  width: 100%;
  max-width: 600px;
  padding: 1.25em 1em;
  border-radius: 8px;
  background-color: #c6158d;
  box-shadow: rgba(99, 99, 99, 0.2) 0px 2px 8px 0px;
  color: #fff;
  font-size: 1.125em;
  text-decoration: none;
}
.c-button::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 0.875em;
  transform: translateY(-50%);
  font-family: "Material Symbols Outlined";
  font-size: 1.125em;
}
.c-button--newTab::after {
  content: "open_in_new";
}
.c-underline {
  background: linear-gradient(transparent 60%, var(--primary-lightest-color) 0%);
}
/* ギャラリー */
.gallery {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  column-gap: 16px;
  row-gap: 24px;
}
.gallery .gallery-item {
  margin: 0;
}
.gallery .gallery-item .gallery-icon {
  width: 100%;
  height: 160px;
  padding: 8px;
  border: 1px solid #dfdfdf;
}
.gallery .gallery-item .gallery-icon a {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  overflow: hidden;
}
.gallery .gallery-item .gallery-icon img {
  vertical-align: bottom;
}
.gallery .gallery-item dd {
  margin: 10px 0 0 0;
  text-align: center;
}
.gallery .gallery-item dd a {
  text-decoration: none;
}
.gallery .gallery-caption {
  display: none;
}
@media (min-width: 992px) {
  .gallery {
    grid-template-columns: repeat(3, 1fr);
  }
}
.p-funride {
  line-height: 1.875;
  text-align: justify;
}
.p-funride__menuLink {
  display: grid;
  grid-template-columns: 100%;
  gap: 2em;
}
.p-funride__menuLink-item {
  display: flex;
  justify-content: center;
}
@media (min-width: 992px) {
  .p-funride__menuLink {
    grid-template-columns: repeat(3, 1fr);
  }
}
.p-schAbo {
  line-height: 1.875;
  text-align: justify;
}
.p-schAbo p + p {
  margin-top: 1em;
}
.p-schAbo__pageTitle {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  aspect-ratio: 3.3333333333;
  padding: 0;
  margin-bottom: 24px;
  background-color: var(--primary-color);
  border: none;
  border-radius: 8px;
  color: #ffffff;
  font-size: min(26px, 5vw);
}
.p-schAbo__pageTitle::after {
  display: none;
}
.p-schAbo__sectionTitle {
  display: grid;
  grid-template-columns: 1em 1fr;
  gap: 0.5em;
  align-items: center;
  padding: 0;
  margin-top: 3em;
  background-color: #ffffff;
  border-left: none;
  font-size: 1.375em;
  font-weight: 500;
  line-height: 1;
}
.p-schAbo__sectionTitle::before {
  content: "";
  display: block;
  background-color: var(--primary-color);
  height: 1em;
  width: 1em;
}
.p-schAbo__sampleCourse {
  margin: 24px 0;
}
.p-schAbo__rentalBike {
  margin: 24px 0;
}
.p-schAbo__rentalBike-wrap {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px 8px;
}
.p-schAbo__rentalBike-thumbnail {
  width: 100%;
  aspect-ratio: 1.3333333333;
}
.p-schAbo__rentalBike-thumbnail-img {
  width: 100%;
  object-fit: cover;
}
.p-schAbo__rentalBike-name {
  display: flex;
  justify-content: center;
  margin-top: 4px;
  font-size: 1.125em;
}
.p-schAbo__schedule {
  display: grid;
  grid-template-columns: 100%;
  font-feature-settings: "palt";
  font-size: 1.25em;
}
.p-schAbo__schedule-item {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 56px;
  border-bottom: 1px solid #dddddd;
  font-weight: 500;
}
.p-schAbo__price {
  font-feature-settings: "palt";
}
.p-schAbo__price-tax {
  text-align: right;
}
.p-schAbo__priceList {
  margin-top: 4px;
}
.p-schAbo__priceList-header {
  font-weight: 500;
}
.p-schAbo__priceList-header .p-schAbo__priceList-col {
  background-color: #dddddd;
}
.p-schAbo__priceList-header-price {
  justify-content: flex-end;
}
.p-schAbo__priceList-row {
  display: grid;
  grid-template-columns: 1fr 30%;
  gap: 2px;
  align-items: center;
  height: 48px;
}
.p-schAbo__priceList-row:nth-child(even) .p-schAbo__priceList-col {
  background-color: #f0f0f0;
}
.p-schAbo__priceList-row-price {
  justify-content: flex-end;
}
.p-schAbo__priceList-col {
  display: flex;
  align-items: center;
  height: 100%;
  padding: 4px 8px;
}
.p-schAbo__price-attention {
  display: grid;
  grid-template-columns: 100%;
  gap: 4px;
  margin-top: 16px;
  line-height: 1.5;
  font-size: 0.875em;
}
.p-schAbo__price-attention-item {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: flex-start;
  gap: 0.5em;
}
.p-schAbo__price-attention-item::before {
  content: attr(data-attention-no);
  display: block;
}
.p-schAbo__formLink {
  display: flex;
  justify-content: center;
  margin-top: 3em;
}
@media (min-width: 992px) {
  .p-schAbo__pageTitle {
    aspect-ratio: 5;
    margin-bottom: 32px;
  }
  .p-schAbo__sampleCourse {
    margin: 32px 0;
  }
  .p-schAbo__rentalBike-wrap {
    grid-template-columns: repeat(4, 1fr);
  }
  .p-schAbo__schedule {
    grid-template-columns: 1fr 1fr;
  }
  .p-schAbo__schedule-item {
    height: 64px;
  }
  .p-schAbo__schedule-item:nth-child(even) {
    border-left: 1px solid #dddddd;
  }
  .p-schAbo__priceList-row {
    height: 64px;
  }
}
.underbar-title {
  position: relative;
  padding-bottom: 16px;
  font-size: 1.375rem;
  font-weight: 500;
  text-align: center;
  background-color: inherit;
  border: none;
  margin-bottom: 24px;
}
.underbar-title::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  display: block;
  width: 64px;
  height: 4px;
  margin: 0 auto;
  border-radius: 2px;
  background-color: #c6158d;
}
.sp-d-block {
  display: block;
}
.wrapper {
  width: 100%;
  margin: 0 auto;
  background: #fff;
}
.select-box {
  position: relative;
  display: inline-flex;
  justify-content: space-between;
  align-items: center;
  border: 1px solid #999;
}
.select-box::before {
  content: "";
  position: absolute;
  right: 8px;
  display: block;
  height: 20px;
  width: 20px;
  margin-left: 24px;
  background-image: url("./img/under-arrow.svg");
  background-position: center;
  background-size: contain;
  pointer-events: none;
}
.select-box select {
  -webkit-appearance: none;
  appearance: none;
  display: flex;
  align-items: center;
  height: 40px;
  padding: 4px 40px 4px 8px;
  background-color: #fff;
  border: none;
  border-radius: 0;
  color: #333;
}
footer {
  padding: 8px 0;
  margin-top: 32px;
  border-top: 1px solid #bbb;
  font-size: 0.85em;
}
footer .copyright {
  text-align: center;
  font-size: 0.9em;
}
footer .copyright a {
  text-decoration: none;
}
/* サイドバー ウィジェット */
/* ページネーション */
.pagination {
  text-align: center;
}
.pagination .page-numbers {
  display: none;
  padding: 8px 16px;
  border-radius: 5px;
  background: #c6158d;
  color: #fff;
  text-decoration: none;
}
.pagination .page-numbers.prev, .pagination .page-numbers.next {
  display: inline-block;
}
.pagination .current {
  background: #fff;
  color: #333;
  font-weight: bold;
}
.pagination .dots {
  background: #e2e2e2;
  color: #333;
}
/* フロントページ　リスト */
.home-list {
  display: flex;
  flex-direction: column;
  padding: 0 4px;
  margin: 0 0 24px;
}
.home-list .list-date {
  width: 100%;
  padding: 0;
  margin: 0;
}
.home-list .list-title {
  width: 100%;
  padding: 0;
  margin: 0 0 16px;
}
.home-list .list-title a {
  font-weight: 500;
  text-decoration: none;
}
/* フロントページ　ブログカテゴリー */
.home-blog-category {
  display: grid;
  grid-gap: 10px;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
}
.home-blog-category > div {
  height: 40px;
}
.home-blog-category > div > a {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  width: 100%;
  background-color: #c6158d;
  color: #fff;
  text-decoration: none;
}
/* プライスページ　ブログカテゴリー */
.price-blog-category {
  display: grid;
  grid-gap: 10px;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  margin: 0 auto;
}
.price-blog-category > div {
  height: 40px;
}
.price-blog-category > div > a {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  width: 100%;
  border-radius: 4px;
  background-color: #c6158d;
  color: #fff;
  text-decoration: none;
}
/* 単一記事　ベース */
.single-base .date {
  margin-top: -8px;
  margin-bottom: 16px;
  font-size: 0.9em;
  color: #999;
}
.single-base .link-box {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin-top: 40px;
}
.single-base .link-box > div {
  display: flex;
  flex-direction: column;
  justify-content: center;
  width: 100%;
  height: 88px;
  padding: 4px 8px;
}
.single-base .link-box > div > a {
  display: block;
  text-decoration: none;
}
.single-base .link-box .pre-link {
  border-top: 1px solid #ddd;
  border-bottom: 1px solid #ddd;
}
.single-base .link-box .next-link {
  border-bottom: 1px solid #ddd;
  text-align: right;
}
/* ニュース */
.news .news-content .attachment-thumbnail {
  float: left;
  min-height: 150px;
  margin-right: 16px;
  margin-bottom: 16px;
}
/* イベント　記事リスト */
.event-article {
  margin-bottom: 56px;
}
.event-article .wall {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
.event-article .wall .thumbnail {
  width: 100%;
  margin-bottom: 8px;
  text-align: center;
}
.event-article .wall .info {
  width: 100%;
}
.event-article .wall .info .date {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 40px;
  background-color: #d3d6ff;
  margin-top: 0;
  font-size: 1rem;
  font-weight: 500;
}
.event-article .wall .info .content {
  text-align: justify;
}
/* イベント */
.event .eye-catch {
  margin-bottom: 16px;
}
.event .date {
  margin-bottom: 24px;
  font-size: 1.5em;
}
.event .date::before {
  top: 8px;
}
.event .link-box {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  margin-top: 40px;
}
.bike-filter-wall {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  margin-bottom: 16px;
}
.bike-filter-wall .bike-filter-label {
  margin-right: 8px;
}
.bike-filter-wall .bike-filter-select .select-box select {
  width: 120px;
}
/* バイク情報　リスト */
.bike-list-wall {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
.bike-list-wall .bike-block {
  display: block;
  padding: 8px;
  border: 1px solid #ddd;
  color: #333;
  text-decoration: none;
}
.bike-list-wall .bike-block .title {
  display: flex;
  align-items: center;
  height: 56px;
  margin: 8px 0;
  border-bottom: 1px solid #ddd;
  font-size: 1rem;
  line-height: 1.5;
  word-break: break-all;
}
.bike-list-wall .bike-block .image {
  width: 100%;
  aspect-ratio: 1.3333333333;
}
.bike-list-wall .bike-block .image img {
  width: 100%;
  height: auto;
  object-fit: cover;
  object-position: center;
}
.bike-list-wall .bike-block .separator {
  height: 4px;
  margin: 4px 0;
  background: repeating-linear-gradient(-45deg, #fff, #fff 5px, #c6158d 0, #c6158d 10px);
}
.bike-list-wall .bike-block .info-table {
  width: 100%;
  margin-top: 8px;
  font-size: 0.9em;
}
.bike-list-wall .bike-block .info-table td {
  padding: 2px;
}
.bike-list-wall .bike-block .info-table .name {
  font-size: 0.9em;
}
.bike-list-wall .bike-block .info-table .price {
  text-align: right;
  font-size: 1.1em;
  font-weight: bold;
}
.bike-list-wall .bike-block .info-table .year {
  text-align: right;
}
.bike-list-wall .bike-block .info-table .mileage {
  text-align: right;
}
/* バイク情報ページ */
.bike .bike-image-wall .main-img-wrap {
  width: 100%;
  margin-bottom: 16px;
  text-align: center;
}
.bike .bike-image-wall .main-img-wrap img {
  max-width: 100%;
  vertical-align: bottom;
}
.bike .bike-image-wall .thumbnails-wrap {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  align-content: flex-start;
  align-items: flex-start;
  border: 1px solid #bbb;
}
.bike .bike-image-wall .thumbnails-wrap img {
  vertical-align: bottom;
}
.bike .bike-image-wall .thumbnails-wrap .more-images {
  margin: 8px auto;
  text-align: center;
}
.bike .bike-info-wall {
  margin: 24px 0 40px;
}
.bike .bike-info-wall .bike-price {
  margin: 0 0 16px;
  text-align: right;
  font-size: 1.2em;
  font-weight: bold;
  color: #c6158d;
}
.bike .bike-info-wall .bike-price .price {
  font-size: 1.8em;
}
.bike .bike-info-wall dl {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  font-size: 0.9em;
}
.bike .bike-info-wall dl dt, .bike .bike-info-wall dl dd {
  padding: 8px;
  margin: 0;
}
.bike .bike-info-wall dl dt {
  background: #ddd;
}
.bike .bike-content {
  margin: 40px 0;
}
.bike .bike-post {
  margin: 40px 0;
}
.bike .bike-post li {
  padding: 4px 0;
}
.bike .bike-post li a {
  margin-left: 40px;
}
.bike .bike-thumbnails-wall {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin-bottom: 32px;
}
.bike .bike-thumbnails-wall a {
  display: block;
  width: 100%;
  aspect-ratio: 1;
  padding: 4px;
  border: 1px solid #dfdfdf;
}
.bike .bike-thumbnails-wall a img {
  height: auto;
  width: 100%;
  object-fit: cover;
  object-position: center;
}
/* ツイート　記事リスト */
.tweet-article {
  margin-bottom: 64px;
}
.tweet-article a {
  color: inherit;
  text-decoration: none;
}
.tweet-article .date {
  font-size: 0.85em;
  font-weight: 300;
  color: #666;
}
.tweet-article .tweet-content {
  margin-top: 24px;
}
/* ブログ　記事リスト */
.blog-article {
  margin-bottom: 64px;
}
.blog-article a {
  color: inherit;
  text-decoration: none;
}
.blog-article .date {
  font-size: 0.85em;
  font-weight: 300;
  color: #666;
}
.blog-article .blog-content {
  margin-top: 24px;
}
/* 用品情報　リスト */
.item-list-wall {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-around;
}
.item-list-wall .item-block {
  display: block;
  width: 30%;
  padding: 8px;
  margin-bottom: 24px;
  border: 1px solid #ddd;
  color: #333;
  text-decoration: none;
  cursor: pointer;
}
.item-list-wall .item-block .image {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  overflow: hidden;
}
.item-list-wall .item-block .image img {
  width: 100%;
}
.item-list-wall .item-block .title {
  position: relative;
  margin: 4px 0;
  font-size: 1.1rem;
  font-weight: bold;
  text-align: center;
}
.item-list-wall .item-block .price {
  text-align: right;
  font-size: 1.1em;
  color: #c6158d;
  text-align: center;
}
/* 用品ページ */
.items .item-image-wall .main-img-wrap {
  margin: 0 auto;
  margin-bottom: 16px;
  text-align: center;
}
.items .item-image-wall .thumbnails-wrap {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  align-items: flex-start;
  align-content: flex-start;
  border: 1px solid #bbb;
}
.items .item-image-wall .thumbnails-wrap > span {
  margin: 0 auto;
}
.items .item-info-wall {
  margin: 24px 0;
}
.items .item-info-wall .item-price {
  margin: 0 0 16px;
  text-align: right;
  font-size: 1.2em;
  font-weight: bold;
  color: #c6158d;
}
.items .item-info-wall .item-price .price {
  font-size: 1.8em;
}
/* スタッフ */
.staffs-wall {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  margin: 24px 0;
}
.staffs-wall .staff {
  width: 100%;
  padding: 16px;
  border: 1px solid #ddd;
}
.staffs-wall .staff + .staff {
  margin-top: 40px;
}
.staffs-wall .staff .image-block {
  width: 100%;
  text-align: center;
}
.staffs-wall .staff .info-block {
  width: 100%;
  margin-top: 16px;
}
.staffs-wall .staff .info-block p {
  margin-bottom: 10px;
  font-size: 0.875rem;
}
.staffs-wall .staff .info-block p.introduction {
  text-align: justify;
  margin-bottom: 0;
}
/* 企業情報テーブル */
.center-title {
  position: relative;
  font-size: 1.5rem;
  text-align: center;
  padding-bottom: 8px;
  margin-bottom: 40px;
}
.center-title::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  margin-left: auto;
  margin-right: auto;
  display: block;
  width: 80px;
  height: 2px;
  background-color: #c6158d;
}
.tablepress.company-table {
  width: 100%;
  max-width: 700px;
  border: 2px solid #c6158d;
}
.tablepress.company-table * {
  box-sizing: border-box;
}
.tablepress.company-table th, .tablepress.company-table td {
  display: block;
  width: 100%;
  padding: 24px 16px;
}
.tablepress.company-table th {
  background: #eaeaea;
  text-align: left;
}
.widget_instagram-feed-widget h3::before {
  display: none;
}
#webike-moto.webike-moto-bike-detail h3.shop-name::before {
  display: none;
}
#webike-moto.webike-moto-bike-detail h3.block-title::before {
  top: 3px;
}
@media (min-width: 992px) {
  /* フロントページ　リスト */
  /* イベント　記事リスト */
  /* 単一記事　ベース */
  /* バイク情報ページ */
  /* 用品ページ */
  /* コメントフォーム */
  /* コメントリスト */
  /* スタッフ */
  br.sp-br {
    display: none;
  }
  br.pc-br {
    display: inline;
  }
  .pc-d-none {
    display: none;
  }
  .home-list {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    padding: 0 16px;
    margin: 0 0 24px;
    font-size: 1rem;
  }
  .home-list .list-date {
    width: 20%;
    padding: 0;
    margin: 0;
  }
  .home-list .list-title {
    width: 80%;
    padding: 0;
    margin: 0 0 4px;
  }
  .event-article .wall .thumbnail {
    width: 30%;
    text-align: center;
  }
  .event-article .wall .thumbnail img {
    max-width: 200px;
  }
  .event-article .wall .info {
    width: 65%;
  }
  .single-base .link-box > div {
    width: 50%;
  }
  .single-base .link-box .next-link {
    border-top: 1px solid #ddd;
  }
  .bike-list-wall {
    grid-template-columns: 1fr 1fr 1fr;
    gap: 24px;
  }
  .bike-list-wall .bike-block {
    padding: 16px;
  }
  .bike .thumbnails-wrap img {
    width: 20%;
    padding: 8px;
  }
  .bike .thumbnails-wrap > span {
    margin: 0 auto;
  }
  .bike dl dt, .bike dl dd {
    border-top: 1px solid #999;
    border-bottom: 1px solid #999;
  }
  .bike dl dt {
    width: 13%;
  }
  .bike dl dd {
    width: 20%;
    border-top: 1px solid #999;
    border-bottom: 1px solid #999;
    border-right: 1px solid #999;
  }
  .bike dl dt:nth-of-type(3n + 1) {
    width: 14%;
    border-left: 1px solid #999;
  }
  .bike dl dt:nth-of-type(n + 4), .bike dl dd:nth-of-type(n + 4) {
    border-top: none;
  }
  .bike .bike-thumbnails-wall {
    grid-template-columns: 1fr 1fr 1fr 1fr;
  }
  .items .item-image-wall .main-img-wrap {
    width: 80%;
  }
  .items .item-image-wall .main-img-wrap img {
    max-width: 100%;
    vertical-align: bottom;
  }
  .items .item-image-wall .thumbnails-wrap > div {
    width: 20%;
    padding: 8px;
  }
  .items .item-content {
    margin: 24px 0;
  }
  .comment-respond {
    margin: 40px 0;
  }
  .comment-respond .comment-form > p {
    display: flex;
    flex-wrap: wrap;
    margin-bottom: 16px;
  }
  .comment-respond .comment-form label {
    display: inline-block;
    width: 15%;
  }
  .comment-respond .comment-form input[type=text], .comment-respond .comment-form textarea {
    width: 85%;
    padding: 8px;
  }
  .comment-respond .comment-form .form-allowed-tags {
    padding-left: 15%;
  }
  .comment-respond .comment-form .form-submit {
    padding-left: 15%;
  }
  .comment-respond .comment-form .form-submit input[type=submit] {
    width: 100%;
    padding: 16px 8px;
    border: none;
    background: #c6158d;
    font-size: 1.1em;
    color: #fff;
    cursor: pointer;
  }
  .comment-respond .comment-form #throwsSpamAway {
    padding-left: 15%;
    color: red;
  }
  .comments ul {
    list-style: none;
    padding: 0;
  }
  .comments ul li {
    padding-top: 24px;
    margin-bottom: 24px;
  }
  .comments ul li .comment-body > div {
    display: flex;
    flex-wrap: wrap;
    padding: 1px 0;
  }
  .comments ul li .comment-body > div > * {
    padding: 4px 16px;
  }
  .comments ul li .comment-body > div label {
    display: block;
    width: 15%;
    padding-right: 12px;
    background: #daf3ff;
    text-align: right;
  }
  .comments ul li .comment-content > div {
    display: block;
    width: 85%;
  }
  .comments ul li .comment-content p {
    margin-bottom: 16px;
  }
  .comments ul li:first-child {
    padding-top: 0;
  }
  .comments ul li + li {
    border-top: 1px dashed #c6158d;
  }
  .comments ul.children li {
    padding-top: 0;
  }
  .staffs-wall .staff {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-around;
    align-content: center;
    padding: 16px 0;
  }
  .staffs-wall .staff .image-block {
    width: 30%;
  }
  .staffs-wall .staff .info-block {
    width: 60%;
    margin-top: 0;
  }
  .tablepress.company-table th, .tablepress.company-table td {
    display: table-cell;
  }
  .tablepress.company-table th {
    width: 25%;
  }
  .tablepress.company-table tr + tr > th {
    border-top: 1px solid #ddd;
  }
}
@media screen and (max-width: 991px) {
  /* バイク情報ページ */
  /* 用品情報　リスト */
  /* 用品ページ */
  /* コメントフォーム */
  /* コメントリスト */
  .bike .bike-image-wall .main-img-wrap {
    width: 100%;
    height: auto;
    margin-bottom: 24px;
    text-align: center;
  }
  .bike .bike-image-wall .main-img-wrap .no-image {
    padding-top: 0;
  }
  .bike .bike-image-wall .main-img-wrap img {
    max-width: 100%;
    vertical-align: bottom;
  }
  .bike .bike-image-wall .thumbnails-wrap {
    border: 1px solid #bbb;
  }
  .bike .bike-image-wall .thumbnails-wrap img {
    width: 20%;
    padding: 8px;
    vertical-align: bottom;
  }
  .bike .bike-info-wall dl {
    border: 1px solid #999;
  }
  .bike .bike-info-wall dl dt {
    width: 25%;
    border-top: 1px solid #999;
  }
  .bike .bike-info-wall dl dt:first-child, .bike .bike-info-wall dl dt:nth-of-type(2) {
    border-top: none;
  }
  .bike .bike-info-wall dl dt:first-child + dd {
    border-top: none;
  }
  .bike .bike-info-wall dl dd {
    width: 25%;
    border-top: 1px solid #999;
  }
  .bike .bike-info-wall dl dd:nth-of-type(2) {
    border-top: none;
  }
  .bike .bike-post ul {
    list-style: none;
    padding: 0 8px;
  }
  .bike .bike-post ul li {
    padding: 8px 0;
  }
  .item-list-wall .item-block {
    width: 46%;
  }
  .items .item-image-wall .main-img-wrap {
    width: 90%;
  }
  .items .item-image-wall .main-img-wrap img {
    max-width: 100%;
    vertical-align: bottom;
  }
  .items .item-image-wall .thumbnails-wrap > div {
    width: 20%;
    padding: 8px;
  }
  .items .item-content {
    margin: 24px 0;
  }
  .comment-respond {
    margin: 40px 0;
  }
  .comment-respond .comment-form > p {
    display: flex;
    flex-wrap: wrap;
    margin-bottom: 16px;
  }
  .comment-respond .comment-form label {
    display: inline-block;
    width: 100%;
    margin-bottom: 4px;
  }
  .comment-respond .comment-form input[type=text], .comment-respond .comment-form textarea {
    width: 100%;
    padding: 8px;
  }
  .comment-respond .comment-form .form-allowed-tags {
    padding-left: 15%;
  }
  .comment-respond .comment-form .form-submit input[type=submit] {
    width: 100%;
    padding: 16px 8px;
    border: none;
    background: #c6158d;
    font-size: 1.1em;
    color: #fff;
    cursor: pointer;
  }
  .comment-respond .comment-form #throwsSpamAway {
    color: red;
  }
  .comments ul {
    list-style: none;
    padding: 0;
  }
  .comments ul li {
    padding-top: 24px;
    margin-bottom: 24px;
  }
  .comments ul li .comment-body > div > * {
    display: block;
    padding: 4px 8px;
  }
  .comments ul li .comment-body > div label {
    background: #daf3ff;
  }
  .comments ul li .comment-content > div {
    display: block;
    width: 100%;
  }
  .comments ul li .comment-content p {
    margin-bottom: 16px;
  }
  .comments ul li:first-child {
    padding-top: 0;
  }
  .comments ul li + li {
    border-top: 1px dashed #c6158d;
  }
  .comments ul.children li {
    padding-top: 0;
  }
}
/* General Purpose Class */
.article-title {
  font-size: 1.6rem;
  margin-top: 0;
  padding-top: 20px;
  border-bottom-width: 2px;
}
.article-title::before {
  position: absolute;
  top: 0px;
  left: 0;
  content: "== Title ==";
  font-size: 0.6em;
  font-weight: 300;
  color: #496fff;
}
.article-title::after {
  bottom: -2px;
  height: 2px;
}
.page-title {
  position: relative;
  padding: 12px 12px;
  margin-top: 8px;
  margin-bottom: 24px;
  line-height: 1.3;
  background: #eeeeee;
  font-size: 1.5em;
  font-weight: bold;
  color: #000;
}
.btn-link {
  display: inline-block;
  padding: 8px 24px;
  background: #c6158d;
  border-radius: 5px;
  color: #fff;
  text-decoration: none;
}
.text-right {
  text-align: right;
}
.text-center {
  text-align: center;
}
.text-left {
  text-align: left;
}
/* WordPress Native Styles */
.aligncenter {
  display: block;
  margin: 0 auto;
}
.alignright {
  float: right;
}
.alignleft {
  float: left;
}
.clearfix {
  overflow: hidden;
  zoom: 1;
}
.clearfix:after {
  content: "";
  display: block;
  clear: both;
}
img[class*="wp-image-"], img[class*="attachment-"] {
  max-width: 100%;
  height: auto;
}
/* -----------------------
 プラグインCSS変更
-------------------------- */
/* Biz Calendar */
#biz_calendar table.bizcal {
  margin-top: 0;
  font-size: 14px;
}
#biz_calendar p {
  font-size: 14px;
}
#biz_calendar table.bizcal .calmonth {
  font-size: 0.95rem;
}
/* XO Event Calendar */
.widget_xo_event_calendar {
  padding: 0;
}
.widget_xo_event_calendar h3 {
  padding: 0;
  margin-bottom: 0;
  line-height: 2;
  font-size: 1rem;
  font-weight: normal;
  text-align: center;
  background: #c6158d;
  color: #fff;
}
.widget_xo_event_calendar h3::before {
  display: none;
}
.xo-event-calendar table.xo-month .month-header {
  margin-top: 12px 0;
}
.xo-event-calendar table.xo-month .month-dayname td div {
  height: 40px;
  padding: 0;
  line-height: 40px;
  text-align: center;
  font-size: 1em;
}
.xo-event-calendar table.xo-month .month-dayname-space {
  height: auto;
}
.xo-event-calendar table.xo-month .month-week {
  line-height: 40px;
  height: 40px;
}
/* Webike */
#webike-moto * {
  color: #333;
}
#webike-moto .form-group label {
  margin-bottom: 4px;
  font-weight: 500;
  color: #333;
}
#webike-moto .form-group select {
  color: #333;
}
#webike-moto.webike-moto-bike-list button.submit {
  height: 36px;
  border: none;
  background-color: #c6158d;
}
#webike-moto.webike-moto-bike-list a.reset {
  height: 36px;
  margin-top: 0;
  box-shadow: none;
  border: none;
  border-radius: 0;
  line-height: 1;
  color: #666;
}
#webike-moto.webike-moto-bike-list .card-maker {
  margin-bottom: 5px;
}
#webike-moto.webike-moto-bike-list .card-maker a {
  font-weight: normal;
  color: #333;
}
#webike-moto.webike-moto-bike-list .card-bike-name {
  margin-top: 5px;
}
#webike-moto.webike-moto-bike-list .card-bike-name a {
  font-size: 1rem;
}
#webike-moto.webike-moto-bike-list .card-img {
  position: relative;
}
#webike-moto.webike-moto-bike-list .card-img::before {
  content: "";
  display: block;
  padding-top: 75%;
}
#webike-moto.webike-moto-bike-list .card-img img {
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0;
  left: 0;
  height: 100%;
}
#webike-moto.webike-moto-bike-list .card-text {
  font-size: 10px;
}
#webike-moto.webike-moto-bike-list .bike-point > p {
  font-size: 10px;
}
#webike-moto.webike-moto-bike-list .table {
  width: 100%;
}
#webike-moto .bike-price {
  color: #333;
  font-weight: normal;
}
#webike-moto .bike-price.total {
  color: #333;
  font-size: 20px;
  font-weight: 500;
}
#webike-moto .bike-point .new-point {
  font-size: 10px;
  color: #333;
  font-weight: normal;
}
#webike-moto .webike-moto-pagination ul.page-numbers li > .page-numbers:hover:not(span) {
  background-color: #c6158d;
  border-color: #c6158d;
}
#webike-moto .webike-moto-pagination ul.page-numbers li > .page-numbers.current {
  background-color: #c6158d;
  border-color: #c6158d;
}
@media screen and (min-width: 992px) {
  .widget_xo_event_calendar {
    padding: 0;
  }
}
.p-front__sectionTitle {
  padding-left: 4px;
  font-family: "Jost", "Noto Sans JP", sans-serif;
}
.p-front__instagram {
  margin-bottom: 40px;
}
.p-front__banner {
  display: grid;
  grid-template-columns: 1fr;
  gap: 40px;
  margin-top: 64px;
}
/* Home ショップリスト */
.home-shop-list {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
  margin-top: 40px;
}
.home-shop-list .shop-block {
  background-color: #f5f5f5;
  box-shadow: rgba(0, 0, 0, 0.16) 0px 1px 4px;
}
.home-shop-list .shop-block .shop-image-box {
  width: 100%;
  aspect-ratio: 1.3333333333;
}
.home-shop-list .shop-block .shop-image-box img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}
.home-shop-list .shop-info {
  padding: 16px 16px 24px;
}
.home-shop-list .shop-info-box {
  font-size: 0.75rem;
  text-align: center;
}
.home-shop-list .shop-name-box {
  margin-bottom: 12px;
  font-size: 1rem;
  font-weight: 500;
  text-align: center;
}
.home-shop-list .shop-contact-wall {
  display: grid;
  grid-template-columns: 1fr;
  gap: 8px;
}
.home-shop-list .shop-detail-box a, .home-shop-list .shop-tel-box a {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 48px;
  color: #fff;
  font-size: 0.875rem;
  line-height: 1;
  text-decoration: none;
}
.home-shop-list .shop-detail-box a {
  background-color: #d846a9;
}
.home-shop-list .shop-detail-box a::before {
  content: "location_on";
  position: relative;
  display: block;
  margin-right: 4px;
  font-family: "Material Symbols Outlined";
  font-size: 1.25rem;
  line-height: 1;
  transform: translateY(-1px);
}
.home-shop-list .shop-tel-box a {
  background-color: #5f80ff;
}
.home-shop-list .shop-tel-box a::before {
  content: "call";
  position: relative;
  display: block;
  margin-right: 4px;
  font-family: "Material Symbols Outlined";
  font-size: 1.25rem;
  line-height: 1;
  transform: translateY(-1px);
}
@media (min-width: 992px) {
  .home-shop-list {
    gap: 24px;
  }
  .home-shop-list .shop-block {
    display: grid;
    grid-template-columns: 40% 1fr;
    column-gap: 40px;
    align-items: center;
  }
  .home-shop-list .shop-block .shop-image-box {
    aspect-ratio: unset;
    overflow: hidden;
    height: 100%;
    max-height: 220px;
  }
  .home-shop-list .shop-block .shop-image-box img {
    height: 100%;
    width: 100%;
    object-fit: cover;
    object-position: center;
  }
  .home-shop-list .shop-block .shop-contact-wall {
    grid-template-columns: 1fr;
    grid-template-rows: auto auto;
    align-self: center;
    gap: 12px;
  }
  .home-shop-list .shop-block .shop-detail-box a, .home-shop-list .shop-block .shop-tel-box a {
    height: 48px;
  }
}
.p-main-price h3 {
  margin-top: 56px;
}
.p-main-price .blog-banner {
  display: flex;
  justify-content: center;
  width: 100%;
}
.p-main-price .blog-banner a {
  display: block;
  width: 100%;
  max-width: 600px;
}
.p-main-price .price-notice {
  padding: clamp(8px, 1.5vw, 24px);
  margin-top: 24px;
  background-color: #ffe2e2;
  border: 1px solid #ff0000;
  color: #ff0000;
}
.p-main-price .price-list {
  font-size: 0.75rem;
}
.p-main-price .base-price-list {
  font-size: 0.75rem;
}
.p-main-price .base-price-list .column-2, .p-main-price .base-price-list .column-3 {
  width: min(120px, 25%);
  text-align: right;
}
.p-main-price .price-remarks {
  padding-left: 12px;
  font-size: 0.75rem;
  line-height: 1.5;
}
.p-main-price .price-remarks li + li {
  margin-top: 4px;
}
.p-main-price .price-link-button {
  display: flex;
  justify-content: center;
  width: 100%;
}
.p-main-price .price-link-button a {
  position: relative;
  display: flex;
  justify-content: center;
  width: 100%;
  max-width: 600px;
  padding: 12px 4px;
  border-radius: 8px;
  background-color: #c6158d;
  color: #fff;
  font-size: 1rem;
  text-decoration: none;
}
.p-main-price .price-link-button a::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 12px;
  transform: translateY(-50%);
  font-family: "Material Symbols Outlined";
  font-size: 1rem;
}
@media (min-width: 768px) {
  .p-main-price .price-list {
    font-size: 0.875rem;
  }
  .p-main-price .base-price-list {
    font-size: 0.875rem;
  }
}
.p-main-tire-exchange .message {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 80px;
  padding: 8px;
  background-color: #c6158d;
  color: #fff;
  font-size: 1rem;
  font-weight: 500;
  text-align: center;
}
.p-main-tire-exchange .reserve-flow .flow-item-wall:first-child .flow-item-title {
  margin-top: 0;
}
.p-main-tire-exchange .reserve-flow .flow-item-wall .flow-item-title {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-top: 40px;
  margin-bottom: 12px;
  line-height: 1;
  font-size: 1.5rem;
}
.p-main-tire-exchange .reserve-flow .flow-item-wall .flow-item-title .no {
  color: #c6158d;
  font-size: 3rem;
  font-weight: 700;
  letter-spacing: -2px;
}
.p-main-tire-exchange .reserve-flow .flow-item-wall .flow-item-content .contact-item {
  padding-left: 16px;
}
.p-main-tire-exchange .shop-info {
  display: grid;
  grid-template-columns: 1fr;
  margin-top: 40px;
  padding: 16px;
  border: 2px solid #c6158d;
}
.p-main-tire-exchange .shop-info .shop-title {
  margin-bottom: 16px;
  font-size: 1.25rem;
  font-weight: 500;
}
.p-main-tire-exchange .shop-info .shop-text {
  font-size: 1rem;
}
.p-main-tire-exchange .shop-info .shop-text .info-item {
  display: flex;
}
.p-main-tire-exchange .shop-info .shop-text .info-item .label {
  width: 88px;
}
.p-main-tire-exchange .shop-info .shop-text .info-item .content img {
  width: 240px;
}
.p-main-tire-exchange .shop-info .shop-text .info-item.line-image {
  margin-top: 8px;
}
.p-main-tire-exchange .shop-info .shop-text .info-item.line-image .content {
  width: 100%;
  text-align: center;
}
.p-main-tire-exchange .shop-info .shop-map iframe {
  width: 100%;
  height: 400px;
  vertical-align: bottom;
}
@media (min-width: 768px) {
  .p-main-tire-exchange .shop-info {
    grid-template-columns: 1fr 1fr;
  }
}
