.p-app {
  max-width: 752px;
  margin: auto;
}

.p-app__head {
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 1.75rem;
  font-weight: bold;
}
.p-app__head img {
  flex-shrink: 0;
  margin-right: 16px;
}

.p-app__grid {
  margin-top: 32px;
}

.p-app__ios {
  grid-area: ios;
}

.p-app__ios-icon {
  grid-area: iosicon;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}

.p-app__android {
  grid-area: android;
}

.p-app__qr img {
  background-color: #fff;
}

.p-app__android-icon {
  grid-area: androidicon;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}

.p-app__os {
  grid-area: os;
  text-align: center;
  font-size: 1rem;
  font-weight: bold;
}
.p-app__os .p-app__os-large {
  padding-right: 24px;
  font-size: 1.375rem;
}

.p-app__label {
  font-size: 1rem;
  text-align: center;
}

.p-app__icon {
  transition: transform 0.3s;
}
.p-app__icon:focus-visible {
  transform: scale(1.1);
}

.p-bnr {
  width: 100%;
  max-width: 1168px;
  padding: 0 16px;
  margin: auto;
  margin-top: 16px;
}
.p-bnr .splide__slide {
  border: 2px solid #9ea6b2;
}
.p-bnr .splide__slide img {
  width: 100%;
}
.p-bnr .splide__slide a {
  display: block;
  overflow: hidden;
  position: relative;
}
.p-bnr .splide__slide a img {
  transition: transform 0.3s;
}
.p-bnr .splide__slide a:focus-visible img {
  transform: scale(1.1);
}
.p-bnr .splide__slide a[target=_blank]::after {
  content: "";
  width: 32px;
  height: 24px;
  background-image: url("/common-assets/img/icon_ext.svg");
  background-color: rgba(255, 255, 255, 0.8);
  background-repeat: no-repeat;
  background-position: center center;
  background-size: 20px 16px;
  position: absolute;
  bottom: 0;
  right: 0;
}

.p-bnr__parts {
  margin-top: 16px;
  padding-bottom: 24px;
}

.p-bnr__controls {
  display: flex;
  align-items: center;
  justify-content: space-around;
  min-width: 300px;
  max-width: calc(100% - 32px);
  margin: 0 auto;
  padding: 8px;
  background-color: rgba(244, 247, 250, 0.9);
  border-radius: 8px;
  position: relative;
}
.p-bnr__controls .splide__pagination {
  display: flex;
  gap: 16px;
}
.p-bnr__controls .splide__pagination > li {
  color: #9ea6b2;
  position: relative;
}
.p-bnr__controls .splide__pagination > li button {
  width: 24px;
  height: 24px;
  color: inherit;
}
.p-bnr__controls .splide__pagination > li button::after {
  content: "";
  width: 8px;
  height: 8px;
  background-color: currentColor;
  border-radius: 50%;
  position: absolute;
  left: calc(50% - 4px);
  top: calc(50% - 4px);
}
.p-bnr__controls .splide__pagination > li button.is-active {
  color: #ee2723;
}
.p-bnr__controls .splide__pagination > li button.is-active::before {
  content: "";
  width: 16px;
  height: 16px;
  background-color: transparent;
  border-radius: 50%;
  border: 1px solid currentColor;
  position: absolute;
  left: calc(50% - 8px);
  top: calc(50% - 8px);
}
.p-bnr__controls .splide__pagination > li + li::before {
  content: "";
  width: 8px;
  height: 1px;
  background-color: currentColor;
  position: absolute;
  left: -12px;
  top: 50%;
}
.p-bnr__controls .splide__arrows {
  display: flex;
  align-items: center;
  margin-left: 40px;
  gap: 8px;
}
.p-bnr__controls .splide__arrow {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  background-color: #ee2723;
  border-radius: 4px;
}
.p-bnr__controls .splide__arrow--prev {
  transform: rotate(-180deg);
}
.p-bnr__controls .splide__toggle__play {
  transform: rotate(-180deg);
}
.p-bnr__controls .splide__toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  background-color: #003da5;
  border-radius: 4px;
}
.p-bnr__controls .splide__toggle.is-active {
  background-color: #9ea6b2;
}

.p-bnr.is-initialized:not(.is-active) .splide__list {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 16px;
}
.p-bnr.is-initialized:not(.is-active) .splide__list.-bnr3 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-template-rows: repeat(2, 1fr);
  padding: 0 16px;
}
.p-bnr.is-initialized:not(.is-active) .splide__list.-bnr4 {
  margin: auto !important;
  max-width: 770px;
}

.p-card-comm__item {
  display: flex;
  flex-direction: column-reverse;
  justify-content: flex-end;
}

.p-card-comm__comment {
  min-height: 80px;
}
.p-card-comm__comment p {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 60px;
  background-color: #ffcd00;
  border-radius: 8px;
  font-size: 1.25rem;
  font-weight: bold;
  line-height: 1.3;
  text-align: center;
  position: relative;
}
.p-card-comm__comment p::after {
  content: "";
  width: 0;
  height: 0;
  border: 10px solid transparent;
  border-top-color: #ffcd00;
  position: absolute;
  left: calc(50% - 10px);
  top: 100%;
}

.p-check {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 32px;
}

.p-check__txt {
  margin-left: 16px;
}

.p-check__list {
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.p-check__txt + .p-check__list {
  margin-top: 40px;
}

.p-check__img img {
  margin: auto;
}

.p-check__item {
  padding: 1.5rem 1rem 1.5rem 4rem;
  background: #FFF1EF;
  border-radius: 99em;
  font-size: 1.25rem;
  font-weight: bold;
  line-height: 1.3;
  position: relative;
}
.p-check__item + .p-check__item {
  margin-top: 16px;
}
.p-check__item::before {
  content: "";
  display: block;
  width: 1.5rem;
  height: 1.25rem;
  background-image: url("/store/assets/img/icon_check-red.svg");
  background-repeat: no-repeat;
  background-size: 100%;
  position: absolute;
  left: 1.5rem;
  top: 1.75rem;
}

.p-map {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 40px 16px;
  margin-top: 48px;
  background-image: url("/store/assets/img/img_map.png");
  background-repeat: no-repeat;
  background-position: right bottom 40px;
  background-size: 50%;
}

.p-map__area {
  padding-bottom: 8px;
  font-size: 1.5rem;
  font-weight: bold;
  border-bottom: 2px solid #9ea6b2;
}

.p-map__block[open] .p-map__area::after {
  transform: rotate(0deg);
}

.p-map__list {
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: max-content;
  gap: 16px 1.5rem;
  margin-top: 24px;
}
.p-map__list.-row1 {
  grid-template-rows: repeat(1, auto);
}
.p-map__list.-row2 {
  grid-template-rows: repeat(2, auto);
}
.p-map__list.-row3 {
  grid-template-rows: repeat(3, auto);
}
.p-map__list.-row4 {
  grid-template-rows: repeat(4, auto);
}
.p-map__list.-row5 {
  grid-template-rows: repeat(5, auto);
}
.p-map__list.-row6 {
  grid-template-rows: repeat(6, auto);
}

.p-map__item {
  font-size: 1.125rem;
  font-weight: bold;
}

.p-passport-anshin {
  display: grid;
  grid-template-columns: 3fr 1fr;
  gap: 16px;
}

.p-passport-anshin__list > li + li {
  margin-top: 24px;
}
.p-passport-anshin__list > li {
  display: flex;
}

.p-passport-anshin__head {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  width: 4rem;
  height: 4rem;
  border-radius: 8px;
  background-color: #db0012;
  color: #fff;
  font-size: 1.125rem;
  font-weight: bold;
  line-height: 1;
  text-align: center;
}

.p-passport-anshin__num {
  margin-top: 4px;
  font-size: 1.875rem;
}

.p-passport-anshin__txt {
  margin-left: 1rem;
}

.p-passport-anshin__lead {
  font-size: 1.5rem;
  font-weight: bold;
}

.p-passport-anshin__sub {
  margin-top: 8px;
  font-size: 1.125rem;
}

.p-passport-lead {
  padding: 24px 0;
  background-color: #0068B7;
  position: relative;
}
.p-passport-lead::before {
  content: "";
  right: calc(50% - 50vw);
  left: calc(50% - 50vw);
  position: absolute;
  top: 0;
  bottom: 0;
  z-index: -1;
  background: #0068B7;
}

.p-passport-sp {
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: 16px;
}

.p-store-mv__title {
  display: flex;
  justify-content: center;
  align-items: center;
  padding-top: 40px;
  font-size: 2rem;
  font-weight: bold;
}
.p-store-mv__title span {
  margin-left: 16px;
}

.p-store-mv__inner {
  width: 100%;
  max-width: 1168px;
  padding: 0 16px;
  margin: auto;
}

.p-service__card .c-card__img {
  background-color: #FFF1EF;
}
.p-service__card .c-card__img img {
  -o-object-fit: contain;
     object-fit: contain;
  padding: 16px;
}

.p-service__heading {
  display: flex;
  justify-content: center;
}
.p-service__heading .c-clms.-body {
  width: 960px;
  grid-template-columns: 2fr 7fr;
}
.p-service__heading .c-clms.-clm1-center {
  place-content: center;
}
.p-service__heading .c-list__item {
  font-size: 1.25rem;
}

.p-support-repair__list {
  display: flex;
  flex-wrap: wrap;
  margin-left: 16px;
}
.p-support-repair__list .c-list__item {
  width: 500px;
}

.p-safety_warranty__list.-in-table .c-list__item {
  display: inline-block;
  margin-right: 24px;
  margin-top: 0.5rem;
}
.p-safety_warranty__list.-num.-l1 .c-list__item::before {
  margin-left: -1.2em;
  width: 2em;
  text-align: right;
}
.p-safety_warranty__list.-num.-l1.u-pd8 {
  padding: 8px;
}
.p-safety_warranty__list.-num.-l2 {
  margin-left: 1.5em;
}
.p-safety_warranty__list.-num.-l2 .c-list__item {
  counter-increment: cnt;
  padding-left: 8px;
}
.p-safety_warranty__list.-num.-l2 .c-list__item::before {
  content: "(" counter(cnt) ")";
  display: inline-block;
  margin-left: -2.2em;
  width: 2.2em;
  text-align: right;
  position: absolute;
  top: 0;
  left: 0;
}
.p-safety_warranty__list.-num.-l3 {
  margin-left: 1.5em;
}
.p-safety_warranty__list.-num.-l3 .c-list__item {
  counter-increment: cnt2;
  padding-left: 8px;
}
.p-safety_warranty__list.-num.-l3 .c-list__item::before {
  content: "[" counter(cnt2) "]";
  display: inline-block;
  margin-left: -2.2em;
  width: 2.2em;
  text-align: right;
  position: absolute;
  top: 0;
  left: 0;
}

.p-introduction-delivery__table.-layout-fix {
  table-layout: fixed;
}
.p-introduction-delivery__table .border-red {
  border: 1px solid #db0012;
  box-sizing: border-box;
}
.p-introduction-delivery__table .border-red-r {
  border-right: 1px solid #db0012;
  box-sizing: border-box;
}

.p-service .c-list.-dot {
  --pl: 1.2em;
}
.p-service .c-list.-gap32 > .c-list__item + .c-list__item {
  margin-top: 2rem;
}
.p-service .c-list.-gap40 > .c-list__item + .c-list__item {
  margin-top: 2.5rem;
}

.p-storetop .is-storetop-link {
  display: block;
}
.p-storetop .is-notstoretop-link {
  display: none;
}

.p-service .c-flex.-pc1-sp1 > .c-flex__item {
  width: calc(50% - var(--gap-h));
  min-width: 560px;
}

@media screen and (max-width: 767px) {
  .p-app__head {
    font-size: 1.125rem;
    justify-content: flex-start;
  }
  .p-app__head img {
    width: 56px;
  }
  .p-app__ios-icon {
    flex-direction: row;
    justify-content: center;
    margin-top: 16px;
  }
  .p-app__ios-icon img {
    width: 155px;
  }
  .p-app__android {
    margin-top: 40px;
  }
  .p-app__android-icon {
    flex-direction: row;
    justify-content: center;
    margin-top: 16px;
  }
  .p-app__android-icon img {
    width: 190px;
  }
  .p-app__os {
    margin-top: 32px;
  }
  .p-app__os .p-app__os-large {
    display: block;
    padding-right: 0;
    font-size: 1.25rem;
  }
  .p-bnr {
    padding: 0;
  }
  .p-bnr .splide__slide {
    padding: 0 16px;
    border: none;
  }
  .p-bnr .splide__slide img {
    border: 2px solid #9ea6b2;
  }
  .p-bnr .splide__slide a[target=_blank]::after {
    bottom: 2px;
    right: 2px;
  }
  .p-bnr__controls .splide__pagination > li + li::before {
    left: -8px;
  }
  .p-bnr__controls .splide__pagination {
    gap: 8px;
    flex-shrink: 0;
  }
  .p-bnr__controls .splide__arrows {
    margin-left: 4px;
    gap: 4px;
  }
  .p-card-comm__comment {
    min-height: 0;
  }
  .p-card-comm__comment p {
    margin-bottom: 20px;
    font-size: 1.125rem;
  }
  .p-check {
    grid-template-columns: 1fr;
  }
  .p-check__txt {
    margin-left: 0;
  }
  .p-check__txt + .p-check__list {
    margin-top: 16px;
  }
  .p-check__item {
    padding: 16px 24px 16px 52px;
    font-size: 1rem;
  }
  .p-check__item + .p-check__item {
    margin-top: 8px;
  }
  .p-check__item::before {
    left: 20px;
    top: 16px;
  }
  .p-map {
    grid-template-columns: repeat(1, 1fr);
    background-image: none;
  }
  .p-map__area {
    position: relative;
    font-size: 1.125rem;
  }
  .p-map__area::before, .p-map__area::after {
    content: "";
    width: 16px;
    height: 2px;
    border-radius: 2px;
    background-color: #1d2129;
    position: absolute;
    right: 0;
    top: calc(50% - 1px);
  }
  .p-map__area::after {
    transform: rotate(90deg);
    transition: transform 0.3s;
  }
  .p-map__list {
    grid-auto-columns: 1fr;
  }
  .p-map__item {
    font-size: 1rem;
  }
  .p-passport-anshin {
    grid-template-columns: 1fr;
    gap: 40px;
  }
  .p-passport-anshin__list > li {
    display: block;
  }
  .p-passport-anshin__head {
    flex-direction: row;
    width: -moz-fit-content;
    width: fit-content;
    height: auto;
    padding: 4px 8px;
    border-radius: 4px;
    font-size: 0.875rem;
  }
  .p-passport-anshin__num {
    margin-top: 0;
    margin-left: 4px;
    font-size: 1.125rem;
  }
  .p-passport-anshin__txt {
    margin-left: 0;
    margin-top: 8px;
  }
  .p-passport-anshin__lead {
    font-size: 1.125rem;
  }
  .p-passport-anshin__sub {
    font-size: 0.875rem;
  }
  .p-passport-sp {
    grid-template-columns: 1fr;
    gap: 24px;
  }
  .p-passport-sp__img01 {
    width: 152px;
  }
  .p-store-mv__title {
    padding-top: 16px;
    font-size: 1.125rem;
  }
  .p-store-mv__title img {
    width: 120px;
  }
  .p-store-mv__inner {
    padding: 0;
  }
  .p-service__card .c-card__img img {
    padding: 8px;
  }
  .p-service__heading .c-clms.-body {
    width: 100%;
    grid-template-columns: 100%;
  }
  .p-service__heading .c-list__item {
    font-size: 1rem;
  }
  .p-support-repair__list {
    margin-left: 8px;
  }
  .p-support-repair__list .c-list__item {
    width: 100%;
  }
  .p-safety_warranty__list.-in-table .c-list__item {
    display: block;
    margin-right: 0;
  }
  .p-introduction-delivery__table .-w-140-sp {
    width: 140px;
  }
  .p-service .c-flex.-pc1-sp1 > .c-flex__item {
    width: calc(100% - var(--gap-h));
    min-width: auto;
  }
}

@media (min-width: 768px) {
  .p-app__grid {
    display: grid;
    grid-template: "ios iosicon androidicon android" 100px "ios os os android" max-content/1fr 173px 222px 1fr;
    gap: 16px 24px;
  }
  .p-app__icon:hover {
    transform: scale(1.1);
  }
  .p-bnr .splide__slide a:hover img {
    transform: scale(1.1);
  }
  .p-bnr__parts {
    display: none;
  }
  .splide__list.-bnr6 > .splide__slide:nth-child(1) {
    width: calc(33% - 10px);
  }
  .splide__list.-bnr6 > .splide__slide:nth-child(2) {
    width: calc(33% - 10px);
  }
  .splide__list.-bnr6 > .splide__slide:nth-child(3) {
    width: calc(33% - 10px);
  }
  .splide__list.-bnr6 > .splide__slide:nth-child(4) {
    width: calc(33% - 10px);
  }
  .splide__list.-bnr6 > .splide__slide:nth-child(5) {
    width: calc(33% - 10px);
  }
  .splide__list.-bnr6 > .splide__slide:nth-child(6) {
    width: calc(33% - 10px);
  }
  .splide__list.-bnr5 > .splide__slide:nth-child(1) {
    width: calc(50% - 8px);
    max-width: 450px;
  }
  .splide__list.-bnr5 > .splide__slide:nth-child(2) {
    width: calc(50% - 8px);
    max-width: 450px;
  }
  .splide__list.-bnr5 > .splide__slide:nth-child(3) {
    width: calc(33% - 10px);
    max-width: 294px;
  }
  .splide__list.-bnr5 > .splide__slide:nth-child(4) {
    width: calc(33% - 10px);
    max-width: 294px;
  }
  .splide__list.-bnr5 > .splide__slide:nth-child(5) {
    width: calc(33% - 10px);
    max-width: 294px;
  }
  .splide__list.-bnr4 > .splide__slide:nth-child(1) {
    width: calc(50% - 8px);
  }
  .splide__list.-bnr4 > .splide__slide:nth-child(2) {
    width: calc(50% - 8px);
  }
  .splide__list.-bnr4 > .splide__slide:nth-child(3) {
    width: calc(50% - 8px);
  }
  .splide__list.-bnr4 > .splide__slide:nth-child(4) {
    width: calc(50% - 8px);
  }
  .splide__list.-bnr3 > .splide__slide:nth-child(1) {
    grid-area: 1/1/3/3;
  }
  .splide__list.-bnr3 > .splide__slide:nth-child(2) {
    grid-area: 1/3/2/4;
  }
  .splide__list.-bnr3 > .splide__slide:nth-child(3) {
    grid-area: 2/3/3/4;
  }
  .p-map .-tohoku {
    grid-area: 1/1/2/2;
  }
  .p-map .-hokuriku {
    grid-area: 2/1/3/2;
  }
  .p-map .-kanto {
    grid-area: 3/1/4/2;
  }
  .p-map .-tokai {
    grid-area: 1/2/2/3;
  }
  .p-map .-kansai {
    grid-area: 2/2/3/3;
  }
  .p-map .-chugoku {
    grid-area: 3/2/4/3;
  }
  .p-map .-kyushu {
    grid-area: 1/3/2/4;
  }
  .p-map__area {
    pointer-events: none;
    cursor: default;
  }
  .p-passport-sp__img02 img {
    margin-left: 0;
  }
  .p-app__ios {
    -ms-grid-row: 1;
    -ms-grid-row-span: 3;
    -ms-grid-column: 1;
  }
  .p-app__ios-icon {
    -ms-grid-row: 1;
    -ms-grid-column: 3;
  }
  .p-app__android {
    -ms-grid-row: 1;
    -ms-grid-row-span: 3;
    -ms-grid-column: 7;
  }
  .p-app__android-icon {
    -ms-grid-row: 1;
    -ms-grid-column: 5;
  }
  .p-app__os {
    -ms-grid-row: 3;
    -ms-grid-column: 3;
    -ms-grid-column-span: 3;
  }
}
