/* =========================================================
   style202304.css
   ========================================================= */

.page-visual.bus-dx {
  height: 420px;
  background: url(../img/bus-dx/bus-dx-kv-pc.png) no-repeat left 44% top;
  background-size: cover;
}

.bus-dx-page .center-text.add-mt {
  margin-top: 25px;
}

.bus-dx-page .image-box {
  margin-top: 55px;
}

.bus-dx-page .about-menu__ttl {
  padding-right: 20px;
  height: 50px;
}

.page-visual.ledger-system {
  padding-bottom: 41%;
  height: auto;
  background-image: url(../img/bus-dx/ledger-system-kv-pc.png);
  background-repeat: no-repeat;
  background-position: left top;
  background-size: 100%;
  position: relative;
}

.page-visual.police-management {
  padding-bottom: 41%;
  height: auto;
  background-image: url(../img/bus-dx/police-management-kv-pc.png);
  background-repeat: no-repeat;
  background-position: left top;
  background-size: 100%;
  position: relative;
}

.page-visual.crew-ledger-management {
  padding-bottom: 41%;
  height: auto;
  background-image: url(../img/bus-dx/crew-ledger-management-kv-pc.png);
  background-repeat: no-repeat;
  background-position: left top;
  background-size: 100%;
  position: relative;
}

.page-visual.timetable-organization {
  padding-bottom: 41%;
  height: auto;
  background-image: url(../img/bus-dx/timetable-organization-kv-pc.png);
  background-repeat: no-repeat;
  background-position: left top;
  background-size: 100%;
  position: relative;
}

.page-visual.vehicle-ledger-system {
  padding-bottom: 41%;
  height: auto;
  background-image: url(../img/bus-dx/vehicle-ledger-system-kv-pc.png);
  background-repeat: no-repeat;
  background-position: left top;
  background-size: 100%;
  position: relative;
}

.page-visual.bus-time-creation {
  padding-bottom: 41%;
  height: auto;
  background-image: url(../img/bus-dx/bus-time-creation-kv-pc.png);
  background-repeat: no-repeat;
  background-position: left top;
  background-size: 100%;
  position: relative;
}

.page-visual.boarding-alighting-data {
  padding-bottom: 41%;
  height: auto;
  background-image: url(../img/bus-dx/boarding-alighting-data-kv-pc.png);
  background-repeat: no-repeat;
  background-position: left top;
  background-size: 100%;
  position: relative;
}

.page-visual.eco-driving-analysis {
  padding-bottom: 41%;
  height: auto;
  background-image: url(../img/bus-dx/eco-driving-analysis-kv-pc.png);
  background-repeat: no-repeat;
  background-position: left top;
  background-size: 100%;
  position: relative;
}

.bus-dx-page-det .service-mv__ttl::after {
  display: none;
}

.bus-dx-page-det .service-mv__text {
  top: 10vw;
}

.bus-dx-page-det .service-mv__main-ttl {
  font-size: 30px;
  font-weight: bold;
  color: #6667ab;
  margin-top: 10px;
}

.dx-contact {
  display: flex;
  align-items: stretch;
  margin-bottom: 65px;
}

.dx-contact__item {
  width: 50%;
  border: 1px solid #f1f1f1;
}

.dx-contact__item:nth-of-type(2) {
  border-left: none;
}

.dx-contact__item-inner {
  padding: 40px;
}

.dx-contact__item-ttl {
  font-size: 14px;
  font-weight: bold;
  color: #6667ab;
  margin-bottom: 15px;
}

.dx-contact__item-name {
  display: flex;
  align-items: center;
  margin-bottom: 15px;
}

.dx-contact__item-name-com {
  font-size: 20px;
  font-weight: bold;
  color: #6667ab;
  padding-right: 20px;
  padding-left: 10px;
}

.dx-contact__item-name-com a {
  display: block;
  font-size: 13px;
  font-weight: normal;
}

.dx-contact__item-name-logo {
  width: 50px;
}

.dx-contact__item-name.partner {
  margin-right: 10px;
}

.dx-contact__item-place {
  font-size: 14px;
}

.dx-contact__item-place span {
  display: block;
  margin-bottom: 10px;
}

.dx-contact__item-commnet {
  font-size: 16px;
  font-weight: bold;
  color: #6667ab;
  margin-top: 15px;
}

.content-text {
  margin-top: 20px;
  font-size: 16px;
  line-height: 1.8;
}

.purple-bg-ttl.for-sp-ttl {
  margin-bottom: 15px;
}

.content-space {
  margin: 55px 0;
}

.content-space-m {
  margin: 40px 0 50px;
}

.oneclm-img {
  max-width: 960px;
  margin: 0 auto;
}

.twoclm-content-seven {
  width: 65%;
}

.twoclm-content-three {
  width: 30%;
}

.twoclm-content-two {
  width: 47.5%;
}

.border-gray {
  border: 2px #ededed solid;
}

.mt-0 {
  margin-top: 0 !important;
}

.mt-15 {
  margin-top: 15px;
}

.mt-20 {
  margin-top: 20px;
}

.mt-space {
  margin-top: 40px;
}

.mt-space-l {
  margin-top: 50px;
}

.mb-space {
  margin-bottom: 50px;
}

.mb-10 {
  margin-bottom: 10px;
}

.mb-20 {
  margin-bottom: 20px;
}

.clm-inner {
  padding: 40px;
}

.gold-bg-ttl {
  color: #fff;
  background: #ccb97e;
  font-size: 18px;
  font-weight: 500;
  padding: 5px 10px;
}

.gold-desc {
  display: flex;
  align-items: center;
  font-size: 14px;
  margin-top: 10px;
}

.gold-desc.a-imtems-top {
  align-items: flex-start;
}

.gold-desc::before {
  display: block;
  content: "";
  width: 12px;
  height: 12px;
  min-width: 12px;
  background: #ccb97e;
  border-radius: 50%;
  margin-right: 15px;
}

.gold-content {
  padding: 5px 20px 15px;
  border: 4px solid #ccb97e;
}

.gold-desc.a-imtems-top::before {
  margin-top: 5px;
}

.at-text-right {
  text-align: right;
  font-size: 16px;
}

.at-text-left {
  text-align: left;
  font-size: 16px;
  line-height: 1.8;
}

.fs-14 {
  font-size: 14px;
}

.fs-16 {
  font-size: 16px;
  line-height: 1.8;
}

.fs-12 {
  font-size: 12px;
}

.text-center {
  text-align: center;
}

.fs-l {
  font-size: 19px;
}

.purple-content {
  padding: 5px 15px 15px;
  border: 4px solid #696aab;
}

.list-num li {
  display: flex;
  margin-bottom: 10px;
}

.list-num__num {
  font-size: 14px;
  color: #696aab;
  font-weight: bold;
  padding-right: 8px;
}

.list-num__text {
  font-size: 14px;
}

.threeclm-box {
  display: flex;
  justify-content: space-between;
}

.threeclm-box__img {
  width: 31%;
}

.bus-content-img {
  max-width: 215px;
}

.ovx-hidden {
  overflow-x: hidden;
}

.purple-desc {
  font-size: 15px;
}

.small-at {
  font-size: 14px;
}

/* =========================================================
   Media Queries (style202304.css)
   ========================================================= */

@media screen and (min-width: 1100px) {
  .sp-white-space-no {
    width: auto;
  }
}

@media screen and (min-width: 821px) and (max-width: 1024px) {
  .service-mv__text {
    padding: 20px;
    left: 2.5vw;
  }
  .page-content {
    padding-left: 20px;
    padding-right: 20px;
  }
  .page-visual.crew-ledger-management .service-mv__text {
    top: 2.5vw;
  }
  .page-visual.vehicle-ledger-system .service-mv__text {
    top: 4.2vw;
  }
  .page-visual.bus-time-creation .service-mv__text {
    top: 2.3vw;
  }
  .about-memu {
    padding: 65px 3%;
  }
}

@media screen and (min-width: 820px) {
  .sp-white-space-no {
    width: 60px;
  }
}

@media screen and (max-width: 820px) {
  .page-visual.bus-dx {
    height: 40vh;
    background: url(../img/bus-dx/bus-dx-kv-sp.png) no-repeat left top;
    background-size: cover;
  }
  .bus-dx-page .about-menu__ttl {
    height: auto;
  }
  .page-visual.ledger-system {
    padding-bottom: 0%;
    height: auto;
    background-image: none;
    background-size: 100%;
  }
  .page-visual.police-management {
    padding-bottom: 0%;
    height: auto;
    background-image: none;
    background-size: cover;
  }
  .page-visual.crew-ledger-management {
    padding-bottom: 0%;
    height: auto;
    background-image: none;
    background-size: 100%;
  }
  .page-visual.timetable-organization {
    padding-bottom: 0%;
    height: auto;
    background-image: none;
    background-size: 100%;
  }
  .page-visual.vehicle-ledger-system {
    padding-bottom: 0%;
    height: auto;
    background-image: none;
    background-size: 100%;
  }
  .page-visual.bus-time-creation {
    padding-bottom: 0%;
    height: auto;
    background-image: none;
    background-size: 100%;
  }
  .page-visual.boarding-alighting-data {
    padding-bottom: 0%;
    height: auto;
    background-image: none;
    background-size: 100%;
  }
  .page-visual.eco-driving-analysis {
    padding-bottom: 0%;
    height: auto;
    background-image: none;
    background-size: 100%;
  }
  .bus-dx-page-det .service-mv__text {
    top: auto;
  }
  .bus-dx-page-det .service-mv__main-ttl {
    font-size: 24px;
    margin-top: 0;
  }
  .dx-contact {
    display: block;
    margin-bottom: 40px;
  }
  .dx-contact__item {
    width: 100%;
  }
  .dx-contact__item:nth-of-type(2) {
    border-left: 1px solid #f1f1f1;
    border-top: none;
  }
  .dx-contact__item-inner {
    padding: 20px;
  }
  .dx-contact__item-ttl {
    font-size: 13px;
    margin-bottom: 10px;
  }
  .dx-contact__item-name-com {
    font-size: 18px;
    padding-right: 20px;
  }
  .dx-contact__item-name-com a {
    font-size: 12px;
  }
  .dx-contact__item-name-logo {
    width: 45px;
  }
  .dx-contact__item-place {
    font-size: 12px;
  }
  .dx-contact__item-commnet {
    font-size: 13px;
  }
  .content-text {
    font-size: 14px;
  }
  .content-space {
    margin: 30px 0;
  }
  .content-space-m {
    margin: 15px 0 30px;
  }
  .twoclm-content-seven {
    width: 100%;
  }
  .twoclm-content-three {
    width: 100%;
  }
  .twoclm-content-two {
    width: 100%;
  }
  .mt-20 {
    margin-top: 15px;
  }
  .mt-space {
    margin-top: 20px;
  }
  .mt-space-l {
    margin-top: 30px;
  }
  .mb-space {
    margin-bottom: 30px;
  }
  .mb-20 {
    margin-bottom: 15px;
  }
  .sp-mt-none {
    margin-top: 0;
  }
  .sp-mb-30 {
    margin-bottom: 30px;
  }
  .clm-inner {
    padding: 25px;
  }
  .sp-mt-15 {
    margin-top: 15px;
  }
  .gold-bg-ttl {
    font-size: 14px;
    padding: 5px 10px;
  }
  .gold-desc {
    font-size: 12px;
  }
  .gold-desc::before {
    width: 10px;
    height: 10px;
    min-width: 10px;
  }
  .gold-content {
    padding: 5px 14px 15px;
  }
  .at-text-right {
    font-size: 14px;
  }
  .at-text-left {
    font-size: 14px;
  }
  .fs-14 {
    font-size: 12px;
  }
  .fs-16 {
    font-size: 14px;
  }
  .fs-12 {
    font-size: 10px;
  }
  .fs-l {
    font-size: 16px;
  }
  .purple-content {
    padding: 5px 14px 15px;
  }
  .threeclm-box {
    display: block;
  }
  .threeclm-box__img {
    width: 100%;
  }
  .threeclm-box__img:nth-of-type(2) {
    margin: 15px 0;
  }
  .bus-content-img {
    max-width: 100%;
  }
  .top-service-card__item {
    vertical-align: top;
  }
  .sp-white-space-no {
    white-space: nowrap;
  }
}