/* -------------------------------------------------- */
/* slider */

.slider {
  padding: 0;
  position: relative;
}
.slider-body {
  height: 44.27vw;
}
.slider-slide {
  background: transparent no-repeat center center / 100% auto;
  width: 100vw;
}
.slider-slide1 {
  background-image: url(../images/top/slider-slide01.webp);
}
.slider-slide2 {
  background-image: url(../images/top/slider-slide02.webp);
}
.slider-slide3 {
  background-image: url(../images/top/slider-slide03.webp);
}
.slider-slide4 {
  background-image: url(../images/top/slider-slide04.webp);
}
.slider-slide .wrapper {
  align-items: flex-start;
  display: flex;
  flex-direction: column;
  height: 100%;
  justify-content: center;
  position: relative;
}
.slider-slide1 .wrapper {
  align-items: flex-end;
  justify-content: flex-start;
}
.slider-slide3 .wrapper {
  align-items: flex-end;
  justify-content: flex-start;
  padding-top: 4.16vw;
  text-align: right;
}
.slider-slide4 .wrapper {
  justify-content: flex-end;
  padding-bottom: 5.95vw;
}
.slider-slide p {
  font-family: '游明朝体', serif;
  font-weight: bold;
}
.slider-slide p.fcw {
  color: #fff;
  line-height: 1.25;
  text-shadow: 0 3px 6px rgba(0,0,0,.6);
}
.slider-slide p.fcb {
  color: var(--main-color1);
  margin-bottom: 20px;
  text-align: center;
}
.slider-slide p span.fs142 {
  font-size: 14.2rem;
}
.slider-slide p span.fs110 {
  font-size: 11rem;
}
.slider-slide p span.fs100 {
  display: inline-block;
  font-size: 10rem;
  margin-bottom: 5px;
}
.slider-slide p span.fs89 {
  font-size: 8.9rem;
}
.slider-slide p span.fs80 {
  font-size: 8rem;
}
.slider-slide p span.fs60 {
  font-size: 6rem;
}
.slider-slide p span.fs46 {
  font-size: 4.6rem;
}
.slider-slide p span.fs30 {
  font-size: 3rem;
  line-height: 1.5;
}
.slider-slide p span.by {
  background: rgba(255,247,0,.8);
  border-radius: 10px;
  display: inline-block;
  padding: .05em;
}
.slider-slide p span.w540 {
  width: 540px;
}
.slider-slide p span.w445 {
  width: 445px;
}
.slider-slide p span.w220 {
  width: 220px;
}
.slider-slide p span.w130 {
  margin-right: 10px;
  width: 130px;
}
.slider-slide p.pa {
  bottom: 30px;
  color: #fff;
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 1.4rem;
  font-weight: 400;
  position: absolute;
}
.slider-slide1 p.pa {
  left: 260px;
}
.slider-slide2 p.pa {
  left: 478px;
}
.slider-content {
  left: 0;
  height: 100%;
  pointer-events: none;
  position: absolute;
  top: 0;
  width: 100%;
  z-index: 20;
}
.slider-content .wrapper {
  height: 100%;
  position: relative;
  width: 100%;
}
.slider-box {
  background: rgba(13,94,245,.85);
  background: linear-gradient(180deg, rgba(13,94,245,.85), rgba(19,149,212,.85));
  border-radius: 10px;
  bottom: -80px;
  padding: 27px 49px;
  pointer-events: all;
  position: absolute;
  right: 0;
}
.slider-head {
  color: #fff;
  font-size: 2.8rem;
  font-weight: 700;
  margin-bottom: 10px;
  text-align: center;
}
.slider-select {
  align-items: stretch;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  margin-bottom: 20px;
}
.slider-select select {
  background: var(--bg-color2) url(../images/arrow-down-gray.webp) no-repeat center right 20px / 9.5px 6.5px;
  border: 1px solid #cdd6dd;
  margin: 6.5px 0;
  padding: .95em;
  width: 360px;
}
.slider-button a,
.slider-button input[type='submit'] {
  background: #fff700 url(../images/arrow-right-blue.webp) no-repeat center right 20px / 6.5px 9.5px;
  border: 2px solid #fff;
  border-radius: 9999px;
  color: var(--main-color2);
  cursor: pointer;
  display: block;
  font-size: 2rem;
  font-weight: 700;
  padding: .5em;
  text-align: center;
  transition: background .2s, color .2s;
  width: 100%;
}
.slider-button a:hover,
.slider-button input[type='submit']:hover {
  background-color: var(--hover-color);
}

/* -------------------------------------------------- */
/* pickup */

.pickup {
  padding-top: 0;
}
.pickup .title {
  text-align: center;
  width: 100%;
}
.pickup-head {
  align-items: stretch;
  margin-bottom: 20px;
}
.pickup h2.global {
  border-right: 7px solid var(--main-color2);
  margin-bottom: 0;
  width: calc(50% + 3.5px);
}
.pickup-head p {
  width: 47%;
}
.pickup-body {
  position: relative;
}
.pickup-content.swiper {
  margin-bottom: 20px;
  padding: 10px;
}
.pickup-content .swiper-wrapper {
  align-items: stretch;
}
.pickup-slide.swiper-slide {
  background: #fff;
  box-shadow: 0 0 10px rgba(0,0,0,.16);
  color: var(--text-color1);
  height: auto;
  padding: 5px;
}
.pickup-image {
  background: var(--bg-color2);
  height: 235px;
  margin-bottom: 15px;
  position: relative;
  width: 100%;
}
.pickup-image img {
  height: 100%;
  object-fit: cover;
  width: 100%;
}
.pickup-image-circle {
  align-items: center;
  background: #fff700;
  border-radius: 50%;
  display: flex;
  font-size: 1.8rem;
  font-weight: 700;
  height: 76px;
  justify-content: center;
  position: absolute;
  right: 10px;
  top: 10px;
  width: 76px;
}
.pickup-name {
  color: var(--main-color2);
  font-size: 2.4rem;
  font-weight: 700;
  margin-bottom: 15px;
  text-align: center;
}
.pickup-point {
  color: var(--main-color2);
  font-weight: 700;
  margin-bottom: 25px;
  text-align: center;
}
.pickup-point span {
  background: linear-gradient(180deg, var(--gradient1), var(--gradient2));
  border-radius: 9999px;
  color: #fff;
  display: block;
  font-size: 1.2rem;
  font-weight: 400;
  margin: 0 auto 15px;
  padding: .7em 0 .6em;
  width: 117px;
}
.pickup-text {
  padding: 0 15px;
}
.pickup-text table {
  font-size: 1.6rem;
  line-height: 1.8;
  margin-bottom: 20px;
  vertical-align: top;
  width: 100%;
}
.pickup-text table tr th {
  border-bottom: 1px solid #cdd6dd;
  font-weight: 400;
  padding: .25em 1em;
  vertical-align: top;
}
.pickup-text table tr td {
  border-bottom: 1px solid #cdd6dd;
  font-weight: 700;
  padding: .25em 0;
}
.pickup .swiper-button-prev,
.pickup .swiper-button-next {
  background: var(--text-color2) url(../images/arrow-right-white.webp) no-repeat center center / 13px 19px;
  border-radius: 10px;
  height: 50px;
  width: 50px;
}
.pickup .swiper-button-prev {
  left: -55px;
  transform: rotate(180deg);
}
.pickup .swiper-button-next {
  right: -55px;
}
.pickup .swiper-button-prev::after,
.pickup .swiper-button-next::after {
  display: none;
}

/* -------------------------------------------------- */
/* category */

.category h2.global,
.category h3.global {
  margin-bottom: 30px;
}
.category p {
  line-height: 1.8;
  margin-bottom: 60px;
  text-align: center;
}
.category-model {
  margin-bottom: 80px;
}
.category-maker {
  left: -16px;
  margin-bottom: 20px;
  position: relative;
  top: -20px;
  width: calc(100% + 32px);
}
.category-maker ul.grid {
  justify-content: center;
}
.category-maker ul li {
  margin: 20px 15px;
  width: 263px;
}
.category-button {
  margin-bottom: 20px;
}

/* -------------------------------------------------- */
/* results */

.results {
  background: #fff;
  padding-top: 80px;
}
.results .wrapper::before {
  background: url(../images/top/results-bg.webp) no-repeat 0 0 / 414px 748px;
  height: 748px;
  right: -70px;
  top: -140px;
  width: 414px;
}
.results .title {
  color: var(--bg-color2);
  top: -80px;
}
.results h2.global {
  margin-bottom: 30px;
}
.results p {
  margin-bottom: 55px;
  text-align: center;
}
.results-content {
  margin-bottom: 45px;
}

/* -------------------------------------------------- */
/* flow */

.flow {
  background: var(--bg-color2);
}
.flow .wrapper {
  position: relative;
}
.flow .title {
  color: #fff;
  position: absolute;
  right: 0;
  top: -80px;
}
.flow-content {
  margin-bottom: 60px;
}
.flow-content ul {
  align-items: stretch;
  display: flex;
  justify-content: space-between;
}
.flow-content ul li {
  border-right: 2px solid #fff;
  padding: 0 30px 50px;
  position: relative;
  width: 25%;
}
.flow-content ul li:last-of-type {
  border-right: 0;
}
.flow-content ul li::after {
  background: var(--main-color2) url(../images/arrow-right-white.webp) no-repeat center center / 13.5px 20.5px;
  border-radius: 10px;
  content: '';
  display: block;
  height: 36px;
  position: absolute;
  right: -18px;
  top: calc(50% - 18px);
  width: 36px;
}
.flow-content ul li:last-of-type::after {
  display: none;
}
.flow-image img {
  border-radius: 50%;
  display: block;
  margin: 0 auto 15px;
  width: 190px;
}
.flow-head {
  color: var(--main-color2);
  font-size: 1.8rem;
  font-weight: 700;
  margin-bottom: 20px;
  text-align: center;
}
.flow-head span {
  color: #707f89;
  display: block;
  font-size: 1.2rem;
  font-weight: 400;
  margin-bottom: 10px;
}
.flow-content ul li p {
  line-height: 1.8;
}
