@charset "utf-8";

/*========================================================================*\

$main

\*========================================================================*/

#topmain {
  margin: 0;
  position: relative;
}

#topmain .mainInner {
  margin-left: auto;
  overflow: hidden;
}

#topmain .slider {
  margin: 0 auto !important;
  opacity: 0;
  padding: 0 !important;
  text-align: center !important;
  transition: 3s;
  width: 100%;
}

#topmain .slick-list {
  margin: 0 auto !important;
  text-align: center !important;
}

#topmain .slick-slide {
  line-height: 0;
  margin: 0 10px;
  padding: 0 !important;
  text-align: center !important;
}

#topmain .slick-initialized {
  opacity: 1;
}

#topmain .slider img,
#topmain .slider video,
#topmain .sliderBox iframe {
  height: auto;
  width: 100%;
}

#topmain .slider-img {
  margin: 0 10px;
}

#topmain .slick-slide li {
  height: 0;
  overflow: hidden;
  padding-bottom: 56.25%;
  position: relative;
}

#topmain .slick-slide {
  position: relative;
}

#topmain .slick-list li div {
  bottom: 100px;
  position: absolute;
  right: 20px;
}

/* 中身を縦横中央に配置 */
#topmain .slick-list li #main_okuaizu {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  text-align: center; /* 中の画像を横センター */
  width: 65%;
}

.slick-list li p img {
  margin: 0 0 0 auto;
  width: 100% !important;
}

.slick-dots {
  bottom: 20px !important;
}

.slick-dots li.slick-active button:before {
  color: #1386bf !important;
  opacity: 0.75;
}

.slick-prev {
  left: 50px !important;
}

.slick-next {
  right: 50px !important;
}

.slick-prev,
.slick-next {
  z-index: 100 !important;
}

#lowermain {
  position: relative;
}

#lowermain::after,
#lowermain_02::after {
  background: rgba(0, 113, 187, 0.05);
  bottom: -45px;
  content: "";
  display: block;
  height: 230px;
  left: 0;
  position: absolute;
  width: 100vw;
  z-index: -1;
}

#lowermain .mainInner {
  align-items: center;
  animation-duration: 1s;
  animation-fill-mode: forwards;
  animation-name: bgextendAnimeBase;
  background: url(../images/lower_main.jpg) center top;
  background-repeat: no-repeat;
  background-size: cover;
  display: flex;
  height: 350px;
  justify-content: flex-end;
  margin: 0 0 0 auto;
  opacity: 0;
  position: relative;
  width: 78vw;
}

#lowermain.case03main .mainInner {
  background: url(../images/lower_main_case03.jpg) left 45%;
  background-repeat: no-repeat;
  background-size: cover;
}

#lowermain.case04main .mainInner {
  background: url(../images/lower_main_case04.jpg) left 45%;
  background-repeat: no-repeat;
  background-size: cover;
}

#lowermain.case05main .mainInner {
  background: url(../images/lower_main_case05.jpg) left 45%;
  background-repeat: no-repeat;
  background-size: cover;
}

#lowermain.case06main .mainInner {
  background: url(../images/lower_main_case06.jpg) left 45%;
  background-repeat: no-repeat;
  background-size: cover;
}

#lowermain.case07main .mainInner {
  background: url(../images/lower_main_case07.jpg) left 45%;
  background-repeat: no-repeat;
  background-size: cover;
}

#lowermain.monthlymain .mainInner {
  background: url(../solution/monthly/img/main.jpg) center bottom;
  background-repeat: no-repeat;
  background-size: cover;
}

#lowermain.constructionmain .mainInner {
  background: url(../solution/construction/img/main.jpg) center bottom;
  background-repeat: no-repeat;
  background-size: cover;
}

#lowermain.udxmain .mainInner {
  background: url(../solution/udx/img/main.jpg) left 45%;
  background-repeat: no-repeat;
  background-size: cover;
}

#lowermain.networkmain .mainInner {
  background: url(../solution/network/img/main.jpg) center center;
  background-repeat: no-repeat;
  background-size: cover;
}

#lowermain.aimain .mainInner {
  background: url(../solution/ai/img/ai_main.jpg) center center;
  background-repeat: no-repeat;
  background-size: cover;
}

#lowermain.aimain_02 .mainInner {
  background: url(../solution/ai/img/ai_main_02.jpg) center center;
  background-repeat: no-repeat;
  background-size: cover;
}

#lowermain.autonomousmain .mainInner {
  background: url(../solution/autonomous/img/main.jpg) center 55%;
  background-repeat: no-repeat;
  background-size: cover;
}

#lowermain.privacymain .mainInner {
  background: url(../privacy/img/main.jpg) center 30%;
  background-repeat: no-repeat;
  background-size: cover;
}

#lowermain.termsmain .mainInner {
  background: url(../terms/img/main.jpg) center top;
  background-repeat: no-repeat;
  background-size: cover;
}

#lowermain.termsmain .mainInner {
  background: url(../terms/img/main.jpg) center center;
  background-repeat: no-repeat;
  background-size: cover;
}

#lowermain.newsmain .mainInner {
  background: url(../news/img/main.jpg) center center;
  background-repeat: no-repeat;
  background-size: cover;
}

#lowermain.contractmain .mainInner {
  background: url(../contract/img/main.jpg) center center;
  background-repeat: no-repeat;
  background-size: cover;
}

#lowermain.contactmain .mainInner {
  background: url(../contact/img/main.jpg) center center;
  background-repeat: no-repeat;
  background-size: cover;
}

#lowermain.faqmain .mainInner {
  background: url(../faq/img/main.jpg) center 10%;
  background-repeat: no-repeat;
  background-size: cover;
}

#lowermain.companymain .mainInner {
  background: url(../company/img/lower_main.jpg) center center;
  background-repeat: no-repeat;
  background-size: cover;
}

#lowermain.companymain_02 .mainInner {
  background: url(../company/img/lower_main_02.jpg) center center;
  background-repeat: no-repeat;
  background-size: cover;
}

#lowermain.companymain_03 .mainInner {
  background: url(../company/img/lower_main_03.jpg) center center;
  background-repeat: no-repeat;
  background-size: cover;
}

#lowermain.companymain_04 .mainInner {
  background: url(../company/img/lower_main_04.jpg) center 80%;
  background-repeat: no-repeat;
  background-size: cover;
}

#lowermain.securitymain .mainInner {
  background: url(../case/security/img/main.jpg) center center;
  background-repeat: no-repeat;
  background-size: cover;
}

#lowermain.securitymain .mainInner {
  background: url(../case/security/img/main.jpg) center 40%;
  background-repeat: no-repeat;
  background-size: cover;
}

#lowermain.englishmain .mainInner {
  background: url(../english/img/main.jpg) center center;
  background-repeat: no-repeat;
  background-size: cover;
}

#lowermain.englishmain .mainInner {
  background: url(../english/img/main.jpg) center center;
  background-repeat: no-repeat;
  background-size: cover;
}

#lowermain.englishmain_02 .mainInner {
  background: url(../english/use/img/main.jpg) center center;
  background-repeat: no-repeat;
  background-size: cover;
}

#lowermain.englishmain_03 .mainInner {
  background: url(../english/use/img/main.jpg) center center;
  background-repeat: no-repeat;
  background-size: cover;
}

#lowermain.recruitmain .mainInner {
  background: url(../recruit/img/main.jpg) center 45%;
  background-repeat: no-repeat;
  background-size: cover;
}

#lowermain.downloadmain .mainInner {
  background: url(../company/download/img/main.jpg) center 70%;
  background-repeat: no-repeat;
  background-size: cover;
}

#lowermain.columnmain .mainInner {
  background: url(../column/img/main.jpg) center 70%;
  background-repeat: no-repeat;
  background-size: cover;
}

#smart_ticket #lowermain .mainInner {
  background: url(../solution/smart_ticket_parking/img/main.jpg) center 45%;
  background-repeat: no-repeat;
  background-size: cover;
}

.bgRLextend::before {
  animation-duration: 1s;
  animation-fill-mode: forwards;
  animation-name: bgRLextendAnime;
  background: #1386bf;
  content: "";
  height: 100%;
  position: absolute;
  width: 100%;
}

@keyframes bgRLextendAnime {
  0% {
    transform: scaleX(0);
    transform-origin: right;
  }
  50% {
    transform: scaleX(1);
    transform-origin: right;
  }
  50.001% {
    transform-origin: left;
  }
  100% {
    transform: scaleX(0);
    transform-origin: left;
  }
}

@keyframes bgextendAnimeBase {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

#lowermain .mainItem {
  left: 5%;
  margin: auto;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
}

#lowermain .mainItem h2,
#lowermain.columnmain h1 {
  color: #0061af;
  font-size: 3.6rem;
  font-weight: 700;
  line-height: 1.3;
}

#lowermain .mainItem h2::before,
#lowermain.columnmain h1::before {
  background-image: url(../images/ico_lep.png);
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  display: block;
  height: 100px;
  margin: 0 0 20px 0;
  text-align: center;
  width: 120px;
}

#lowermain .mainItem .en {
  display: block;
  font-family: "Work Sans", sans-serif !important;
  font-size: 2rem;
  font-weight: 700;
  letter-spacing: 0.3rem;
  line-height: 1.6;
}

#lowermain.specialMain .mainInner {
  align-items: center;
  animation-duration: 1s;
  animation-fill-mode: forwards;
  animation-name: bgextendAnimeBase;
  background: url(../solution/coin_parking/img/main.jpg) center top;
  background-repeat: no-repeat;
  background-size: cover;
  display: flex;
  height: 750px;
  justify-content: flex-end;
  margin: 0;
  opacity: 0;
  position: relative;
  width: 100vw;
}

#system #lowermain.specialMain .mainInner {
  background: url(../solution/system/img/main.jpg) center top;
  background-size: cover;
}

#coin_parking #lowermain.specialMain .mainInner {
  background: url(../solution/coin_parking/img/main.jpg) center top;
  background-size: cover;
}

#smart_parking #lowermain.specialMain .mainInner {
  background: url(../solution/smart_parking/img/main.jpg) center top;
  background-size: cover;
}

#park_go #lowermain.specialMain .mainInner {
  background: url(../solution/park-go/img/main.jpg) center bottom;
  background-size: cover;
}

#parking_system #lowermain.specialMain .mainInner {
  background: url(../solution/parking_system/img/main.jpg) center top;
  background-size: cover;
}

#udx #lowermain.specialMain .mainInner {
  background: url(../solution/udx/img/main.jpg) center top;
  background-size: cover;
}

#carshare #lowermain.specialMain .mainInner {
  background: url(../solution/carshare/img/main.jpg) center top;
  background-size: cover;
}

#okuaizu #lowermain.specialMain .mainInner {
  background: url(../solution/carshare/okuaizu/img/main.jpg) center center;
  background-size: cover;
}

#lowermain.specialMain .mainInner::before {
  background: rgba(21, 115, 182, 0.4);
  content: "";
  display: block;
  height: 100%;
  left: 0;
  position: absolute;
  top: 0;
  width: 100%;
}

#lowermain.specialMain .mainItem,
#lowermain_02.specialMain .mainItem {
  bottom: 10%;
  top: auto;
  transform: none;
}

#lowermain.specialMain .mainItem h2,
#lowermain_02.specialMain .mainItem h2 {
  color: #ffffff;
  font-size: 6rem;
  font-weight: 700;
  margin-bottom: 20px;
}

#system #lowermain.specialMain .mainItem h2 {
  font-size: 5rem;
}

#system #lowermain.specialMain .mainItem h2 .ss {
  font-size: 2.5rem;
  line-height: 1.2 !important;
}

#udx #lowermain.specialMain .mainItem h2 {
  line-height: 1.2;
}

#lowermain.specialMain .mainItem h2::before,
#lowermain_02.specialMain .mainItem h2::before {
  content: none;
}

#lowermain.specialMain .mainItem h2 .ss,
#lowermain_02.specialMain .mainItem h2 .ss {
  font-size: 1.8rem;
  line-height: 2.8;
}

#lowermain.specialMain .mainItem p,
#lowermain_02.specialMain .mainItem p {
  color: #ffffff;
  font-size: 1.8rem;
  line-height: 1.8;
}

#lowermain_02 {
  margin: 0;
  position: relative;
}

#lowermain_02 .mainInner {
  height: 750px;
  margin-left: auto;
  overflow: hidden;
}

#lowermain_02 .swiper-img.main_01 {
  background-image: url(../solution/enterprise_carshare/img/main_01.jpg);
}

#lowermain_02 .swiper-img.main_02 {
  background-image: url(../solution/enterprise_carshare/img/main_02.jpg);
}

#lowermain_02 .swiper-container {
  padding-right: 0 !important;
  position: relative;
}

#lowermain_02 .swiper-slide {
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  overflow: hidden;
}

#lowermain_02 .swiper-slide-active .swiper-img,
#lowermain_02 .swiper-slide-duplicate-active .swiper-img,
#lowermain_02 .swiper-slide-prev .swiper-img {
  animation: zoomUp 8s linear 0s;
  animation-fill-mode: both;
}

#lowermain_02 .swiper-img {
  background-position: center center;
  background-size: cover;
  height: 750px;
}

#lowermain_02 .swiper-slide-active .swiper-text .swiper-text__inner.slide-in {
  animation-delay: 1s;
  animation-name: fadeInUpSmall;
  bottom: 10%;
  left: 5%;
  position: absolute;
  transform: none;
}

#lowermain_02 .swiper-text {
  background: rgba(21, 115, 182, 0.4);
  content: "";
  display: block;
  height: 100%;
  left: 0;
  position: absolute;
  top: 0;
  width: 100%;
}

#lowermain_02 .swiper-text__inner {
  margin: 0 auto;
  max-width: 1040px;
  width: 1040px;
}

#lowermain_02 .swiper-text h2 {
  color: #ffffff;
  display: block;
  font-size: 7rem;
  font-weight: 700;
  line-height: 1.3;
  margin-bottom: 1rem;
}

#lowermain_02 .swiper-text p {
  color: #ffffff;
  display: block;
  font-size: 4rem;
  font-weight: 700;
  line-height: 1.6;
}

/*========================================================================*\

$index

\*========================================================================*/

#index .sectionInner {
  margin: 0 auto;
  padding: 10rem 0;
  width: 1040px;
}

/*========================================================================*\

$catchSection

\*========================================================================*/

#catchSection {
  background-color: rgba(0, 99, 177, 1);
  background-image: repeating-linear-gradient(
    135deg,
    transparent,
    transparent 3px,
    rgba(0, 113, 187, 1) 3px,
    rgba(0, 113, 187, 1) 6px
  );
  background-size: auto auto;
  border-top: 10px solid #fedd11;
}

#index #catchSection .sectionInner {
  padding: 30px 0;
}

#catchSection h2 {
  color: #ffffff;
  font-size: 3.6rem;
  font-weight: 700;
  line-height: 1;
  margin: 0;
  padding: 0;
  text-align: center;
}

/*========================================================================*\

$catchSection

\*========================================================================*/

#solutionSection {
  background: url(../images/bg_solution.png) no-repeat bottom center;
}

#solutionSection .lpbtn {
  width: 700px;
  margin: 50px auto 0 auto;
}

#solutionSection .lpbtn a {
  background: #d40004;
  color: #ffffff;
  border: none;
  font-size: 2rem;
}

#solutionSection .lpbtn a::after {
  border-right: 2px solid #ffffff;
  border-top: 2px solid #ffffff;
}

#solutionSection .sectionInner {
  align-items: center;
  display: flex;
  flex-direction: row-reverse;
  position: relative;
}

#solutionSection h2 {
  font-size: 4.2rem;
  font-weight: 700;
  line-height: 1;
  margin: 0 0 40px 0;
  padding: 0;
}

#solutionSection h2::before {
  background-image: url(../images/ico_lep.png);
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  display: block;
  height: 61px;
  margin: 0 auto 30px auto;
  text-align: center;
  width: 90px;
}

#solutionSection .solutionBox {
  box-sizing: border-box;
  overflow: hidden;
  padding: 0 8% 0 0;
  position: relative;
  width: 60%;
}

@media screen and (max-width: 1150px) {
  #solutionSection .solutionBox {
    padding: 0 8% 0 5%;
  }
}

#solutionSection .solutionBox p {
  font-size: 1.8rem;
}

#solutionSection .solutionBox .catch {
  font-size: 2.2rem;
  font-weight: 700;
}

#solutionSection .solutionImage {
  display: flex;
  margin: 0 0 0 auto;
  width: 35%;
}

#solutionSection .solutionImage ul {
  display: flex;
}

#solutionSection .solutionImage ul li:nth-child(1) {
  padding-top: 60px;
}

#solutionSection .solutionImage ul li:nth-child(3) {
  padding-top: 100px;
}

/*========================================================================*\

$newsSection

\*========================================================================*/

#Co #newsSection {
  background: #f2f8fc;
  padding: 10rem 0;
}

#Co #newsSection .sectionInner {
  background: #ffffff;
  padding: 5rem;
  position: relative;
}

#Co #newsSection .sectionInner:nth-child(n + 2) {
  margin-top: 5rem;
}

#Co #newsSection .sectionInner:nth-child(n + 2) h3 {
  margin-bottom: 20px;
}

#Co #newsSection .sectionInner iframe {
  height: 750px;
  width: 100%;
}

#Co #newsSection .sectionInner h3 {
  font-size: 4.2rem;
  font-weight: 700;
  line-height: 1;
  margin: 0;
  margin-bottom: 40px;
}

#Co #newsSection .sectionInner h3 .en {
  color: #1386bf;
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.2;
}

#Co #newsSection .newsBoxInner dl {
  align-items: center;
  display: flex;
  justify-content: space-between;
  width: 100%;
}

#Co #newsSection .newsBoxInner dt {
  align-items: center;
  display: flex;
  font-family: "Work Sans", sans-serif !important;
  justify-content: space-between;
  width: 23%;
}

#Co #newsSection .newsBoxInner dd {
  line-height: 1.4;
  padding-right: 5%;
  width: 75%;
}

#Co #newsSection .newsBox {
  position: relative;
}

#Co #newsSection .newsBox .newsBoxInner {
  border-bottom: 1px solid #c3c3c3;
  color: #121212;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin-bottom: 2rem;
  padding-bottom: 2rem;
  position: relative;
  text-decoration: none;
  width: 100%;
}

#Co #newsSection .newsBox .newsBoxInner::before {
  background-color: #1386bf;
  bottom: -1px;
  content: "";
  display: inline-block;
  height: 1px;
  left: 0;
  position: absolute;
  width: 22%;
}

#Co #newsSection .newsBox .newsBoxInner:after {
  border-right: solid 2px #121212;
  border-top: solid 2px #121212;
  content: "";
  height: 8px;
  position: absolute;
  right: 20px;
  top: 46%;
  transform: translateY(-50%) rotate(45deg);
  transition: 0.3s;
  width: 8px;
}

#Co #newsSection .newsBox .newsBoxInner:hover:after {
  border-right: solid 2px #1386bf;
  border-top: solid 2px #1386bf;
  right: 5px;
}

#Co #newsSection .btn {
  margin: 0;
  position: absolute;
  right: 50px;
  top: 100px;
  width: auto;
}

#Co #newsSection .btn a {
  background: transparent;
  border: none;
  color: #1386bf;
  display: inline-block;
  font-size: 1.4rem;
  margin: 0;
  padding: 0 2.5rem 0 0;
  position: relative;
  text-align: right;
  text-decoration: underline;
  width: auto;
}

#Co #newsSection .btn a:hover {
  text-decoration: none;
}

#Co #newsSection .btn a:hover::after {
  border-right: solid 2px #1386bf;
  border-top: solid 2px #1386bf;
}

/*========================================================================*\

$side_tel

\*========================================================================*/

#side_tel {
  background: rgba(0, 104, 178, 0.9);
  bottom: 10px;
  display: block;
  padding: 14px;
  position: fixed;
  right: 10px;
  width: 300px;
  z-index: 10000;
}

#side_tel.is-none {
  display: none !important;
}

#side_tel h3 {
  color: #ffffff;
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1;
  margin-bottom: 14px;
  text-align: center;
}

#side_tel .side_tel_Inner {
  background: #ffffff;
  padding: 0 14px;
}

#side_tel .side_tel_Inner a {
  color: #121212;
  display: block;
  padding: 14px 0;
  text-decoration: none;
  width: 100%;
}

#side_tel .side_tel_Inner a:first-child {
  border-bottom: 1px dashed #bdbdbd;
}

#side_tel .side_tel_Inner a p {
  font-size: 1.4rem;
}

#side_tel .side_tel_Inner a p::before {
  border-color: transparent transparent transparent #fedd11;
  border-style: solid;
  border-width: 4.5px 0 4.5px 8px;
  content: "";
  display: inline-block;
  height: 0;
  margin-right: 8px;
  width: 0;
}

#side_tel .side_tel_Inner a h4 {
  font-size: 3.1rem;
  font-weight: 700;
  letter-spacing: -0.2rem;
  line-height: 1;
}

#side_tel .side_tel_Inner a h4:before {
  background-image: url(../images/ico_free.png);
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  display: inline-block;
  height: 20px;
  margin-right: 8px;
  vertical-align: middle;
  width: 35px;
}

/*========================================================================*\

$footer

\*========================================================================*/

footer {
  background: #1386bf;
  padding: 3rem 0;
}

footer a {
  text-decoration: none;
}

footer #footerInner {
  align-items: center;
  display: flex;
  justify-content: space-between;
  margin: 0 auto;
  width: 1040px;
}

footer #footerInner #footerL {
  width: 50%;
}

footer #footerInner #footerL h2 {
  margin: 0 0 10px 0;
}

footer #footerInner #footerL ul {
  align-items: center;
  display: flex;
  justify-content: flex-start;
  margin-bottom: 0 !important;
}

footer #footerInner #footerL ul li {
  color: #ffffff;
  font-size: 1.2rem;
  margin-bottom: 0 !important;
}

footer #footerInner #footerL ul li a {
  color: #ffffff;
  display: block;
  position: relative;
  width: 100%;
}

footer #footerInner #footerL ul li:first-child {
  margin-right: 20px;
}

footer #footerInner #footerL ul li:first-child a::after {
  color: #ffffff;
  content: "|";
  display: inline-block;
  position: absolute;
  right: -10px;
  top: -5px;
}

footer #footerInner #footerR {
  display: flex;
  justify-content: flex-end;
  width: 50%;
}

footer #footerInner #footerR ul {
  align-items: flex-end;
  display: flex;
  justify-content: flex-end;
}

footer #footerInner #footerR ul li:last-child {
  margin-left: 1rem;
}

footer .qr_text {
  color: rgba(255, 255, 255, 1) !important;
  display: none !important;
}

.qr footer #footerInner #footerR .copy .qr_text {
  display: block !important;
  margin: 5px 0 0 0;
}

footer #footerInner #footerR .copy {
  text-align: right;
  color: rgba(255, 255, 255, 0.7);
  font-size: 1.1rem;
  margin-top: 5px;
}

.qr footer #footerInner #footerR .copy {
  margin-top: 0;
}

/*========================================================================*\

$page

\*========================================================================*/

#Co .page section h2 {
  border-image: linear-gradient(
      180deg,
      rgba(32, 80, 161, 1) 0%,
      rgba(0, 165, 230, 1) 100%
    )
    1/0 0 0 2px;
  border-image-slice: 1;
  border-left: solid;
  border-top: none;
  color: #121212;
  font-size: 3.6rem;
  font-weight: 700;
  line-height: 1.2;
  margin: 0 0 40px 0;
  padding: 10px 0 10px 15px;
}

#Co .page section h2:nth-child(n + 2) {
  margin: 80px 0 40px 0;
}

#Co .page section h2 .en {
  color: #0070ba;
  display: block;
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1.4;
}

#Co .page h3 {
  border-bottom: 1px solid #c3c3c3;
  font-size: 2.8rem;
  font-weight: 700;
  line-height: 1.6;
  margin: 0 0 3rem 0;
  padding: 0 0 2rem 0;
  position: relative;
}

#Co .page h3.no {
  border: none;
  margin: 0 0 2rem 0;
  padding: 0;
}

#Co .page h3 .sss {
  font-size: 2rem;
}

#Co .page h3:not(:first-child) {
  margin: 5rem 0 3rem 0;
}

#Co .page h3.no:not(:first-child) {
  margin: 5rem 0 2rem 0;
}

#Co .page h3::after {
  background-color: #1386bf;
  bottom: -1px;
  content: "";
  display: inline-block;
  height: 1px;
  left: 0;
  position: absolute;
  width: 25%;
}

#Co .page h3.no::after {
  content: none;
}

#Co .page h4 {
  border-bottom: 1px dotted #cccccc;
  font-size: 2.2rem;
  font-weight: 700;
  line-height: 1.6;
  margin: 40px 0 20px 0;
  padding: 0 0 10px 20px;
  position: relative;
}

#Co .page h4:before {
  background: #0070ba;
  border-radius: 50%;
  content: "";
  height: 5px;
  left: 0;
  position: absolute;
  top: 0.75em;
  width: 5px;
}

#Co .page .bgBox h4 {
  border-bottom: none;
  margin: 0 0 10px 0;
  padding: 0 0 10px 24px;
}

#Co .page .bgBox h4:before {
  background: transparent;
  border: 4px solid #1386bf;
  border-radius: 50px;
  content: "";
  height: 14px;
  left: 0;
  position: absolute;
  top: 44%;
  transform: translateY(-50%);
  width: 14px;
}

#Co .page h5 {
  font-size: 1.8rem;
  margin-bottom: 1rem;
  padding-bottom: 0.8rem;
}

.bgcolor {
  position: relative;
}

.bgcolor::before {
  background: rgba(0, 113, 187, 0.05);
  bottom: -45px;
  content: "";
  display: block;
  height: 20%;
  left: 0;
  margin: 0 calc(50% - 50vw);
  position: absolute;
  width: 100vw;
  z-index: -1;
}

.page .bgBox {
  background: rgba(0, 113, 187, 0.05);
  margin-bottom: 50px;
  padding: 30px;
  width: 100%;
}

.page .bgBox .bgBoxInner {
  background: #ffffff;
  margin: 0 auto;
  padding: 30px;
  width: 100%;
}

.page .bgBox.wide {
  margin: 0 calc(50% - 50vw);
  padding: 80px 0;
  width: 100vw;
}

.page .bgBox.wide .bgBoxInner {
  width: 100%;
  max-width: 1040px;
}

#Co .page section .bgBox.wide h2.width {
  margin: 0 auto 30px auto;
  width: 1040px;
}

#Co .page .bgBox .caseBox {
  padding: 30px 30px 10px 30px;
}

#Co .page .bgBox .caseBox:last-child {
  margin-bottom: 0;
}

#Co .page .sectionInner .menu {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

#Co .page .sectionInner .menu::after {
  content: "";
  display: block;
  width: 32%;
}

#Co .page .sectionInner .menu .menuInner {
  background: rgba(0, 165, 230, 1);
  text-decoration: none;
  width: 32%;
}

#Co .page .sectionInner .menu .menuInner:nth-child(n + 4) {
  margin-top: 30px;
}

#Co .page .sectionInner .menu .menuInner .menuInnerItem {
  padding: 1rem 2rem;
}

#Co .page .sectionInner .menu .menuInner .photo {
  margin: 0;
}

#Co .page .sectionInner .menu .menuInner .menuInnerItem h4 {
  border: none;
  color: #ffffff;
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.6;
  margin: 0;
  padding: 0 0 0 24px;
}

#Co .page .sectionInner .menu .menuInner .menuInnerItem h4::before {
  background-color: transparent;
  background-image: url(../images/menu_arrow._f.png);
  background-position: 0 0;
  background-repeat: no-repeat;
  background-size: 18px;
  content: "";
  display: inline-block;
  height: 2rem;
  margin-right: 8px;
  top: 0.35em;
  width: 2rem;
}

#Co .page .sectionInner .box {
  display: flex;
  flex-direction: row-reverse;
  flex-wrap: wrap;
  justify-content: space-between;
  margin-bottom: 50px;
}

#Co .page .sectionInner .box .boxInner {
  width: 57%;
}

#Co .page .sectionInner .box .boxInner:first-child {
  width: 38%;
}

#Co .page .sectionInner .boxblue {
  background: #00a5e6;
  margin-bottom: 8rem;
  padding: 20px;
}

#Co .page .sectionInner .boxblue .boxblueInner {
  background: #ffffff;
  padding: 20px;
}

#Co .page .sectionInner .boxblue .boxblueInner h4 {
  margin: 0 0 20px 0;
}

/*------------------------------------------------------------------------*\

 $page / contactArea

\*------------------------------------------------------------------------*/

#Co .page .contactArea {
  background: url(../images/bg_contact.jpg) no-repeat center center;
  background-size: cover;
  padding: 50px;
}

#Co .page .contactArea .contactAreaInner {
  background: rgba(255, 255, 255, 0.7);
  padding: 50px;
}

#Co .page .contactArea .contactAreaInner h2 {
  border: none;
  color: #1386bf;
  font-size: 3.4rem;
  line-height: 1;
  margin-bottom: 25px;
  padding: 0;
  text-align: center;
}

#Co .page .contactArea .contactAreaInner p {
  color: #1386bf;
  font-size: 1.4rem;
  font-weight: 700;
  line-height: 1;
  margin-bottom: 40px;
  padding: 0;
  text-align: center;
}

#Co .page .contactArea .contactAreaInner ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 0 auto;
  position: relative;
  width: 850px;
}

#Co .page .contactArea .contactAreaInner ul li {
  font-weight: 700;
  line-height: 1;
  margin: 0;
  position: relative;
  width: 48%;
}

#Co .page .contactArea .contactAreaInner ul li a {
  align-items: center;
  background: #ffffff;
  border: 2px solid #1386bf;
  border-radius: 600px;
  color: #1386bf;
  display: block;
  display: flex;
  font-size: 2.6rem;
  height: 70px;
  justify-content: center;
  margin-bottom: 0;
  position: relative;
  text-decoration: none;
  width: 100%;
}

#Co .page .contactArea .contactAreaInner ul li a:hover {
  background: #1386bf;
  color: #ffffff;
}

#Co .page .contactArea .contactAreaInner ul li a .ico {
  align-items: center;
  display: flex;
  justify-content: center;
}

#Co .page .contactArea .contactAreaInner ul li a,
#Co #contactPage .contactArea .contactAreaInner ul li a {
  font-family: "Work Sans", sans-serif !important;
  font-size: 1.8rem;
}

#Co .page .contactArea .contactAreaInner ul li:nth-child(2) a,
#Co #contactPage .contactArea .contactAreaInner ul li a {
  font-size: 2.6rem;
}

#Co .page .contactArea .contactAreaInner ul li .ico:before {
  background-image: url(../images/ico_mail.png);
  height: 16px;
  width: 20px;
  margin-right: 8px;
  vertical-align: middle;
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  display: inline-block;
}

#Co .page .contactArea .contactAreaInner ul li a:hover .ico:before {
  background-image: url(../images/ico_mail_w.png);
  height: 16px;
  width: 20px;
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  display: inline-block;
  margin-right: 8px;
  vertical-align: middle;
}

#Co .page .contactArea .contactAreaInner ul li:nth-child(2) .ico:before,
#Co #contactPage .contactArea .contactAreaInner ul li .ico:before {
  background-image: url(../images/ico_tel.png);
  height: 21px;
  width: 17px;
}

#Co .page .contactArea .contactAreaInner ul li:nth-child(2) a:hover .ico:before,
#Co #contactPage .contactArea .contactAreaInner ul li a:hover .ico:before {
  background-image: url(../images/ico_tel_w.png);
  height: 21px;
  width: 17px;
}

/*========================================================================*\

$solutionPage

\*========================================================================*/

#Co #solutionPage .solutionArea {
  margin-bottom: 120px;
}

#Co #solutionPage .solutionArea:last-child {
  margin-bottom: 0;
}

#Co #solutionPage .solutionArea .solutionAreaItem {
  margin-bottom: 50px;
  position: relative;
}

#Co #solutionPage .solutionArea .solutionAreaImg {
  text-align: right;
}

#Co #solutionPage .solutionArea.secondBox .solutionAreaImg {
  text-align: left;
}

#Co #solutionPage .solutionAreaImg img {
  margin-right: calc(50% - 50vw);
  position: relative;
  width: 85%;
}

#Co #solutionPage .solutionArea.secondBox .solutionAreaImg img {
  margin-left: calc(50% - 50vw);
  margin-right: 0;
}

#Co #solutionPage .solutionArea .solutionAreaInner {
  background: rgba(255, 255, 255, 0.8);
  left: 0;
  margin-top: 6%;
  padding: 50px;
  position: absolute;
  top: 0;
  width: 66.3333333%;
}

#Co #solutionPage .solutionArea.secondBox .solutionAreaInner {
  left: auto;
  right: 0;
}

#Co #solutionPage .solutionArea .solutionAreaInner h3::before {
  background-image: url(../solution/img/ico_parking.png);
  background-size: contain;
  content: "";
  display: inline-block;
  height: 62px;
  margin-right: 12px;
  vertical-align: middle;
  width: 62px;
}

#Co #solutionPage .solutionArea.secondBox .solutionAreaInner h3::before {
  background-image: url(../solution/img/ico_carshare.png);
  height: 45px;
  width: 62px;
}

#Co #solutionPage .solutionArea.thaadBox .solutionAreaInner h3::before {
  background-image: url(../solution/img/ico_carshare.png);
  height: 45px;
  width: 62px;
}

#Co #solutionPage .solutionArea .bnr {
  margin-bottom: 50px;
}

/*========================================================================*\

$specialPage / monthlySection

\*========================================================================*/

#Co .page .sectionInner .boxblue .box02Inner h4 {
  font-size: 1.8rem;
  margin-bottom: 0.5rem;
}

#Co .page .sectionInner .methodBox {
  margin-bottom: 5rem;
}

#Co .page .sectionInner .methodBox .box02Inner {
  background: #00a5e6;
  padding: 20px;
}

#Co .page .sectionInner .methodBox .box02Inner:nth-child(n + 3) {
  margin-top: 3rem !important;
}

#Co .page .sectionInner .methodBox .box02Inner h4 {
  border: none;
  color: #ffffff;
  font-size: 2.2rem;
  margin: 0 0 2rem 0;
  padding: 0;
  text-align: center;
}

#Co .page .sectionInner .methodBox .box02Inner h4::before {
  content: none;
}

#Co .page .sectionInner .methodBox .box02Inner .itemBox {
  background: #ffffff;
  padding: 20px;
}

#Co .page .sectionInner .methodBox .box02Inner .itemBox .detailBox {
  background: rgba(0, 165, 230, 0.05);
  padding: 20px;
}

#Co .page .sectionInner .methodBox .box02Inner .itemBox h5 {
  color: #00a5e6;
  font-size: 1.8rem;
}

#Co .page .sectionInner .methodBox .box02Inner .itemBox .point {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin-bottom: 0;
}

#Co .page .sectionInner .methodBox .box02Inner .itemBox .point li {
  font-size: 1.4rem;
  margin-bottom: 0;
}

#Co
  .page
  .sectionInner
  .methodBox
  .box02Inner
  .itemBox
  .point
  li:not(:last-child) {
  margin-bottom: 0;
}

#Co
  .page
  .sectionInner
  .methodBox
  .box02Inner
  .itemBox
  .point
  li:nth-child(n + 3) {
  margin-top: 0rem !important;
}

#Co .page .sectionInner.katuyouBox .box02 {
  background: rgba(0, 113, 187, 0.05);
  padding: 30px;
}

#Co .page .sectionInner.katuyouBox .box02 h4 {
  border: none;
  color: #00a5e6;
  font-size: 2.2rem;
  font-weight: 700;
  line-height: 1.6;
  margin: 0;
  padding-left: 0;
}

#Co .page .sectionInner.katuyouBox .box02 h4::before {
  content: none;
}

#Co .page .sectionInner.katuyouBox .box02Inner {
  flex: 0 0 calc(100% - 350px);
}

#Co .page .sectionInner.katuyouBox .box02Inner:first-child {
  flex: 0 0 300px;
}

#Co .aiPage .sectionInner .flowBox .flowBoxInner {
  padding: 0 0 30px 0;
}

#Co .aiPage .sectionInner .flowBox .flowBoxInner {
  padding: 0 0 30px 0;
}

#Co .aiPage .sectionInner .flowBox .flowBoxInner:last-child {
  padding: 0;
}

#Co .aiPage .sectionInner .flowBox .flowBoxInner h4 {
  margin: 0;
  padding: 0 0 5px 24px;
}

/*========================================================================*\

$page / #solutionPage.specialPage

\*========================================================================*/

#Co #solutionPage.specialPage .mainTitle {
  border: none;
  font-size: 4rem;
  line-height: 0.8;
  margin: 0 0 50px 0;
  padding: 0;
  text-align: center;
}

#Co #solutionPage.specialPage .featureBox,
#Co #solutionPage.specialPage .circleBox,
#Co #companyPage .basisBox {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 0 0 50px 0;
}

#Co #solutionPage.specialPage .featureBox .featureBoxInner,
#Co #solutionPage.specialPage .circleBox .circleBoxInner,
#Co #companyPage .basisBox .basisBoxInner {
  text-align: center;
  width: 31.5%;
}

#Co #solutionPage.specialPage .featureBox .featureBoxInner .featureBoxItem,
#Co #solutionPage.specialPage .circleBox .circleBoxInner .circleItem {
  align-items: center;
  background: rgba(237, 161, 0, 0.1);
  border-radius: 50%;
  display: flex;
  height: 327.59px;
  justify-content: center;
  width: 327.59px;
}

#Co #solutionPage.specialPage .featureBox .featureBoxInner h3 {
  background: #ec8f34;
  border: none;
  border-radius: 60rem;
  color: #ffffff;
  font-size: 1.8rem;
  line-height: 1;
  margin: -60px 0 40px 0;
  padding: 10px 5px;
  text-align: center;
}

#Co #solutionPage.specialPage .featureBox .featureBoxInner h3::after {
  content: none;
}

#Co #solutionPage.specialPage .featureBox .featureBoxInner p {
  line-height: 1.8;
  padding: 0 1.5rem;
  text-align: left;
}

#Co #solutionPage.specialPage .specialBox .specialTitle {
  background: rgb(52, 80, 157);
  background: -moz-linear-gradient(
    0deg,
    rgba(52, 80, 157, 1) 0%,
    rgba(0, 165, 230, 1) 100%
  );
  background: -webkit-linear-gradient(
    0deg,
    rgba(52, 80, 157, 1) 0%,
    rgba(0, 165, 230, 1) 100%
  );
  background: linear-gradient(
    0deg,
    rgba(52, 80, 157, 1) 0%,
    rgba(0, 165, 230, 1) 100%
  );
  color: #ffffff;
  filter: progid:DXImageTransform.Microsoft.gradient(startColorstr="#34509d",endColorstr="#00a5e6",GradientType=1);
  line-height: 1;
  margin: 0 calc(50% - 50vw);
  padding: 20px 0;
  text-align: center;
  width: 100vw;
}

/*========================================================================*\

$specialPage  / coin_parking

\*========================================================================*/

#coin_parking #solutionPage.specialPage #coin_parkingSection .bgBox.wide {
  padding: 100px 0 40px 0;
}

#coin_parking
  #solutionPage.specialPage
  #coin_parkingSection
  .bgBox.wide
  .bgBoxInner {
  background: transparent;
}

#coin_parking
  #solutionPage.specialPage
  #coin_parkingSection
  .mainTitle::before {
  background-image: url(../solution/coin_parking/img/logo.png);
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  display: block;
  height: 53px;
  margin: 0 auto 20px auto;
  text-align: center;
  width: 300px;
}

#Co #solutionPage.specialPage #coin_parkingSection .specialBox .bgBoxInner {
  background: transparent;
  padding: 0;
}

#Co #solutionPage.specialPage #coin_parkingSection .slick-dotted.slick-slider {
  margin-bottom: 0;
}

#Co #solutionPage.specialPage .specialBox .specialItem {
  background: #ffffff;
  margin-bottom: 100px;
  padding: 30px 20px 30px 23rem;
  position: relative;
}

#Co #solutionPage.specialPage .specialBox .specialItem .anxiety,
#Co #solutionPage.specialPage .specialBoxInner .anxiety {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
}

#Co #solutionPage.specialPage .specialBox .specialItem .anxiety {
  margin-bottom: 0 !important;
}

#Co #solutionPage.specialPage .specialBoxInner .anxiety {
  margin-bottom: 3rem !important;
}

#Co #solutionPage.specialPage .specialBox .specialItem .anxiety li,
#Co #solutionPage.specialPage .specialBoxInner .anxiety li {
  background: #fff200;
  color: #0071bc;
  font-size: 2rem;
  font-weight: 700;
  line-height: 1;
  margin: 0 5px 10px 0;
  padding: 12px 8px;
}

#Co #solutionPage.specialPage .specialBoxInner .anxiety li {
  font-size: 1.8rem;
}

#Co #solutionPage.specialPage .specialBox .specialItem .catch {
  font-size: 2rem;
  line-height: 1.8;
  margin: 0;
}

#Co #solutionPage.specialPage .specialBox .specialItem .human_01 {
  bottom: -30px;
  left: 0;
  position: absolute;
}

#Co #solutionPage.specialPage .specialBox .btnArea {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

#Co #solutionPage.specialPage .specialBox .btnArea li {
  margin-bottom: 0 !important;
  position: relative;
  width: 48.5%;
}

#Co #solutionPage.specialPage .specialBox .human_02,
#Co #solutionPage.specialPage .specialBox .human_03 {
  bottom: -22px;
  left: 0;
  position: absolute;
}

#Co #solutionPage.specialPage .specialBox .btnArea li a {
  background: #ffffff;
  border: 3px solid #0068b2;
  border-bottom: 8px solid #005e9c;
  border-radius: 10px;
  color: #121212;
  display: block;
  font-size: 2.2rem;
  font-weight: 700;
  line-height: 1.4;
  padding: 2rem 2rem 2rem 16rem;
  text-decoration: none;
  width: 100%;
}

#Co #solutionPage.specialPage .specialBox .btnArea li:last-of-type a {
  padding: 2rem 2rem 2rem 14rem;
}

#Co #solutionPage.specialPage .specialBox .btnArea li a:hover {
  border-bottom: 3px solid #005e9c;
}

#Co #solutionPage.specialPage .specialBox .btnArea li a span {
  background: linear-gradient(transparent 60%, #ffff66 60%);
  color: #0063b1;
  font-size: 2.8rem;
}

#Co #solutionPage.specialPage .specialBox .specialBoxInner {
  margin-top: 80px;
}

#Co #solutionPage.specialPage .specialBox .sliderBox {
  border: 5px solid #005e9c;
  margin-bottom: 50px;
  padding: 20px;
  position: relative;
}

#Co #solutionPage.specialPage .specialBox .sliderBox h4 {
  border-image: linear-gradient(
      180deg,
      rgba(32, 80, 161, 1) 0%,
      rgba(0, 175, 83, 1) 100%
    )
    1/0 0 0 2px;
  border-image-slice: 1;
  border-left: solid;
  border-top: none;
  color: #121212;
  font-size: 2.2rem;
  font-weight: 700;
  line-height: 1;
  margin: 0 0 20px 0;
  padding: 10px 0 10px 15px;
}

#Co #solutionPage.specialPage .specialBox .sliderBox h4::before {
  content: none;
}

#Co #solutionPage.specialPage .specialBox .sliderBox ul {
  margin: 0 !important;
  position: static;
}

#Co #solutionPage .bgBox .caseBox {
  background: #ffffff;
}

#Co #solutionPage .future.caseBox .caseBoxInner ul {
  background: rgba(254, 221, 17, 0.05);
  margin: 0;
  padding: 20px;
}

#Co #solutionPage .future.caseBox .caseBoxInner ul li:last-child {
  margin: 0;
}

#Co #solutionPage .caseBox h6 {
  font-size: 1.8rem;
  font-weight: 700;
  margin-bottom: 20px;
  padding: 5px 0 5px 10px;
}

#Co #solutionPage .current.caseBox h6 {
  background: rgba(5, 164, 246, 0.1);
  color: #05a4f6;
}

#Co #solutionPage .future.caseBox h6 {
  background: rgba(212, 0, 4, 0.1);
  color: #d40004;
}

#Co #solutionPage .bgBox .caseBox.current {
  align-items: center;
  margin-bottom: 100px;
  padding: 30px 30px 10px 30px;
  position: relative;
}

#Co #solutionPage .bgBox .caseBox.current::after {
  background-image: url(../solution/coin_parking/img/arrow.png);
  background-size: contain;
  bottom: -80px;
  content: "";
  height: 56px;
  left: 50%;
  position: absolute;
  transform: translateX(-50%);
  vertical-align: middle;
  width: 150px;
}

#Co #solutionPage .caseBox ul {
  margin-bottom: 0;
}

#Co #solutionPage .caseBox li {
  border-bottom: 1px dotted rgba(0, 0, 0, 0.3);
  margin-bottom: 15px;
  padding: 0 0 10px 24px;
  padding-bottom: 10px;
  position: relative;
}

#Co #solutionPage .caseBox li:last-child {
  border: none;
  padding: 0 0 0 24px;
  padding-bottom: 0;
}

#Co #solutionPage .caseBox li::after {
  border-bottom: 2px solid #05a4f6;
  border-left: 2px solid #05a4f6;
  content: "";
  display: block;
  height: 5px;
  left: 0;
  position: absolute;
  top: 40%;
  transform: translateY(-50%);
  transform: rotate(-45deg);
  width: 10px;
}

#Co #solutionPage .future.caseBox li::after {
  border-bottom: 2px solid #d40004;
  border-left: 2px solid #d40004;
  content: "";
}

#Co #solutionPage .future.caseBox {
  padding-bottom: 25px;
}

#Co #solutionPage .future.caseBox h6 {
  margin-bottom: 5px;
}

#Co #solutionPage .caseBox p {
  font-size: 2.2rem;
  font-weight: 700;
  margin: 0;
}

#Co #solutionPage .current.caseBox .price {
  color: #05a4f6;
}

#Co #solutionPage .future.caseBox p .price {
  font-size: 2.8rem;
}

#Co #solutionPage.specialPage .circleBox .circleBoxInner .circleItem {
  background: transparent;
  border: 5px solid #005e9c;
  margin-bottom: 10px !important;
}

#Co #solutionPage.specialPage .circleBox .circleBoxInner p {
  font-size: 2.2rem;
  font-weight: 700;
  line-height: 1.8;
  margin-bottom: 0;
}

#Co #solutionPage .bgBox .nayami {
  border: none;
  font-size: 2.8rem;
  font-weight: 700;
  margin-bottom: 20px;
  padding: 0;
  text-align: center;
}

#Co #solutionPage .bgBox .nayami::after {
  background-image: url(../solution/coin_parking/img/ico_nayami.png);
  background-size: contain;
  content: "";
  display: inline-block;
  height: 25px;
  margin-left: 2px;
  position: relative;
  top: -25px;
  vertical-align: middle;
  width: 23px;
}

#Co #solutionPage .bgBox .nayami .pointTxt {
  background: transparent;
  color: #0063b1;
}

#Co #solutionPage .bgBox .nayamiBox {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

#Co #solutionPage .bgBox .nayamiBox .nayamiBoxInner {
  background: #ffffff;
  width: 48.5%;
}

#Co #solutionPage .bgBox .nayamiBox .nayamiBoxInner:nth-child(n + 3) {
  margin-top: 3rem;
}

#Co #solutionPage .bgBox .nayamiBox .nayamiBoxInner .photo {
  margin-bottom: 0;
}

#Co #solutionPage .bgBox .nayamiBox .nayamiBoxInner .detailBox {
  padding: 20px;
}

#Co #solutionPage .bgBox .nayamiBox .nayamiBoxInner .detailBox h6 {
  color: #0063b1;
  font-size: 2.2rem;
  font-weight: 700;
  margin-bottom: 0;
}

#Co #solutionPage .bgBox .nayamiBox .nayamiBoxInner .detailBox p {
  line-height: 1.8;
  margin: 0;
}

#Co #solutionPage .voiceBox {
  margin: 0;
}

#Co #solutionPage .voiceBoxdetail {
  border: 1px dashed #8ab83f;
  margin: 0;
  padding: 20px;
}

#Co #solutionPage .voiceBoxdetail p {
  color: #8ab83f;
  margin-bottom: 0;
}

#Co #solutionPage .voiceBoxdetail .name {
  color: #0e050b;
  font-size: 1.2rem;
  font-weight: 700;
}

#Co #solutionPage p.title {
  align-items: center;
  display: flex;
  font-size: 4rem;
  font-weight: 700;
  justify-content: center;
  text-align: center;
}

#Co #solutionPage p.title::before,
#Co #solutionPage p.title::after {
  background-color: #0e050b;
  content: "";
  height: 45px;
  width: 2px;
}

#Co #solutionPage p.title::before {
  margin-right: 30px;
  transform: rotate(-35deg);
}

#Co #solutionPage p.title::after {
  margin-left: 30px;
  transform: rotate(35deg);
}

#Co #solutionPage h3.ico {
  padding-left: 100px;
}

#Co #solutionPage h3.ico::before {
  background: url(../images/ico_lep.png);
  background-size: contain;
  content: "";
  display: inline-block;
  height: 76px;
  left: 0;
  margin-right: 8px;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  vertical-align: middle;
  width: 88px;
}

#Co #solutionPage .supportArea {
  margin-bottom: 50px;
}

#Co #solutionPage .supportArea h5 {
  border: none;
  color: #e64c64;
  font-weight: 700;
  margin-bottom: 30px;
  padding: 0;
  position: relative;
}

#Co #solutionPage .supportArea h5 span {
  background: #e64c64;
  border-radius: 600px;
  color: #ffffff;
  display: inline-block;
  font-size: 1.8rem;
  margin-right: 10px;
  padding: 0 30px;
}

#Co #solutionPage .supportArea h5::after {
  background-color: #e64c64;
  bottom: 0;
  content: "";
  display: inline-block;
  height: 3px;
  position: absolute;
  right: 0;
  width: 98%;
}

#Co #solutionPage .supportArea h6 {
  border-bottom: 1px solid #e64c64;
  font-size: 1.8rem;
  font-weight: 700;
  margin-bottom: 10px;
  padding-bottom: 5px;
  position: relative;
}

#Co #solutionPage .supportArea h6 .number {
  background: #e64c64;
  border-radius: 50%;
  color: #ffffff;
  display: inline-block;
  font-family: "Work Sans", sans-serif !important;
  height: 24px;
  line-height: 24px;
  margin-right: 5px;
  text-align: center;
  width: 24px;
}

#Co #solutionPage .supportArea.secondBox h5 {
  color: #ee7424;
}
#Co #solutionPage .supportArea.thaadBox h5 {
  color: #00b3b0;
}
#Co #solutionPage .supportArea.fourthBox h5 {
  color: #0095d6;
}
#Co #solutionPage .supportArea.fifthBox h5 {
  color: #009933;
}

#Co #solutionPage .supportArea.secondBox h5 span {
  background: #ee7424;
}
#Co #solutionPage .supportArea.thaadBox h5 span {
  background: #00b3b0;
}
#Co #solutionPage .supportArea.fourthBox h5 span {
  background: #0095d6;
}
#Co #solutionPage .supportArea.fifthBox h5 span {
  background: #009933;
}

#Co #solutionPage .supportArea.secondBox h5::after {
  background-color: #ee7424;
}
#Co #solutionPage .supportArea.thaadBox h5::after {
  background-color: #00b3b0;
}
#Co #solutionPage .supportArea.fourthBox h5::after {
  background-color: #0095d6;
}
#Co #solutionPage .supportArea.fifthBox h5::after {
  background-color: #009933;
}

#Co #solutionPage .supportArea.secondBox h6 {
  border-bottom: 1px solid #ee7424;
}
#Co #solutionPage .supportArea.thaadBox h6 {
  border-bottom: 1px solid #00b3b0;
}
#Co #solutionPage .supportArea.fourthBox h6 {
  border-bottom: 1px solid #0095d6;
}
#Co #solutionPage .supportArea.fifthBox h6 {
  border-bottom: 1px solid #009933;
}
#Co #solutionPage .supportArea.secondBox h6 .number {
  background: #ee7424;
}
#Co #solutionPage .supportArea.thaadBox h6 .number {
  background: #00b3b0;
}
#Co #solutionPage .supportArea.fourthBox h6 .number {
  background: #0095d6;
}
#Co #solutionPage .supportArea.fifthBox h6 .number {
  background: #009933;
}

#Co #solutionPage .supportArea {
  position: relative;
}

#Co #solutionPage .supportArea .supportBox {
  display: flex;
  flex-direction: row-reverse;
  justify-content: space-between;
  margin-bottom: 0;
  max-height: 150px;
  overflow: hidden;
  position: relative;
  transition: max-height 1s;
}

#Co #solutionPage .supportArea .supportBox .supportBoxInner {
  width: 70%;
}

#Co #solutionPage .supportArea .supportBox .supportBoxInner:first-child {
  width: 25%;
}

#Co #solutionPage .supportBox:has(:checked) {
  max-height: 100vh;
}

#Co #solutionPage .supportBox::after {
  background: linear-gradient(
    180deg,
    hsla(0, 0%, 100%, 0) 0,
    hsla(0, 0%, 100%, 0.9) 50%,
    hsla(0, 0%, 100%, 0.9) 0,
    #ffffff
  );
  bottom: 0;
  content: "";
  display: block;
  height: 60px;
  left: 0;
  position: absolute;
  width: 100%;
}

#Co #solutionPage .supportBox:has(:checked)::after {
  content: none;
}

#Co #solutionPage .supportBox label {
  align-items: center;
  bottom: 0;
  color: #4f96f6;
  display: flex;
  font-size: 1.6rem;
  gap: 0 4px;
  left: 50%;
  position: absolute;
  transform: translateX(-50%);
  z-index: 20;
}

#Co #solutionPage .supportBox label:hover {
  color: #c7511f;
  cursor: pointer;
  text-decoration: underline;
}

#Co #solutionPage .supportBox:has(:checked) label {
  display: none;
}

#Co #solutionPage .supportBox label::after {
  background-color: #b6bdc3;
  clip-path: polygon(0 0, 100% 0, 50% 100%);
  content: "";
  display: inline-block;
  height: 5px;
  width: 10px;
}

#Co #solutionPage .supportBox input {
  display: none;
}

#anchorBox ul.solution_menu li a {
  padding: 3rem 1rem;
}

#Co #solutionPage #anchorBox ul.solution_menu li a::before {
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  display: block;
  margin: 0 auto 10px auto;
  text-align: center;
}

#Co #solutionPage #anchorBox ul.solution_menu li:nth-child(1) a::before {
  background-image: url(../solution/img/ico_parking.png);
  height: 60px;
  width: 60px;
}

#Co #solutionPage #anchorBox ul.solution_menu li:nth-child(2) a::before {
  background-image: url(../solution/img/ico_carshare.png);
  height: 60px;
  width: 83px;
}

#Co #solutionPage #anchorBox ul.solution_menu li:nth-child(3) a::before {
  background-image: url(../solution/img/ico_solution.png);
  height: 60px;
  width: 86px;
}

#anchorBox ul.solution_menu li a:after {
  border-bottom: solid 2px #0061af;
  border-right: solid 2px #0061af;
  bottom: 10%;
  content: "";
  height: 8px;
  left: 50%;
  position: absolute;
  transform: translateX(-50%) rotate(45deg);
  transition-duration: 0.3s;
  width: 8px;
}

#anchorBox ul.solution_menu li a:hover:after,
#anchorBox ul.solution_menu li a.on:after {
  bottom: 5%;
  transition-duration: 0.3s;
}

@media screen and (max-width: 767px) {
  #anchorBox ul.solution_menu li a {
    font-size: 1.4rem;
    line-height: 1.4;
    padding: 2.5rem 1rem;
  }

  #Co #solutionPage #anchorBox ul.solution_menu li:nth-child(1) a::before {
    height: 40px;
    width: 40px;
  }

  #Co #solutionPage #anchorBox ul.solution_menu li:nth-child(2) a::before {
    height: 40px;
    width: 63px;
  }

  #Co #solutionPage #anchorBox ul.solution_menu li:nth-child(3) a::before {
    height: 40px;
    width: 66px;
  }
}

/*========================================================================*\

$specialPage smart_parking

\*========================================================================*/

#Co #sp_Section .bgBox {
  background: rgba(0, 153, 255, 0.05);
}

#Co #solutionPage.specialPage #sp_Section .mainTitle .orange {
  color: #ec8f34;
}

#Co #solutionPage.specialPage #sp_Section .mainTitle .big {
  font-size: 5rem;
}

#Co #solutionPage.specialPage #sp_Section .mainTitle::before {
  background-image: url(../solution/smart_parking/img/logo.png);
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  display: block;
  height: 61px;
  margin: 0 auto 10px auto;
  text-align: center;
  width: 500px;
}

#Co #solutionPage.specialPage #sp_Section .featureBox {
  margin: 0 0 10px 0;
}

#Co #solutionPage.specialPage #sp_Section .featureBox img {
  padding: 0 0 30px 0;
}

#Co
  #solutionPage.specialPage
  #sp_Section
  .featureBox
  .featureBoxInner
  .featureBoxItem {
  background: rgba(0, 153, 255, 0.1);
}

#Co #solutionPage.specialPage #sp_Section .featureBox .featureBoxInner h3 {
  background: #0099ff;
}

#Co #solutionPage.specialPage #sp_Section .caseBox,
#Co #solutionPage.specialPage #sp_Section .caseBox_02 {
  background: #ffffff;
  margin: 0 auto 30px auto;
  padding: 30px;
  width: 1040px;
}

#Co #solutionPage.specialPage #sp_Section .caseBox_02 {
  margin: 0 auto;
}

#Co #solutionPage.specialPage #sp_Section .caseBox li:last-child {
  border-bottom: 1px dotted rgba(0, 0, 0, 0.3);
  margin-bottom: 15px;
  padding: 0 0 10px 24px;
  padding-bottom: 10px;
  position: relative;
}

#Co #solutionPage.specialPage #sp_Section .caseBox p {
  font-size: 1.4rem;
  font-weight: 500;
}

#Co #solutionPage.specialPage #sp_Section .caseBox_02 .detailBox {
  display: flex;
  justify-content: space-between;
}

#Co
  #solutionPage.specialPage
  #sp_Section
  .caseBox_02
  .detailBox
  .detailBoxInner {
  position: relative;
  width: 25%;
}

#Co
  #solutionPage.specialPage
  #sp_Section
  .caseBox_02
  .detailBox
  .detailBoxInner
  figure {
  margin: 0; /* マージンをリセット */
  display: flex; /* figureをflexコンテナにする */
  align-items: flex-end; /* 下揃え */
}

#Co
  #solutionPage.specialPage
  #sp_Section
  .caseBox_02
  .detailBox
  .detailBoxInner
  figure
  img {
  max-width: 100%; /* 幅を100%にして、レスポンシブに対応 */
  height: auto; /* 高さは自動調整 */
  display: block; /* 画像をブロック要素にする */
}

#Co
  #solutionPage.specialPage
  #sp_Section
  .caseBox_02
  .detailBox
  .detailBoxInner::after {
  background-image: url(../solution/smart_parking/img/arrow.png);
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  height: 45px;
  position: absolute;
  right: -100px;
  top: -0;
  vertical-align: middle;
  width: 53px;
}

#Co
  #solutionPage.specialPage
  #sp_Section
  .caseBox_02
  .detailBox
  .detailBoxInner:last-child:after {
  content: none;
}

#Co #solutionPage.specialPage #sp_Section .caseBox_02 h5 {
  background: rgb(97, 203, 244);
  background: linear-gradient(
    90deg,
    rgba(97, 203, 244, 1) 0%,
    rgba(0, 112, 192, 1) 100%
  );
  border-radius: 6px;
  color: #ffffff;
  font-size: 2.2rem;
  margin-bottom: 10px;
  text-align: center;
}

#Co #solutionPage.specialPage #sp_Section .caseBox_02 p {
  font-size: 1.4rem;
  line-height: 1.6;
}

#Co #solutionPage.specialPage .featuresBox {
  display: flex;
  margin-bottom: 50px;
}

#Co #solutionPage.specialPage .featuresBox .featuresInner:last-child {
  margin-left: 30px;
}

#Co #solutionPage.specialPage .featuresBox .featuresInner h4 {
  border-bottom: none;
  font-size: 2.2rem;
  margin: 0 0 10px 0;
  padding: 0 0 0 20px;
}

#Co #solutionPage.specialPage .settlementBox {
  margin-bottom: 50px;
}

#Co #solutionPage.specialPage .settlementBoxInner {
  background: #ffffff;
  padding: 40px;
  border: 50px solid #28a5dd;
}

#Co #solutionPage.specialPage .meritBox {
  display: flex;
  flex-direction: row-reverse;
  justify-content: space-between;
}

#Co #solutionPage.specialPage .meritBox .meritBoxInner {
  width: 65%;
}

#Co #solutionPage.specialPage .meritBox .meritBoxInner h5 {
  color: #0070ba;
  font-size: 2.2rem;
  font-weight: 700;
}

#Co #solutionPage.specialPage .meritBox .meritBoxInner h5 .merit_t {
  background: #0070ba;
  color: #ffffff;
  font-size: 1.8rem;
  margin-right: 8px;
  padding: 3px 5px;
}

#Co #solutionPage.specialPage .meritBox .meritBoxInner:first-child {
  width: 30%;
}

/*========================================================================*\

$specialPage udxPage

\*========================================================================*/

#Co #solutionPage.specialPage .campaign li {
  border-bottom: dotted 1px rgba(0, 0, 0, 0.2);
  margin-bottom: 2rem;
  padding-bottom: 2rem;
}

#Co #solutionPage.specialPage .campaign li:last-child {
  border-bottom: none;
  margin-bottom: 0;
  padding-bottom: 0;
}

#Co #solutionPage.specialPage .accessBox .box02Inner {
  width: 34%;
}

#Co #solutionPage.specialPage .accessBox .box02Inner:last-child {
  width: 63%;
}

#Co #solutionPage.specialPage .accessBox .box02Inner th,
#Co #solutionPage.specialPage .accessBox .box02Inner td {
  font-size: 1.4rem;
  padding: 1.5rem 0;
}

#Co #solutionPage.specialPage .accessBox .box02Inner th {
  width: 35%;
}

#Co #solutionPage.specialPage td .point {
  margin-bottom: 1rem !important;
}

#Co #solutionPage.specialPage td .line {
  color: #0070ba;
  display: block;
  padding-bottom: 0.5rem;
}

#Co #solutionPage.specialPage td .ss {
  display: block;
  padding-left: 1.4em;
}

#Co #solutionPage.specialPage #udxSection h4 {
  border-bottom: 1px dotted #cccccc;
  font-size: 2.2rem;
  font-weight: 700;
  line-height: 1.6;
  margin: 50px 0 20px 0;
  padding: 0 0 10px 20px;
  position: relative;
}

#Co #solutionPage.specialPage #udxSection h4:before {
  background: #0070ba;
  border-radius: 50%;
  content: "";
  height: 5px;
  left: 0;
  position: absolute;
  top: 0.75em;
  width: 5px;
}

#Co #solutionPage.specialPage #udxSection .list {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

#Co #solutionPage.specialPage #udxSection .list li {
  background: #f6f6f6;
  padding: 1.5rem;
  width: 23.5%;
}

#Co #solutionPage.specialPage #udxSection .list li:nth-child(n + 5) {
  margin-top: 1.5rem;
}

#Co #solutionPage.specialPage #udxSection .itemBox {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

#Co #solutionPage.specialPage #udxSection .itemBox::after {
  content: "";
  display: block;
  width: 32%;
}

#Co #solutionPage.specialPage #udxSection .itemBox a {
  border: 10px solid rgba(0, 113, 187, 0.05);
  color: #0e050b;
  display: block;
  padding: 30px 20px;
  position: relative;
  text-decoration: none;
  width: 32%;
}

#Co #solutionPage.specialPage #udxSection .itemBox a::before {
  border-color: transparent transparent #0070ba transparent;
  border-style: solid;
  border-width: 0 0 10px 10px;
  bottom: 10px;
  content: "";
  height: 0;
  position: absolute;
  right: 10px;
  width: 0;
}

#Co #solutionPage.specialPage #udxSection .itemBox a.no::before {
  content: none;
}

#Co #solutionPage.specialPage #udxSection .itemBox a:hover {
  background: rgba(0, 113, 187, 0.05);
}

#Co #solutionPage.specialPage #udxSection .itemBox a:nth-child(n + 4) {
  margin-top: 20px;
}

#Co #solutionPage.specialPage #udxSection .itemBox .itemBoxInner h5 {
  border-bottom: 1px solid #0070ba;
  color: #0070ba;
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1;
  margin: 0 0 15px 0;
  padding: 0 0 15px 0;
}

#Co #solutionPage.specialPage #udxSection .itemBox .itemBoxInner p {
  line-height: 1.6;
  margin: 0;
}

#Co #solutionPage #udxSection .contactArea {
  margin-top: 50px;
}

#Co #solutionPage #udxSection .contactArea .contactAreaInner h2 {
  line-height: 1.6;
}

#Co #solutionPage #udxSection .faqBox {
  margin-bottom: 50px;
}

#Co #solutionPage #udxSection .faqBox .bgBox {
  background: #ffffff;
  margin-bottom: 0;
  margin-left: 2%;
  width: 98%;
}

/*========================================================================*\

$specialPage carshare

\*========================================================================*/

#carshare #lowermain h2 {
  line-height: 1.2;
}

#Co #solutionPage #carshareSection .campaignBox .campaignBoxInner {
  background: #ffffff;
  padding: 30px;
}

#Co
  #solutionPage
  #carshareSection
  .campaignBox
  .campaignBoxInner:nth-child(n + 2) {
  margin-top: 30px;
}

#Co #solutionPage #carshareSection .campaignBox .campaignBoxInner .detailBox {
  display: flex;
  flex-direction: row-reverse;
  justify-content: space-between;
}
#Co
  #solutionPage
  #carshareSection
  .campaignBox
  .campaignBoxInner
  .detailBoxInner {
  width: 65%;
}

#Co
  #solutionPage
  #carshareSection
  .campaignBox
  .campaignBoxInner
  .detailBoxInner:first-child {
  width: 30%;
}

#Co #solutionPage #carshareSection .campaignBox .campaignBoxInner h5 {
  border-bottom: 2px solid #eeeeee;
  margin-bottom: 1rem;
  padding-bottom: 0.8rem;
}

#Co #solutionPage #carshareSection .campaignBox .campaignBoxInner li {
  margin-bottom: 0 !important;
  width: 100%;
}

#Co #solutionPage.specialPage #carshareSection .specialBox .specialItem {
  margin-bottom: 0;
  padding: 20px;
}

#Co #solutionPage #carshareSection .downloadlist {
  align-items: center;
  display: flex;
  justify-content: center;
  margin: 0 auto;
  width: 60%;
}

#Co #solutionPage #carshareSection .downloadlist li {
  margin-right: 5%;
}

#Co #solutionPage #carshareSection .downloadlist li:last-child {
  margin-left: 5%;
  margin-right: 0;
}

#Co #solutionPage #carshareSection .commissionBox,
#Co #newsPage .commissionBox {
  align-items: center;
  display: flex;
  justify-content: space-between;
  margin-bottom: 5rem;
}

#Co #solutionPage #carshareSection .commissionBox .commissionBoxInner,
#Co #newsPage .commissionBox .commissionBoxInner {
  background: #00a5e6;
  padding: 2rem;
  width: 48.5%;
}

#Co #solutionPage #carshareSection .commissionBox .commissionBoxInner h4,
#Co #newsPage .commissionBox .commissionBoxInner h4 {
  border: none;
  color: #ffffff;
  font-size: 2.2rem;
  margin: 0 0 2rem 0;
  padding: 0;
  text-align: center;
}

#Co
  #solutionPage
  #carshareSection
  .commissionBox
  .commissionBoxInner
  h4::before,
#Co #newsPage .commissionBox .commissionBoxInner h4::before {
  content: none;
}

#Co #solutionPage #carshareSection .commissionBox .commissionBoxInner p,
#Co #newsPage .commissionBox .commissionBoxInner p {
  background: #ffffff;
  font-size: 6rem;
  font-weight: 700;
  line-height: 1;
  margin: 0;
  padding: 4rem 0;
  text-align: center;
}

#Co #solutionPage #carshareSection .tbl td {
  text-align: center;
}

#Co .page .tbl td .price {
  color: #0e050b;
}

#Co .page .tbl td .torikeshi {
  text-decoration: line-through;
}

#Co .page .tbl td .waribiki .price {
  color: #d80000;
}

#Co #solutionPage #carshareSection .point li:not(:last-child) {
  margin-bottom: 0 !important;
}

#Co #solutionPage #carshareSection .point li:not(:last-child) {
  margin-bottom: 0 !important;
}

#Co #solutionPage #carshareSection .stationBox {
  background: rgba(0, 113, 187, 0.05);
  padding: 20px;
}

#Co #solutionPage #carshareSection .stationBox .box02Inner {
  background: #ffffff;
  height: 330px;
  overflow-y: scroll;
  padding: 1rem 2rem 2rem 2rem;
  width: 35%;
}

#Co #solutionPage #carshareSection .stationBox .box02Inner li {
  width: 100%;
}
#Co #solutionPage #carshareSection .stationBox .box02Inner li a {
  border-bottom: 1.5px dotted #cccccc;
  display: block;
  font-size: 1.4rem;
  line-height: 1.4;
  padding: 1.5rem 0;
  width: 100%;
}

#Co #solutionPage #carshareSection .list {
  margin-bottom: 3rem;
}

#Co #solutionPage #carshareSection .list li:nth-child(n + 4) {
  margin-top: 1.5rem;
}

.new {
  background-color: #d80000;
  color: #ffffff;
  display: inline-block;
  font-size: 12px;
  line-height: 1em;
  margin: 0 5px;
  padding: 5px;
  vertical-align: 4%;
}

#Co #solutionPage #carshareSection .stationBox .box02Inner li:nth-child(n + 3) {
  margin-top: 0 !important;
}

#Co #solutionPage #carshareSection .stationBox .box02Inner li a {
  color: #0e050b;
  text-decoration: none;
}

#Co #solutionPage #carshareSection .stationBox .box02Inner li a:hover {
  color: #d80000;
}

#Co #solutionPage #carshareSection .stationBox .box02Inner:first-child {
  overflow-y: visible;
  padding: 0;
  width: 63%;
}

#Co #solutionPage #carshareSection .stationBox .box02Inner iframe {
  height: 330px;
  width: 100%;
}

#Co #solutionPage #carshareSection .stationBox .box02Inner li i {
  color: #d80000;
}

/* ============================================================

$specialPage parking_system

============================================================ */

#Co #solutionPage.specialPage .headingBox {
  align-items: center;
  display: flex;
  justify-content: center;
  margin: 0 0 2rem 0;
  text-align: center;
}

#Co #solutionPage.specialPage .headingBox .headingTitle {
  font-size: 2.4rem;
  font-weight: 700;
  margin: 0;
}

#Co #solutionPage.specialPage .headingBox .ss {
  display: block;
  font-size: 2rem;
  font-weight: 700;
  line-height: 1;
  margin: 0;
  text-align: center;
}

#Co #solutionPage.specialPage .headingBox::before,
#Co #solutionPage.specialPage .headingBox::after {
  background-color: #121212;
  content: "";
  height: 45px;
  width: 2px;
}

#Co #solutionPage.specialPage .headingBox::before {
  margin-right: 30px;
  transform: rotate(-35deg);
}

#Co #solutionPage.specialPage .headingBox::after {
  margin-left: 30px;
  transform: rotate(35deg);
}

#parking_system
  #Co
  #solutionPage.specialPage
  .featureBox
  .featureBoxInner
  .featureBoxItem {
  background: rgba(147, 189, 59, 0.1);
}

#parking_system #Co #solutionPage.specialPage .featureBox .featureBoxInner h3 {
  background: #93bd3b;
}

#parking_system #Co #solutionPage.specialPage .bgBox.wide .bgBoxInner {
  margin-bottom: 3rem;
}

#parking_system #Co #solutionPage.specialPage .bgBox.wide .box03 {
  margin: 0 auto 5rem auto;
  width: 1040px;
}

#parking_system #Co #solutionPage.specialPage .bgBox.wide .box03 .box03Inner {
  background: #ffffff;
}

#parking_system
  #Co
  #solutionPage.specialPage
  .bgBox.wide
  .box03
  .box03Inner
  .photo {
  margin: 0;
}

#parking_system
  #Co
  #solutionPage.specialPage
  .bgBox.wide
  .box03
  .box03Inner
  .detailBox {
  padding: 20px;
}

#parking_system
  #Co
  #solutionPage.specialPage
  .bgBox.wide
  .box03
  .box03Inner
  h4 {
  margin: 0;
}

#parking_system
  #Co
  #solutionPage.specialPage
  .bgBox.wide
  .box03
  .box03Inner
  .detailBox
  ul {
  margin: 0;
}

#parking_system
  #Co
  #solutionPage.specialPage
  .bgBox.wide
  .box03
  .box03Inner
  .detailBox
  li {
  font-size: 1.4rem;
  width: 100%;
}

#parking_system #Co #solutionPage.specialPage .bgBox.wide .aCenter {
  font-size: 3rem;
  margin: 0;
}

#parking_system #Co #solutionPage.specialPage .accordionBox,
#Co .constructionPage .accordionBox {
  background: rgba(0, 113, 187, 0.05);
  margin-bottom: 5rem;
  padding: 50px;
}

#parking_system #Co #solutionPage.specialPage .accordionBox .box02,
#Co .constructionPage .accordionBox .accordionBoxInner {
  background: #ffffff;
  padding: 50px;
}

#parking_system
  #Co
  #solutionPage.specialPage
  .accordionBox
  .box02Inner:first-child {
  width: 30%;
}

#parking_system #Co #solutionPage.specialPage .accordionBox .box02Inner {
  width: 65%;
}

#parking_system #Co #solutionPage.specialPage .accordionBox .accordionBoxInner {
  display: none;
  margin: 5rem auto 0 auto;
}

#parking_system
  #Co
  #solutionPage.specialPage
  .accordionBox
  .accordionBoxInner
  h4:first-child {
  margin: 0 auto 2rem 0;
}

#parking_system
  #Co
  #solutionPage.specialPage
  .accordionBox
  .accordionBoxInner
  .accordionBoxItem {
  background: #ffffff;
  margin: 0 auto 3rem 0;
  padding: 50px;
}

#parking_system
  #Co
  #solutionPage.specialPage
  .accordionBox
  .accordionBoxInner
  .accordionBoxItem:last-child {
  margin: 0;
}

#parking_system
  #Co
  #solutionPage.specialPage
  .accordionBox
  .accordionBoxInner
  .accordionBoxItem
  .box02 {
  padding: 0;
}

#parking_system
  #Co
  #solutionPage.specialPage
  .accordionBox
  .accordionBoxInner
  .accordionBoxItem
  .box02.detailBox {
  background: transparent;
  background: rgba(254, 221, 17, 0.1);
  margin: 0;
  padding: 20px;
}

#parking_system
  #Co
  #solutionPage.specialPage
  .accordionBox
  .accordionBoxInner
  .accordionBoxItem
  .box02
  figure {
  margin-bottom: 0;
}

#parking_system
  #Co
  #solutionPage.specialPage
  .accordionBox
  .accordionBoxInner
  .accordionBoxItem
  h5 {
  border: none;
  margin-bottom: 0.5rem;
  padding: 0;
}

#parking_system
  #Co
  #solutionPage.specialPage
  .accordionBox
  .accordionBoxInner
  .accordionBoxItem
  li {
  font-size: 1.4rem;
  margin-bottom: 1rem;
  width: 100%;
}

#parking_system
  #Co
  #solutionPage.specialPage
  .accordionBox
  .accordionBoxInner
  .accordionBoxItem
  .box02
  li:last-child {
  margin-bottom: 0;
}

#parking_system
  #Co
  #solutionPage.specialPage
  .accordionBox
  .accordionBoxInner
  .accordionBoxItem
  .box04
  .point,
#parking_system
  #Co
  #solutionPage.specialPage
  .accordionBox
  .accordionBoxInner
  .accordionBoxItem
  .box04
  .point
  li {
  margin-bottom: 0;
}

#parking_system
  #Co
  #solutionPage.specialPage
  .accordionBox
  .accordionBoxInner
  .accordionBoxItem
  .box04
  figure {
  margin-bottom: 0.5rem;
}

#parking_system #Co #solutionPage.specialPage .otherItem {
  background: rgba(0, 113, 187, 0.05);
  padding: 50px;
}

#parking_system #Co #solutionPage.specialPage .otherItem .box03 {
  margin-bottom: 5rem;
}

#parking_system #Co #solutionPage.specialPage .otherItem .box03Inner {
  background: #ffffff;
  padding: 3rem 3rem 2rem 3rem;
  text-decoration: none;
}

#parking_system #Co #solutionPage.specialPage .otherItem .box03Inner:hover {
  background: #28489c;
  padding: 3rem 3rem 2rem 3rem;
  text-decoration: none;
}

#parking_system #Co #solutionPage.specialPage .otherItem .box03Inner h4 {
  border-bottom: none;
  color: #0e050b;
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.6;
  margin: 2rem 0 0 0;
  padding: 0 0 0 2rem;
  position: relative;
}

#parking_system #Co #solutionPage.specialPage .otherItem .box03Inner:hover h4 {
  color: #ffffff;
}

#parking_system #Co #solutionPage.specialPage .otherItem .box03Inner h4:before {
  background: transparent;
  border: 4px solid #1386bf;
  border-radius: 50px;
  content: "";
  height: 14px;
  left: 0;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 14px;
}

#parking_system
  #Co
  #solutionPage.specialPage
  .otherItem
  .box03Inner:hover
  h4:before {
  border: 4px solid #ffffff;
}

#parking_system #Co #solutionPage.specialPage .otherBox {
  background: #ffffff;
  margin-bottom: 3rem;
  padding: 3rem 3rem 2rem 3rem;
  text-decoration: none;
}

#parking_system #Co #solutionPage.specialPage .otherBox:last-child {
  margin-bottom: 0;
}

#parking_system #Co #solutionPage.specialPage .otherBox h4 {
  margin: 0 0 20px 0;
}

#parking_system
  #Co
  #solutionPage.specialPage
  .otherBox
  .box02Inner:first-child {
  width: 30%;
}

#parking_system #Co #solutionPage.specialPage .otherBox .box02Inner {
  width: 65%;
}

#parking_system
  #Co
  #solutionPage.specialPage
  .otherBox
  .otherBoxInner
  .detailBox {
  margin: 0;
}

#parking_system #Co #solutionPage.specialPage .otherBox .otherBoxInner li {
  width: 100%;
}

#parking_system #Co #solutionPage.specialPage .otherBox .otherBoxInner ul {
  margin: 0;
}

@media (max-width: 767px) {
  .headingBox::before,
  .headingBox::after {
    height: 35px;
    margin-top: 0;
  }

  .headingBox::before {
    margin-right: 25px;
  }

  .headingBox::after {
    margin-left: 25px;
  }

  #Co #solutionPage.specialPage .headingBox .headingTitle {
    font-size: 2rem;
    margin: 0;
  }
}

/* ============================================================

$enterprise_carshareSection

============================================================ */

#Co #solutionPage #enterprise_carshareSection .bgBox .bgBoxInner:nth-child(2) {
  margin-top: 20px;
}

#Co #solutionPage #enterprise_carshareSection h2 {
  margin-bottom: 4rem;
}

#Co #solutionPage #enterprise_carshareSection .mainTitle::before {
  background-image: url(../solution/enterprise_carshare/img/logo_ep.png);
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  display: block;
  height: 51px;
  margin: 0 auto 15px auto;
  text-align: center;
  width: 500px;
}

#Co #solutionPage #enterprise_carshareSection .mainTitle#a02::before {
  background-image: url(../solution/enterprise_carshare/img/logo_pf.png);
  height: 57px;
  width: 500px;
}

#Co #solutionPage #enterprise_carshareSection h2#a02 {
  margin-top: 10rem;
}

/* ============================================================

$uspaceSection

============================================================ */

#Co #solutionPage #uspaceSection .itemBox .itemBoxInner p {
  margin: 0;
}

#Co #solutionPage #uspaceSection .bgBox .bgBoxInner {
  margin: 0 0 30px 0;
}

#Co #solutionPage #uspaceSection .bgBox .bgBoxInner:last-child {
  margin: 0;
}

#Co #solutionPage #uspaceSection .arrowBox {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  margin: 0;
}

#Co #solutionPage #uspaceSection .arrowBox li {
  font-size: 1.4rem;
  line-height: 1.4;
  margin-right: 7%;
  position: relative;
  width: 19%;
}

#Co #solutionPage #uspaceSection .arrowBox li:last-child {
  margin-right: 0;
}

#Co #solutionPage #uspaceSection .arrowBox li span {
  display: block;
}

#Co #solutionPage #uspaceSection .arrowBox li span::before {
  border-color: transparent transparent transparent #df3138;
  border-style: solid;
  border-width: 4.5px 0 4.5px 8px;
  content: "";
  display: inline-block;
  height: 0;
  margin-right: 8px;
  width: 0;
}

#Co #solutionPage #uspaceSection .arrowBox li img {
  border: 1px solid #e0e6ea;
  margin-bottom: 5px;
}

#Co #solutionPage #uspaceSection .arrowBox li::after {
  background-image: url(../solution/smart_parking/img/arrow.png);
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  height: 45px;
  position: absolute;
  right: -72px;
  top: 50%;
  transform: translateY(-50%);
  vertical-align: middle;
  width: 53px;
}

#Co #solutionPage #uspaceSection .arrowBox li:last-child::after {
  content: none;
}

#Co #solutionPage.autonomousPage #networkSection .sectionInner {
  padding-bottom: 0;
}

#Co #solutionPage.autonomousPage #networkSection .bgBox.wide .sectionInner {
  padding-bottom: 8rem;
}

#Co #solutionPage.autonomousPage .box05 {
  margin-bottom: 8rem;
}

#Co #solutionPage.autonomousPage .box05 li {
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  background: rgb(240, 249, 255);
  background: -moz-linear-gradient(
    0deg,
    rgba(240, 249, 255, 1) 0%,
    rgba(255, 255, 255, 1) 100%
  );
  background: linear-gradient(
    0deg,
    rgba(240, 249, 255, 1) 0%,
    rgba(255, 255, 255, 1) 100%
  );
  border: 1px solid #0061af;
  border-radius: 6px;
  color: #0061af;
  display: flex;
  filter: progid:DXImageTransform.Microsoft.gradient(startColorstr="#f0f9ff",endColorstr="#ffffff",GradientType=1);
  flex-direction: column;
  font-size: 1.5rem;
  line-height: 1.4;
  font-weight: 700;
  justify-content: center;
  padding: 1.5rem 1rem;
  position: relative;
  text-align: center;
  text-decoration: none;
  transition-duration: 0.3s;
  width: 19%;
}

#Co #solutionPage.autonomousPage .bgBox.wide {
  padding: 0;
}

#Co #solutionPage.autonomousPage .bgBox.wide .caseBox {
  margin-bottom: 5rem;
  padding: 5rem;
}

#Co #solutionPage.autonomousPage .bgBox.wide .caseBox p {
  font-size: 1.6rem;
  line-height: 1.6;
  font-weight: 400;
  margin: 0px 0px 30px 0px;
}

/* ============================================================

$okuaizu

============================================================ */

#okuaizu #header {
  padding: 20px 0 15px 0;
  padding: 2rem 3% 1.5rem 0;
}

#okuaizu .navi {
  display: block;
  margin: 2rem auto 0 auto;
  width: 100%;
}

#okuaizu header #headerInner {
  display: flex;
  justify-content: space-between;
}

#okuaizu header #headerInner #headerL {
  padding: 0 0 0 3%;
}

#okuaizu #lowermain.specialMain .mainItem {
  position: absolute;
  top: 55%;
  left: 50%;
  transform: translateY(-50%) translateX(-50%);
  margin: auto;
}

#okuaizu #lowermain {
  margin-bottom: 0;
}

#okuaizu #Co {
  background: url(../solution/carshare/okuaizu/img/bg_co.jpg);
}

#okuaizu #pan {
  background: #eae0ce;
  padding-bottom: 7px;
}

#okuaizu .okuaizubox {
  background: #ffffff;
  padding: 50px;
  border-radius: 10px;
  margin-bottom: 5rem;
}

#okuaizu #Co #solutionPage .okuaizubox p:last-child {
  margin-bottom: 0;
}

#okuaizu #Co #solutionPage .colorBox {
  background: #f8f6f2;
  padding: 5rem;
}

#okuaizu #Co #solutionPage h2 {
  border: none;
  font-size: 2.8rem;
}

#okuaizu #Co #solutionPage h3 img {
  position: absolute;
  right: 0;
  top: -20px;
}

#okuaizu #Co #solutionPage h3::after {
  background-color: #96641a;
}

#okuaizu #Co #solutionPage .colorBox h4 {
  margin-top: 0;
}

#okuaizu #Co #solutionPage h4:before {
  background: #96641a;
}

#okuaizu #Co #solutionPage .flowBox h4 {
  color: #96641a;
}

#okuaizu #Co .point li::before {
  border-color: transparent transparent transparent #96641a;
}

#okuaizu #Co #solutionPage .flowBox .stepnumber {
  background: #96641a;
}

#okuaizu #Co table.tbl th {
  background: #96641a;
  color: #ffffff;
}

#okuaizu #Co table.tbl th.second {
  background: #f8f6f2;
  color: #0e050b;
}

#okuaizu #Co table.tbl td img {
  margin-bottom: 1rem;
}

#okuaizu .page .bgBox {
  background: #f8f6f2;
  margin-bottom: 50px;
  padding: 30px;
  width: 100%;
}

#okuaizu #Co #solutionPage .bgBox h4:before {
  background: transparent;
  border: 4px solid #96641a;
}

#okuaizu #Co #solutionPage .downloadlist {
  display: flex;
  justify-content: center;
  align-items: center;
  margin-bottom: 5rem;
}

#okuaizu #Co #solutionPage .downloadlist li {
  width: 30%;
}

#okuaizu #Co #solutionPage .downloadlist li:first-child {
  margin-right: 3%;
}

#okuaizu #Co .btn a {
  background: #ffffff;
  border: 1px solid #96641a;
  color: #96641a;
  font-size: 2.4rem;
  font-weight: 700;
  padding: 2rem 1rem;
}

#okuaizu #Co .btn a .ico:before {
  background-image: url(../solution/carshare/okuaizu/img/ico_tel.png);
  height: 21px;
  width: 17px;
  margin-right: 8px;
  vertical-align: middle;
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  display: inline-block;
}

#okuaizu #Co .btn a::after {
  content: none;
}

#okuaizu #side_tel {
  display: none !important;
}

#okuaizu .gallerySection {
  overflow: hidden;
}

#okuaizu .swiper {
  position: relative;
  margin-bottom: 10rem;
}

#okuaizu .gallerySection img {
  margin-bottom: 1rem;
}

#okuaizu .gallerySection .swiper-slide {
  margin-bottom: 2rem;
}

#okuaizu .gallerySection .swiper-slide p {
  line-height: 1.6;
  margin-bottom: 0 !important;
  font-size: 1.5rem;
}

#okuaizu .gallerySection .swiper-slide .time {
  font-weight: 900;
  font-size: 1.4rem;
}

#okuaizu .gallerySection .swiper-slide strong {
  color: #96641a;
}

#okuaizu .gallerySection .swiper-slide p.last {
  margin-top: 1rem;
  padding-top: 1rem;
  border-top: 1px dotted #cccccc;
}

#okuaizu .swiper-container-horizontal > .swiper-pagination-progressbar,
#okuaizu
  .swiper-container-vertical
  > .swiper-pagination-progressbar.swiper-pagination-progressbar-opposite {
  bottom: -20px !important;
  top: auto !important;
}

#okuaizu .swiper-button-prev,
#okuaizu .swiper-button-next {
  height: 40px;
  width: 40px;
  background: transparent;
  right: 0;
  top: -72px;
  margin: 0 !important;
  left: auto;
}

#okuaizu .swiper-button-prev {
  right: 50px;
}

/* 遏｢蜊ｰ繧呈ｶ医☆縲∫判蜒上↓螟画峩 */
#okuaizu .swiper-button-prev:after,
#okuaizu .swiper-button-next:after {
  content: "";
  background-repeat: no-repeat;
  background-size: contain;
  height: 40px;
  width: 40px;
  margin: auto;
  display: block;
}

/* 蜑阪↓謌ｻ繧狗判蜒上ヱ繧ｹ */
#okuaizu .swiper-button-prev:after {
  background-image: url(../solution/carshare/okuaizu/img/arrow_prev.png);
}

/* 谺｡縺ｫ騾ｲ繧逕ｻ蜒上ヱ繧ｹ */
#okuaizu .swiper-button-next:after {
  background-image: url(../solution/carshare/okuaizu/img/arrow_next.png);
}

.swiper-container-horizontal > .swiper-pagination-progressbar {
  width: 100%;
}

#okuaizu .swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
  background: #96641a;
}

@media screen and (max-width: 1770px) {
  #okuaizu header .hamburger {
    top: 25px;
  }

  #okuaizu header #headerInner #headerL {
    position: static;
    transform: translateY(0%);
    padding: 0 0 0 2%;
  }

  #okuaizu .navi {
    display: block;
    margin: 0.5rem auto 0 auto;
    width: 100%;
  }

  #okuaizu .navi .naviBox > li a.title {
    font-size: 1.2rem;
    line-height: 0.6;
    padding: 15px 12px;
    position: relative;
    border-right: 1px solid #cccccc;
  }

  #okuaizu .navi .naviBox > li:first-child a.title {
    border-left: 1px solid #cccccc;
  }
}

@media screen and (max-width: 1210px) {
  #okuaizu header .hamburger {
    top: 12px;
  }

  #okuaizu .swiper-button-prev,
  #okuaizu .swiper-button-next {
    height: 40px;
    width: 40px;
    top: -66px;
  }

  #okuaizu .swiper-button-prev {
    right: 50px;
  }

  #okuaizu .swiper-button-prev:after,
  #okuaizu .swiper-button-next:after {
    height: 40px;
    width: 40px;
  }
}

#okuaizu .enqueteBox .maskBox {
  position: relative;
}

#okuaizu .enqueteBox .maskBox {
  position: relative;
}

#okuaizu .enqueteBox .maskBox::before {
  content: "\30A2\30F3\30B1\30FC\30C8\306F\7D42\4E86\3057\307E\3057\305F\3002";
  background: rgba(150, 100, 26, 0.3);
  color: rgb(212, 0, 4);
  font-size: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  width: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 20;
  text-align: center;
  font-weight: bold;
}

/* ============================================================

$flowBox

============================================================ */

.flowBox {
  margin-bottom: 50px;
  padding: 0 0 0 90px;
  position: relative;
  z-index: 10;
}

.flowBox:after {
  background: #e0e6ea;
  content: "";
  display: block;
  height: 90%;
  left: 26px;
  position: absolute;
  top: 1px;
  width: 8px;
}

.flowBox94:after {
  height: 94%;
}

.flowBox .flowBoxInner {
  position: relative;
}

.flowBox .flowBoxInner:first-child {
  margin: 0;
}

.flowBox .flowBoxInner:last-child {
  border: 0;
  padding-bottom: 10px;
}

.page .flowBox h4 {
  border-bottom: none;
  color: #0070ba;
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.6em;
  margin: 30px 0 10px 0;
  padding: 5px 0 0 0;
  position: relative;
}

.page .flowBox h4::before {
  border: none;
  border-radius: 50px;
  content: "";
  height: 0;
  left: 0;
  position: absolute;
  top: 0;
  width: 0;
}

.page .flowBox p:last-child {
  margin: 0 !important;
}

.flowBox .stepnumber {
  background: #0070ba;
  border-radius: 30px;
  color: #ffffff;
  font-family: "Work Sans", sans-serif !important;
  font-size: 24px;
  font-weight: 700;
  left: -90px;
  line-height: 60px;
  position: absolute;
  text-align: center;
  top: 0;
  width: 60px;
  z-index: 11;
}

/*========================================================================*\

$newsPage privacyPage

\*========================================================================*/

#Co #newsPage #newsSection,
#Co #newsPage #newsSection .sectionInner {
  background: transparent !important;
  padding: 0;
}

#Co #newsPage #newsSection .sectionInner,
#Co #newsPage.commonPage #newsSection .sectionInner {
  padding: 8rem 0;
}

#Co #newsPage #newsSection .newsBoxInner dt {
  width: 21%;
}

#Co #newsPage #newsSection .newsBoxInner dd {
  width: 77%;
}

#Co #newsPage #newsSection .sectionInner h2,
#Co #newsPage.commonPage #newsSection .sectionInner h2 {
  line-height: 0.5;
}

#Co #newsPage #newsSection .sectionInner h3,
#Co #newsPage.commonPage #newsSection .sectionInner h3 {
  font-size: 2.6rem;
}

#Co #newsPage #newsSection .sectionInner h3 {
  border: none;
  font-size: 2.6rem;
  margin-bottom: 0;
}

#Co #newsPage #newsSection .sectionInner h3::after,
#Co #newsPage.commonPage #newsSection .sectionInner h3::after {
  content: none;
}

#Co #newsPage h5 {
  font-size: 1.8rem;
  line-height: 1;
  margin: 4rem 0 1em 0;
  padding: 0.5rem 0 0.5rem 1.8rem;
  position: relative;
}

#Co #newsPage h5::before {
  background-color: #0070ba;
  border-radius: 3px;
  content: "";
  display: block;
  height: 100%;
  left: 0;
  position: absolute;
  top: 0;
  width: 4px;
}

#Co #newsPage h6 {
  color: #0070ba;
  font-size: 1.6rem;
  line-height: 1;
  margin: 2rem 0 0.5em 0;
  padding: 0.5rem 0 0.5rem 2.4rem;
  position: relative;
}

#Co #newsPage h6::before {
  background-color: #0070ba;
  border-radius: 3px;
  content: "";
  display: block;
  height: 14px;
  left: 0;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 14px;
}

#Co #newsPage .bgBox .bgBoxInner h5 {
  margin: 2rem 0 0.5em 0;
}

#Co #newsPage .bgBox .bgBoxInner p:last-child {
  margin: 0;
}

#Co #newsPage .bgBox .bgBoxInner:nth-child(n + 2) {
  margin: 2em 0 0 0;
}

#Co #newsPage .bgBox .box03Inner.bgBoxInner:nth-child(n + 2) {
  margin: 0;
}

#Co #newsPage .bgBox.box02 .bgBoxInner,
#Co #newsPage .bgBox .box03 .bgBoxInner {
  margin: 0;
}

#Co #newsPage .bgBox .box03 {
  margin: 2rem 0 0 0;
}

#Co #newsPage .bgBox .box03 li {
  line-height: 1.6;
  margin: 0 0 1rem 0;
}

#Co #newsPage .bgBox.box02 .bgBoxInner:nth-child(n + 2) {
  margin: 0;
}

#Co #newsPage h3 .red {
  background: #d80000;
  color: #ffffff;
  font-size: 1.8rem;
  line-height: 1;
  margin-left: 10px;
  padding: 5px 10px;
}

#Co #newsPage .btn {
  margin: 5em auto 0 auto;
}

#Co #newsPage .carshare_box {
  background: url(../news/img/bg_carshare.png) no-repeat top center;
}

#Co #newsPage .carshare_box ul {
  margin: 0 auto;
  padding-top: 26%;
  width: 60%;
}

#Co #newsPage .flexBox {
  display: flex;
  flex-wrap: nowrap;
  margin-bottom: 10px;
  width: 100%;
}

#Co #newsPage .flexBox .flexBoxInner:last-child {
  margin-left: 20px;
}

#Co #newsPage .flexBox .flexBoxInner p {
  margin-bottom: 0;
}

#Co #newsPage .blueBox {
  background: #28a5dd;
  margin-bottom: 10px;
  padding: 2rem;
}

#Co #newsPage .blueBox figure {
  margin: 0 auto;
  text-align: center;
}

#Co .redTxt {
  color: #d80000 !important;
}

#Co #newsPage .bgBox figure {
  text-align: center;
}

/*------------------------------------------------------------------------*\

$privacyPage

\*------------------------------------------------------------------------*/
#Co .page#privacyPage .tbl th {
  width: auto;
}

/*------------------------------------------------------------------------*\

$companyPage

\*------------------------------------------------------------------------*/

#Co .page#companyPage .greetingBox {
  display: flex;
  flex-direction: row-reverse;
  justify-content: space-between;
}

#Co .page#companyPage .greetingBox .greetingBoxInner {
  width: 67%;
}

#Co .page#companyPage .greetingBox .greetingBoxInner:first-child {
  width: 30%;
}

#Co .commonPage .timeline {
  margin: 0 auto;
  padding: 0;
  width: 100%;
}

#Co .commonPage .timeline li {
  list-style: none;
  margin: 0;
  padding: 0 0 30px 0;
  position: relative;
}

#Co .commonPage .timeline dl {
  border-bottom: solid 1px rgba(0, 0, 0, 0.2);
  margin: 0 0 0 3em;
  padding-bottom: 30px;
}

#Co .commonPage .timeline dt {
  color: #0070ba;
  font-size: 1.8rem;
}

#Co .commonPage .timeline dd {
  display: flex;
  align-items: center;
}

#Co .commonPage .timeline dd strong {
  display: block;
  width: 4%;
  padding: 0;
}

#Co .commonPage .timeline dd span {
  display: block;
  margin-left: 10px;
}

#Co .commonPage .border-line {
  background: #e0e6ea;
  height: 0;
  left: 0.35em;
  position: absolute;
  top: 14px;
  width: 4px;
}

#Co .commonPage .timeline li::after {
  background: #0070ba;
  border-radius: 50%;
  content: "";
  height: 14px;
  left: 0;
  position: absolute;
  top: 14px;
  width: 14px;
}

/*------------------------------------------------------------------------*\

$companyPage

\*------------------------------------------------------------------------*/

#Co #companyPage .basisBox {
  margin: 0 0 30px 0;
}

#Co #companyPage .name {
  font-size: 1.4rem;
  line-height: 1.2;
}

#Co #companyPage .name strong {
  font-size: 2.2rem;
  line-height: 1.6;
}
#Co #companyPage .name img {
  margin: 0 0 10px 0;
}

#Co .commonPage .basisBox .basisBoxInner {
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  background: rgb(240, 249, 255);
  background: -moz-linear-gradient(
    0deg,
    rgba(240, 249, 255, 1) 0%,
    rgba(255, 255, 255, 1) 100%
  );
  background: -webkit-linear-gradient(
    0deg,
    rgba(240, 249, 255, 1) 0%,
    rgba(255, 255, 255, 1) 100%
  );
  background: linear-gradient(
    0deg,
    rgba(240, 249, 255, 1) 0%,
    rgba(255, 255, 255, 1) 100%
  );
  border: 1px solid #0061af;
  border-radius: 6px;
  color: #0061af;
  font-size: 1.6rem;
  font-weight: 700;
  justify-content: center;
  padding: 2.5rem 2rem;
  position: relative;
  text-align: center;
  text-decoration: none;
  transition-duration: 0.3s;
}

#Co .commonPage .basisBox .basisBoxInner h3 {
  border-bottom: none;
  margin-bottom: 5px;
  padding: 0;
}

#Co .commonPage .basisBox .basisBoxInner p {
  margin-bottom: 0;
  padding: 0;
}

#Co .commonPage .basisBox .basisBoxInner h3::after {
  content: none;
}

#Co #companyPage #csrSection .bgBoxInner {
  background: transparent;
  padding: 0;
}

#Co #companyPage #csrSection .crsBox {
  display: flex;
  justify-content: space-between;
}

#Co #companyPage #csrSection .crsBox .crsBoxInner {
  background: #ffffff;
  width: 32%;
}

#Co #companyPage #csrSection .crsBox .crsBoxInner:nth-child(n + 4) {
  margin-top: 2rem;
}

#Co #companyPage #csrSection .crsBox .crsBoxInner .detailBox {
  padding: 2rem;
}

#Co #companyPage #csrSection .crsBox .crsBoxInner .photo {
  margin-bottom: 0;
}

#Co #companyPage #csrSection .crsBox .crsBoxInner h4 {
  font-size: 1.8rem;
  font-weight: 700;
  margin-bottom: 0.7rem;
  padding-bottom: 0;
  padding-left: 24px;
  position: relative;
}

#Co #companyPage #csrSection .crsBox .crsBoxInner h4:before {
  border: 4px solid #1386bf;
  border-radius: 50px;
  content: "";
  height: 14px;
  left: 0;
  position: absolute;
  top: 55%;
  transform: translateY(-50%);
  width: 14px;
}

#Co #companyPage #csrSection .crsBox .crsBoxInner p {
  font-size: 1.4rem;
  margin-bottom: 2rem;
}

#Co #companyPage #csrSection .crsBox .crsBoxInner p:last-child {
  margin-bottom: 0;
}

#Co #companyPage #csrSection .crsBox .crsBoxInner .btn {
  width: 80%;
}

#Co #companyPage #csrSection .crsBox .crsBoxInner .btn a {
  font-size: 1.2rem;
  padding: 10px;
}

#Co #companyPage .list.box03 li:nth-child(n + 4) {
  margin-top: 20px !important;
}

#Co #companyPage .tblBorder dl {
  display: flex;
  flex-wrap: wrap;
}

#Co #companyPage .tblBorder dt {
  width: 16%;
}

#Co #companyPage .tblBorder dd {
  width: 84%;
}

#Co #companyPage .ryouritsuBox {
  margin: 60px 0;
  position: relative;
}

#Co #companyPage .ryouritsuBox .bnr_ryouritsu {
  position: absolute;
  right: 0;
  top: -15px;
}

#Co #companyPage .timelineArea dl {
  width: auto !important;
}

#Co #companyPage .border-line {
  left: 0.37em !important;
  width: 4px !important;
}

@media only screen and (max-width: 767px) {
  #Co #companyPage .list.box03 li:nth-child(n + 2) {
    margin-top: 10px !important;
  }

  #Co #companyPage .tblBorder dt {
    width: 24%;
  }

  #Co #companyPage .tblBorder dd {
    width: 76%;
  }

  #Co #companyPage .ryouritsuBox {
    margin: 40px 0;
    position: relative;
  }

  #Co #companyPage .ryouritsuBox .bnr_ryouritsu {
    position: absolute;
    right: 0;
    top: -20px;
  }
}

/*========================================================================*\

$englishPage

\*========================================================================*/

#Co #englishPage .englishBox {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

#Co #englishPage .bgBoxInner {
  margin-bottom: 30px;
}

#Co #englishPage .bgBoxInner:last-child {
  margin-bottom: 0;
}

#Co #englishPage .englishBox .englishBoxInner {
  position: relative;
  width: 28%;
}

#Co #englishPage .englishBox .englishBoxInner::after {
  background-image: url(../solution/smart_parking/img/arrow.png);
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  height: 45px;
  position: absolute;
  right: -75px;
  top: 24%;
  vertical-align: middle;
  width: 53px;
}

#Co #englishPage .englishBox .englishBoxInner:last-child:after {
  content: none;
}

#Co #englishPage .englishBox .englishBoxInner .photo {
  margin-bottom: 10px;
}

#Co #englishPage .englishBox .englishBoxInner .point {
  margin-bottom: 0;
}

#Co #englishPage .englishBox .englishBoxInner .point li,
#Co #englishPage .machineBox .point li {
  line-height: 1.4;
  margin-bottom: 5px;
}

#Co #englishPage .machineBox h4 {
  margin-bottom: 0;
}

/*========================================================================*\

$faqPage

\*========================================================================*/

#Co #faqPage h3:nth-child(n + 2) {
  margin-top: 80px;
}

#Co #faqPage h4 {
  border: none;
  margin: 50px 0 0 0;
  padding: 0 0 0 24px;
}

#Co #faqPage h4:before {
  background: transparent;
  border: 4px solid #0495c5;
  border-radius: 50px;
  content: "";
  height: 14px;
  left: 0;
  position: absolute;
  top: 55%;
  transform: translateY(-50%);
  width: 14px;
}

/*========================================================================*\

$contactPage

\*========================================================================*/

#Co #contactPage .personalBox h4 {
  margin: 0 0 20px 0;
}

#Co #contactPage .personalBox h5 {
  border: none;
  color: #1386bf;
  font-size: 1.6rem;
  margin: 0;
  padding: 0;
}

#Co #contactPage .personalBox p {
  margin: 0 0 20px 0;
}

#Co #contactPage .personalBox {
  background: #fafafa;
  margin-bottom: 50px;
  padding: 30px;
  width: 100%;
}

#Co #contactPage .personalBox .personalBoxInner {
  height: 350px;
  overflow-y: scroll;
  padding: 20px;
}

#Co #contactPage .personalBox .personalBoxInner .innerBox {
  background: #ffffff;
  margin-top: 20px;
  padding: 30px;
}

#Co #contactPage .btngroup li:last-child a {
  background: #cccccc !important;
  border: 1px solid #cccccc;
  color: #868285;
}

#Co #contactPage .btngroup li:last-child a:after {
  border-right: solid 2px #868285;
  border-top: solid 2px #868285;
}

#Co #contactPage .contactArea .contactAreaInner ul li .txt {
  color: #1386bf;
  display: block;
  margin-bottom: 5px;
  text-align: center;
}

#Co #contactPage .catalogBox .box03Inner .catalogBoxInner {
  background: rgba(0, 153, 255, 0.05);
  margin: 0 auto 10px auto;
  padding: 20px;
  text-align: center;
  width: 100%;
}

#Co #contactPage .catalogBox .box03Inner .photo {
  margin-bottom: 0;
  padding: 20px;
  text-align: center;
  width: 100%;
}

#Co #contactPage .catalogBox .box03Inner .photo img {
  width: 60%;
}

#Co #contactPage .catalogBox .box03Inner h4 {
  border: none;
  font-size: 1.8rem;
  margin-bottom: 10px;
  padding-bottom: 0;
}

#Co #contactPage .catalogBox .box03Inner h4:before {
  background: transparent;
  border: 4px solid #1386bf;
  border-radius: 50px;
  content: "";
  height: 14px;
  left: 0;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 14px;
}

#Co #contactPage .catalogBox .box03Inner .btn {
  margin: 0 auto;
  width: 80%;
}

#Co #contactPage .catalogBox .box03Inner .btn a {
  font-size: 1.2rem;
  padding: 0.5rem;
}

#Co #contactPage .catalogBox .box03Inner #actibookone.btn a {
  padding: 1.06rem 0.5rem;
}

/*========================================================================*\

$exercisePage

\*========================================================================*/

#Co #exercisePage .exerciseBox {
  display: flex;
  flex-direction: row-reverse;
  justify-content: space-between;
}

#Co #exercisePage .exerciseBox .exerciseBoxInner {
  width: 65%;
}

#Co #exercisePage .exerciseBox .exerciseBoxInner:first-child {
  width: 30%;
}

#Co #exercisePage .bgBox {
  background: #00a5e6;
}

#Co #exercisePage h4.subtitle,
#Co #solutionPage #networkSection h4.subtitle {
  border: none;
  color: #ffffff;
  font-size: 2.6rem;
  font-weight: 700;
  line-height: 1.6;
  margin: 0 0 20px 0;
  padding: 0;
  position: relative;
  text-align: center;
}

#Co #exercisePage h4.subtitle::before,
#Co #solutionPage #networkSection h4.subtitle::before {
  content: none;
}

#Co #exercisePage .bgBox .bgBoxInner {
  margin-bottom: 30px;
}

#Co #exercisePage .bgBox .bgBoxInner:last-child {
  font-weight: 700;
  margin-bottom: 0;
}

#Co #exercisePage .bgBox .bgBoxInner .normal {
  font-weight: 400;
}

#Co #exercisePage .bgBox.nayamiBox .bgBoxInner h4 {
  font-size: 2.1rem;
  margin-bottom: 10px;
  padding-bottom: 0;
}

#Co #exercisePage .bgBox.nayamiBox .nayamiBoxItem {
  display: flex;
  flex-direction: row-reverse;
  justify-content: space-between;
}

#Co #exercisePage .bgBox.nayamiBox .nayamiBoxInner {
  width: 54%;
}

#Co #exercisePage .bgBox.nayamiBox .nayamiBoxInner:first-child {
  width: 41%;
}

#Co #exercisePage .bgBox.nayamiBox .bgBoxInner .detailBox {
  background: rgba(0, 113, 187, 0.05);
  padding: 15px 15px 10px 15px;
}

#Co #exercisePage .bgBox.nayamiBox .bgBoxInner .detailBox h5 {
  border-bottom: none;
  border-left: 2px solid #1386bf;
  font-size: 1.6rem;
  margin-bottom: 5px;
  padding: 0 0 0 15px;
}

#Co #exercisePage .bgBox.nayamiBox .bgBoxInner .detailBox .point li {
  font-size: 1.4rem;
}

#Co #exercisePage .bgBox.nayamiBox .bgBoxInner p {
  margin-bottom: 15px;
}

#Co #exercisePage .bgBox.nayamiBox .bgBoxInner .resultBox {
  background: rgba(212, 119, 44, 0.05);
  padding: 20px 20px 15px 20px;
}

#Co #exercisePage .bgBox.nayamiBox .bgBoxInner .resultBox h5 {
  border-bottom: none;
  border-left: 2px solid #d4772c;
  color: #d4772c;
  font-size: 1.8rem;
  margin-bottom: 5px;
  padding-left: 15px;
}

#Co #exercisePage .bgBox.nayamiBox .bgBoxInner .resultBox li::before {
  border-color: transparent transparent transparent #d4772c;
}

#Co #exercisePage.smartPage .bgBoxInner h4 {
  margin-bottom: 2rem !important;
}

#Co #exercisePage .textBox {
  margin-bottom: 1rem !important;
}

#Co #exercisePage .textBox .box02Inner {
  margin-bottom: 1rem !important;
  background: rgba(0, 113, 187, 0.05);
  padding: 20px;
}

#Co #exercisePage .textBox .box02Inner:nth-child(n + 3) {
  margin-top: 1rem;
}

#Co #exercisePage .textBox h5 {
  border-image: linear-gradient(
      180deg,
      rgba(32, 80, 161, 1) 0%,
      rgba(0, 165, 230, 1) 100%
    )
    1 / 0 0 0 2px;
  border-image-slice: 1;
  border-left: solid;
  line-height: 1.4;
  margin: 0 0 10px 0 !important;
  font-size: 1.6rem;
  padding: 5px 0 5px 10px;
}

#Co #exercisePage .textBox p {
  line-height: 1.4;
  margin: 0 !important;
}

/*========================================================================*\

$recruitpage

\*========================================================================*/

#Co #recruitpage .box03 h4 {
  font-size: 1.8rem;
  margin-top: 0 !important;
}

#Co #recruitpage .recruitBoxInner {
  margin-bottom: 30px;
}

#Co #recruitpage .recruitBoxInner:last-child {
  margin-bottom: 0;
}

#Co #recruitpage .recruitBoxInner p {
  font-size: 1.4rem;
  line-height: 2;
  margin-bottom: 20px;
}

#Co #recruitpage .recruitBoxInner p:last-child {
  margin-bottom: 0;
}

#Co #recruitpage .recruitBoxInner .profBox {
  display: flex;
  margin-bottom: 2rem;
}

#Co #recruitpage .recruitBoxInner .profBox .profBoxInner:first-child {
  margin-right: 5%;
}

#Co #recruitpage .recruitBoxInner .profBox .profBoxInner:first-child figure {
  font-size: 1.2rem;
  line-height: 1.4;
  text-align: center;
}

#Co
  #recruitpage
  .recruitBoxInner
  .profBox
  .profBoxInner:first-child
  figure
  img {
  align-items: center;
  background: rgba(0, 130, 209, 0.05);
  border-radius: 10px;
  display: flex;
  height: 120px;
  justify-content: center;
  margin-bottom: 15px;
  width: 120px;
}

#Co #recruitpage .recruitBoxInner .profBox .profBoxInner p strong {
  border: none;
  color: #0070ba;
  font-size: 1.6rem;
  font-weight: 700;
  margin: 0 0 0.5rem 0;
  padding: 0;
}

/*========================================================================*\

$aiPage

\*========================================================================*/

#Co .aiPage .bgBox.wide .sectionInner {
  padding: 0;
}

#Co .aiPage .otherBox {
  background: #ffffff;
  border: 20px solid #00a5e6;
  padding: 3rem 3rem 2rem 3rem;
}

#Co .udxPage .grid-container {
  display: grid;
  grid-template-columns: 43.4% 56.6%;
  gap: 20px;
}

#Co .udxPage .grid-container th {
  width: 35%;
}

#Co #exercisePage .bgBox.wide.withPage {
  background: rgba(0, 113, 187, 0.05);
}

/*========================================================================*\

#system #Co #solutionPage.specialPage

\*========================================================================*/

#system #Co #solutionPage.specialPage .catch {
  color: #00a5e6;
}

#system #Co #solutionPage.specialPage h3 {
  display: flex;
  align-items: center;
}

#system #Co #solutionPage.specialPage h3 img {
  margin-right: 0.625rem;
}

#system #Co #solutionPage.specialPage .bgBox.wide .sectionInner {
  background: #ffffff;
  padding: 3.125rem 3.125rem 0 3.125rem;
}

#system #Co #solutionPage.specialPage .box02.reverse .box02Inner {
  width: 58% !important;
}

#system #Co #solutionPage.specialPage .box02.reverse .box02Inner h4 {
  margin-top: 0 !important;
}

#system #Co #solutionPage.specialPage .box02.reverse .box02Inner li {
  margin-bottom: 10px !important;
}

#system #Co #solutionPage.specialPage .box02.reverse .box02Inner:first-child {
  width: 40% !important;
}

/*========================================================================*\

$columnPage

\*========================================================================*/

#Co .commonPage .columnBox .columnBoxInner {
  display: flex;
  align-items: flex-start;
  align-items: center;
  text-decoration: none;
  border-bottom: 1px dashed #0070ba;
  padding: 20px 30px 20px 0;
  color: rgb(14, 5, 11);
  position: relative;
}

#Co .commonPage .columnBox .columnBoxInner:hover {
  background: rgba(0, 113, 187, 0.05);
}

#Co .commonPage .columnBox .columnBoxInner:hover .textBox p {
  color: #0070ba;
}

#Co .commonPage .columnBox .columnBoxInner::after {
  border-right: solid 2px #0070ba;
  border-top: solid 2px #0070ba;
  content: "";
  height: 8px;
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translateY(-50%) rotate(45deg);
  transition: 0.3s;
  width: 8px;
}

#Co .commonPage .columnBox .columnBoxInner .day {
  margin-right: 20px;
  margin-bottom: 0 !important;
  font-weight: 700;
}

#Co .commonPage .columnBox .columnBoxInner figure {
  width: 110px;
  flex-shrink: 0;
  margin-right: 20px;
}

#Co .commonPage .columnBox .columnBoxInner figure img {
  width: 100%;
  height: auto;
  display: block;
}

#Co .commonPage .columnBox .columnBoxInner .textBox {
  flex: 1;
}

#Co .commonPage .columnBox .columnBoxInner .textBox p {
  margin-bottom: 0 !important;
  line-height: 1.6;
}

#Co .constructionPage .accordionBox .accordionBoxInner figure {
  margin-bottom: 1.25rem;
}

#Co .constructionPage .accordionBox .accordionBoxInner {
  padding: 2.5rem;
  text-align: center;
}

#Co .constructionPage .accordionBox .accordionBoxInner h5 {
  color: #0070ba;
  font-size: 2rem;
  padding: 0;
}

#Co .constructionPage .accordionBox .accordionBoxInner p {
  margin-bottom: 1rem;
  font-weight: 700;
}

#Co .constructionPage .accordionBox .accordionBoxInner:nth-child(n + 3) {
  margin-top: 2.5rem;
}

#Co .constructionPage .accordionBox .accordionBoxInner li {
  width: 100% !important;
  text-align: left;
}

/*========================================================================*\

$スマートパーキング自動精算アプリ

\*========================================================================*/

#park_go #lowermain.specialMain .mainItem p {
  line-height: 1.4;
}

#park_go #lowermain.specialMain .mainItem p span {
  font-size: 4rem;
  color: #fff000;
  font-weight: 900;
}

#park_go #Co #solutionPage.specialPage .mainTitleSub {
  border: none;
  font-size: 4rem;
  line-height: 0.8;
  margin: 0 0 30px 0;
  padding: 0;
  text-align: center;
  color: #1c50a1;
  font-weight: 900;
}

#park_go #Co #solutionPage.specialPage .mainTitleSub span {
  border-bottom: 4px solid #009fe8;
}

#park_go #Co #solutionPage.specialPage .mainTitleSub img {
  margin-top: 50px;
}

#park_go #Co #solutionPage.specialPage .mainTitle::before {
  content: none;
}

#park_go #Co #solutionPage.specialPage .featureBox .featureBoxInner {
  width: 24%;
}

#park_go
  #Co
  #solutionPage.specialPage
  .featureBox
  .featureBoxInner
  .featureBoxItem {
  height: 249.59px;
  width: 249.59px;
}

#park_go #Co #solutionPage.specialPage .red {
  color: #d40004;
}

#park_go #Co #solutionPage.specialPage .specialBox figure {
  background: #05499e;
  background: linear-gradient(
    90deg,
    rgba(5, 73, 158, 1) 0%,
    rgba(34, 123, 192, 1) 100%
  );
  text-align: center;
  padding: 50px 0 0 0;
}

#park_go #Co #solutionPage.specialPage .featureBox .featureBoxInner h3 {
  background: #036eb8;
}

#park_go #Co #solutionPage.specialPage .specialBox {
  margin-top: 80px;
}

#park_go #Co #solutionPage.specialPage .specialBox .bgBox.wide {
  padding: 30px 0;
}

#park_go #Co #solutionPage.specialPage .caseBox {
  background: #ffffff;
  margin: 80px auto 50px auto;
  padding: 30px 30px 0 30px;
}

#park_go #Co #solutionPage.specialPage .caseBox .caseBoxInner {
  width: 40% !important;
}

#park_go #Co #solutionPage.specialPage .caseBox .caseBoxInner:first-child {
  width: 60% !important;
}

#park_go #Co #solutionPage.specialPage .caseBox p {
  font-size: 1.6rem;
}

#park_go #Co #solutionPage.specialPage .preparationBox {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}

#park_go #Co #solutionPage.specialPage .preparationBox .preparationBoxInner {
  display: flex;
  justify-content: space-between;
  width: 50%;
  padding: 50px;
  position: relative;
}

#park_go
  #Co
  #solutionPage.specialPage
  .preparationBox
  .preparationBoxInner
  .preparationBoxitem {
  width: 55%;
}

#park_go
  #Co
  #solutionPage.specialPage
  .preparationBox
  .preparationBoxInner
  .preparationBoxitem:last-child {
  width: 40%;
}

#park_go
  #Co
  #solutionPage.specialPage
  .preparationBox
  .preparationBoxInner:nth-child(1)::before {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 1px; /* 線の太さ */
  height: 100%;
  background: linear-gradient(
    to bottom,
    #c3c3c3 0%,
    #c3c3c3 95%,
    #ffffff 95%,
    #ffffff 100%
  );
}

#park_go
  #Co
  #solutionPage.specialPage
  .preparationBox
  .preparationBoxInner:nth-child(3)::before {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 1px; /* 線の太さ */
  height: 100%;
  background: linear-gradient(
    to bottom,
    #ffffff 0%,
    #ffffff 5%,
    #c3c3c3 5%,
    #c3c3c3 100%
  );
}

#park_go
  #Co
  #solutionPage.specialPage
  .preparationBox
  .preparationBoxInner:nth-child(3)::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  height: 1px; /* 線の太さ */
  width: 100%;
  background: linear-gradient(
    to right,
    #c3c3c3 0%,
    #c3c3c3 95%,
    #ffffff 95%,
    #ffffff 100%
  );
}

#park_go
  #Co
  #solutionPage.specialPage
  .preparationBox
  .preparationBoxInner:nth-child(4)::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  height: 1px;
  width: 100%;
  background: linear-gradient(
    to right,
    #ffffff 0%,
    #ffffff 5%,
    #c3c3c3 5%,
    #c3c3c3 100%
  );
}

#park_go
  #Co
  #solutionPage.specialPage
  .preparationBox
  .preparationBoxInner
  .number {
  font-size: 63px;
  color: #0086d1;
  font-weight: 900;
  margin: 0;
  line-height: 1.4;
}

#park_go #Co #solutionPage.specialPage .preparationBox .preparationBoxInner h4 {
  font-size: 2.9rem;
  border-bottom: none;
  margin: 0 0 20px;
  padding: 0;
  color: #0070ba;
}

#park_go
  #Co
  #solutionPage.specialPage
  .preparationBox
  .preparationBoxInner
  h4:before {
  content: none;
}

#park_go #Co #solutionPage.specialPage .preparationBox .preparationBoxInner li,
#park_go #Co #solutionPage.specialPage .usepoint li {
  font-size: 1.8rem;
  position: relative;
  padding-left: 20px;
  line-height: 1.4;
  margin-bottom: 10px;
}

#park_go
  #Co
  #solutionPage.specialPage
  .preparationBox
  .preparationBoxInner
  li:before,
#park_go #Co #solutionPage.specialPage .usepoint li:before {
  background: #0070ba;
  border-radius: 50%;
  content: "";
  height: 10px;
  left: 0;
  position: absolute;
  top: 0.5em;
  width: 10px;
}

#park_go #Co #solutionPage.specialPage .appBox {
  background: #05499e;
  background: linear-gradient(
    90deg,
    rgba(5, 73, 158, 1) 0%,
    rgba(34, 123, 192, 1) 100%
  );
  padding: 20px;
  margin-bottom: 50px;
}

#park_go #Co #solutionPage.specialPage .appBox .appBoxAll {
  background: #ffffff;
  padding: 50px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

#park_go #Co #solutionPage.specialPage .appBox .appBoxInner {
  width: 55%;
}

#park_go #Co #solutionPage.specialPage .appBox .appBoxInner:last-child {
  width: 40%;
}

#park_go #Co #solutionPage.specialPage .appBox .appBoxInner .logoTxt {
  border: none;
  font-size: 3rem;
  line-height: 0.8;
  margin: 0;
  padding: 0;
  text-align: center;
  color: #1c50a1;
  font-weight: 900;
}

#park_go #Co #solutionPage.specialPage .appBox .appBoxInner .logoTxt img {
  margin: 40px 0 0 0;
}

#park_go #Co #solutionPage.specialPage .appBox .appBoxInner .logoTxt span {
  border-bottom: 4px solid #009fe8;
}

#park_go #Co #solutionPage.specialPage .appBox .appBoxInner .box02Inner {
  padding-right: 0;
  padding-left: 10px;
}

#park_go
  #Co
  #solutionPage.specialPage
  .appBox
  .appBoxInner
  .box02Inner:first-child {
  padding-right: 10px;
  padding-left: 0;
}

#park_go #Co #solutionPage.specialPage .contactAreaInner li {
  margin: 0 auto;
}

#Co .page .sectionInner.katuyouBox .box03Inner {
  background: rgba(0, 113, 187, 0.05);
  padding: 20px;
}

#Co .page .sectionInner.katuyouBox .box03Inner:nth-child(n + 4) {
  margin-top: 25px;
}

#Co .page .sectionInner.katuyouBox .box03 h4 {
  border: none;
  color: #00a5e6;
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.6;
  margin: 15px 0 0 0;
  padding-left: 0;
}

#Co .page .sectionInner.katuyouBox .box03 h4::before {
  content: none;
}

/*========================================================================*\

$newsPage_park_go

\*========================================================================*/

#park_go #newsPage .specialMain {
  position: relative;
}

#park_go #newsPage .specialMain .mainInner {
  background: url(../news/img/20251001_img_01.jpg) center bottom / cover;
  align-items: center;
  animation-duration: 1s;
  animation-fill-mode: forwards;
  animation-name: bgextendAnimeBase;
  display: flex;
  height: 500px;
  justify-content: flex-end;
  opacity: 0;
  position: relative;
  margin: 0px;
}

#park_go #newsPage .specialMain .mainItem {
  left: 2%;
  bottom: 0%;
  top: auto;
  transform: none;
  position: absolute;
}

#park_go #newsPage .specialMain .mainItem h2 {
  color: #ffffff;
  font-size: 6rem;
  font-weight: 700;
  margin-bottom: 20px;
  border: none;
  padding: 0;
}

#park_go #newsPage .specialMain .mainItem h2::before {
  content: none;
}

#park_go #newsPage .specialMain .mainItem h2 .ss {
  font-size: 1.8rem;
  line-height: 2.8;
}

#park_go #newsPage .specialMain .mainItem p {
  color: #ffffff;
  font-size: 1.8rem;
  line-height: 1.8;
}

#park_go #newsPage .specialMain .mainItem p span {
  font-size: 4rem;
  color: #fff000;
  font-weight: 900;
}

#park_go #newsPage .colorBox {
  background: rgba(0, 113, 187, 0.05);
  margin-bottom: 50px;
  padding: 30px;
  width: 100%;
}

#park_go #newsPage .colorBox .colorBoxInner {
  background: #ffffff;
  margin: 0 auto;
  padding: 30px;
  width: 100%;
}

#park_go #newsPage .colorBox .colorBoxInner figure {
  margin: 0 auto;
  text-align: center;
  display: flex;
  justify-content: center;
  align-items: center;
}

#park_go #newsPage .bgBox {
  background: #05499e;
  background: linear-gradient(
    90deg,
    rgba(5, 73, 158, 1) 0%,
    rgba(34, 123, 192, 1) 100%
  );
  text-align: center;
  padding: 50px 0 0 0;
}

#park_go #newsPage .featureBox {
  margin: 0 0 10px 0;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

#park_go #newsPage .featureBox .featureBoxInner {
  width: 24%;
}

#park_go #newsPage .featureBox .featureBoxInner .featureBoxItem {
  height: 249.59px;
  width: 249.59px;
  background: rgba(0, 153, 255, 0.1);
  justify-content: center;
  border-radius: 50%;
  display: flex;
  align-items: center;
}

#park_go #newsPage .featureBox img {
  padding: 0 0 30px 0;
}

#park_go #newsPage .featureBox .featureBoxInner .featureBoxItem,
#system
  #Co
  #solutionPage.specialPage
  .featureBox
  .featureBoxInner
  .featureBoxItem {
  background: rgba(0, 153, 255, 0.1);
}

#park_go #newsPage .featureBox .featureBoxInner h3,
#system #Co #solutionPage.specialPage .featureBox .featureBoxInner h3 {
  background: #036eb8;
  border: none;
  border-radius: 60rem;
  color: #ffffff;
  font-size: 1.8rem;
  line-height: 1;
  margin: -60px 0 40px 0;
  padding: 10px 5px;
  text-align: center;
  display: block;
}

#system
  #Co
  #solutionPage.specialPage
  .featureBox
  .featureBoxInner
  .featureBoxItem
  img {
  width: 50%;
}

#park_go #newsPage .featureBox .featureBoxInner h3::after {
  content: none;
}

#park_go #newsPage .featureBox .featureBoxInner p {
  line-height: 1.6;
}

#park_go #newsPage .preparationBox {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}

#park_go #newsPage .preparationBox .preparationBoxInner {
  display: flex;
  justify-content: space-between;
  width: 50%;
  padding: 50px;
  position: relative;
}

#park_go #newsPage .preparationBox .preparationBoxInner .preparationBoxitem {
  width: 55%;
}

#park_go
  #newsPage
  .preparationBox
  .preparationBoxInner
  .preparationBoxitem:last-child {
  width: 40%;
}

#park_go #newsPage .preparationBox .preparationBoxInner:nth-child(1)::before {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 1px; /* 線の太さ */
  height: 100%;
  background: linear-gradient(
    to bottom,
    #c3c3c3 0%,
    #c3c3c3 95%,
    #ffffff 95%,
    #ffffff 100%
  );
}

#park_go #newsPage .preparationBox .preparationBoxInner:nth-child(3)::before {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 1px; /* 線の太さ */
  height: 100%;
  background: linear-gradient(
    to bottom,
    #ffffff 0%,
    #ffffff 5%,
    #c3c3c3 5%,
    #c3c3c3 100%
  );
}

#park_go #newsPage .preparationBox .preparationBoxInner:nth-child(3)::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  height: 1px; /* 線の太さ */
  width: 100%;
  background: linear-gradient(
    to right,
    #c3c3c3 0%,
    #c3c3c3 95%,
    #ffffff 95%,
    #ffffff 100%
  );
}

#park_go #newsPage .preparationBox .preparationBoxInner:nth-child(4)::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  height: 1px;
  width: 100%;
  background: linear-gradient(
    to right,
    #ffffff 0%,
    #ffffff 5%,
    #c3c3c3 5%,
    #c3c3c3 100%
  );
}

#park_go #newsPage .preparationBox .preparationBoxInner .number {
  font-size: 63px;
  color: #0086d1;
  font-weight: 900;
  margin: 0;
  line-height: 1.4;
}

#park_go #newsPage .preparationBox .preparationBoxInner h4 {
  font-size: 2.9rem;
  border-bottom: none;
  margin: 0 0 20px;
  padding: 0;
  color: #0070ba;
}

#park_go #newsPage .preparationBox .preparationBoxInner h4:before {
  content: none;
}

#park_go #newsPage .preparationBox .preparationBoxInner li,
#park_go #newsPage .usepoint li {
  font-size: 1.8rem;
  position: relative;
  padding-left: 20px;
  line-height: 1.4;
  margin-bottom: 10px;
}

#park_go #newsPage .preparationBox .preparationBoxInner li:before,
#park_go #newsPage .usepoint li:before {
  background: #0070ba;
  border-radius: 50%;
  content: "";
  height: 10px;
  left: 0;
  position: absolute;
  top: 0.5em;
  width: 10px;
}

#park_go #newsPage .appBox {
  background: #05499e;
  background: linear-gradient(
    90deg,
    rgba(5, 73, 158, 1) 0%,
    rgba(34, 123, 192, 1) 100%
  );
  padding: 20px;
  margin-bottom: 50px;
}

#park_go #newsPage .appBox .appBoxAll {
  background: #ffffff;
  padding: 50px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

#park_go #newsPage .appBox .appBoxInner {
  width: 55%;
}

#park_go #newsPage .appBox .appBoxInner:last-child {
  width: 40%;
}

#park_go #newsPage .appBox .appBoxInner .logoTxt {
  border: none;
  font-size: 3rem;
  line-height: 0.8;
  margin: 0;
  padding: 0;
  text-align: center;
  color: #1c50a1;
  font-weight: 900;
}

#park_go #newsPage .appBox .appBoxInner .logoTxt img {
  margin: 40px 0 0 0;
}

#park_go #newsPage .appBox .appBoxInner .logoTxt span {
  border-bottom: 4px solid #009fe8;
}

#park_go #newsPage .appBox .appBoxInner .box02Inner {
  padding-right: 0;
  padding-left: 10px;
}

#park_go #newsPage .appBox .appBoxInner .box02Inner:first-child {
  padding-right: 10px;
  padding-left: 0;
}

#system #Co #solutionPage.specialPage .mainTitle {
  border: none;
  font-size: 4rem;
  line-height: 1.2;
  margin: 0 0 50px 0;
  padding: 0;
  text-align: center;
}

#system #Co #solutionPage.specialPage .mainTitle .orange {
  color: #ec8f34;
}

#system #Co #solutionPage.specialPage .mainTitle .big {
  font-size: 5rem;
}

/*========================================================================*\

$smart_ticket

\*========================================================================*/

#smart_ticket #Co #solutionPage .mainTitle::before {
  background-image: url(../solution/smart_ticket_parking/img/logo.png);
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  display: block;
  height: 62px;
  margin: 0 auto 10px auto;
  text-align: center;
  width: 350px;
}

#smart_ticket #Co #solutionPage .mainTitle {
  border: none;
  font-size: 4rem;
  line-height: 0.8;
  margin: 0 0 50px 0;
  padding: 0;
  text-align: center;
}

#smart_ticket #Co #solutionPage .mainTitle .orange {
  color: #ec8f34;
}

#smart_ticket #Co #solutionPage .mainTitle .big {
  font-size: 5rem;
}

#smart_ticket #Co #solutionPage .featureBox {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 0 0 50px 0;
}

#smart_ticket #Co #solutionPage .featureBox .featureBoxInner {
  text-align: center;
  width: 31.5%;
}

#smart_ticket #Co #solutionPage .featureBox .featureBoxInner .featureBoxItem {
  background: rgba(0, 153, 255, 0.1);
  align-items: center;
  border-radius: 50%;
  display: flex;
  height: 327.59px;
  justify-content: center;
  width: 327.59px;
}

#smart_ticket #Co #solutionPage .featureBox .featureBoxInner h3 {
  background: #0099ff;
  border: none;
  border-radius: 60rem;
  color: #ffffff;
  font-size: 1.8rem;
  line-height: 1;
  margin: -60px 0 0 0;
  padding: 10px 5px;
  text-align: center;
}

#smart_ticket #Co #solutionPage .featureBox .featureBoxInner h3::after {
  content: none;
}

#smart_ticket #Co #solutionPage .caseBox_02 .detailBox,
#park_go #Co #solutionPage.specialPage #sp_Section .caseBox_02 .detailBox {
  display: flex;
  justify-content: space-between;
}

#smart_ticket #Co #solutionPage .caseBox_02 .detailBox .detailBoxInner,
#park_go
  #Co
  #solutionPage.specialPage
  #sp_Section
  .caseBox_02
  .detailBox
  .detailBoxInner {
  position: relative;
  width: 19%;
}

#park_go #Co #solutionPage.specialPage #sp_Section .caseBox_02 {
  padding: 0;
}

#smart_ticket #Co #solutionPage .caseBox_02 h5,
#park_go #Co #solutionPage.specialPage #sp_Section .caseBox_02 h5 {
  background: rgb(97, 203, 244);
  background: linear-gradient(
    90deg,
    rgba(97, 203, 244, 1) 0%,
    rgba(0, 112, 192, 1) 100%
  );
  border-radius: 6px;
  color: #ffffff;
  font-size: 1.7rem;
  text-align: center;
  line-height: 1;
  padding: 18px 0 20px 0;
  margin-bottom: 30px;
}

#park_go #Co #solutionPage.specialPage #sp_Section .caseBox_02 figure {
  margin-bottom: 5px;
}

#smart_ticket #Co #solutionPage .caseBox_02 .detailBox .detailBoxInner::after,
#park_go
  #Co
  #solutionPage.specialPage
  #sp_Section
  .caseBox_02
  .detailBox
  .detailBoxInner::after {
  background-image: url(../solution/smart_parking/img/arrow.png);
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  height: 45px;
  position: absolute;
  right: -80px;
  top: 4px;
  vertical-align: middle;
  width: 53px;
}

#smart_ticket
  #Co
  #solutionPage
  .caseBox_02
  .detailBox
  .detailBoxInner:last-child:after,
#park_go
  #Co
  #solutionPage.specialPage
  #sp_Section
  .caseBox_02
  .detailBox
  .detailBoxInner:last-child:after {
  content: none;
}

#smart_ticket #Co #solutionPage .box03 li,
#park_go #Co #solutionPage .box03 li {
  line-height: 1.6;
}

#smart_ticket #Co #solutionPage .swiper-container {
  width: 1200px;
  margin: 0 auto;
  overflow: hidden;
  box-sizing: border-box;
}

#smart_ticket #Co #solutionPage .swiper-slide {
  background: #ffffff;
}

#smart_ticket #Co #solutionPage .swiper-slide p {
  padding: 1.25rem;
  line-height: 1.6;
  text-align: center;
  margin: 0 !important;
}

#smart_ticket #Co #solutionPage .swiper-pagination-bullet-active {
  background: #1386bf !important;
}

#smart_ticket #Co #solutionPage .swiper-button-next,
#smart_ticket #Co #solutionPage .swiper-button-prev {
  display: block;
  height: 60px;
  left: auto;
  top: auto;
  width: 60px;
  z-index: 3000;
  background: rgb(255, 255, 255);
  border: 1px #1386bf solid;
  border-radius: 50%;
  position: absolute;
  top: 50%;
}

#smart_ticket #Co #solutionPage .swiper-button-prev:hover,
#smart_ticket #Co #solutionPage .swiper-button-next:hover {
  background: #1386bf;
  border: 1px #1386bf solid;
}

#smart_ticket #Co #solutionPage .swiper-button-next {
  right: 140px;
}

#smart_ticket #Co #solutionPage .swiper-button-prev {
  left: 140px;
}

#Co .swiper-button-prev::after,
#Co .swiper-button-prev_02::after {
  mask-image: url(../images/ico_arrow.svg);
  mask-size: contain;
}

#Co .swiper-button-prev::after,
#Co .swiper-button-next::after {
  background-color: #1386bf;
  content: "";
  display: block;
  height: 13px;
  left: 50%;
  position: absolute;
  top: 50%;
  transform: translateY(-50%) translateX(-50%);
  width: 8px;
  margin: auto;
  transition: background-color 0.4s;
}

#Co .swiper-button-next::after {
  mask-image: url(../images/ico_arrow.svg);
  mask-size: contain;
}

#Co .swiper-button-prev::after {
  mask-image: url(../images/ico_arrow_r.svg);
  mask-size: contain;
}

#Co .swiper-button-prev:hover:after,
#Co .swiper-button-next:hover:after {
  background-color: #ffffff;
}
