div#dMain {
  width: 100% !important;
}

#dMain .is-pc {
  display: block;
}

#dMain .is-sp {
  display: none;
}

@media screen and (max-width: 767px) {
  #dMain .is-pc {
    display: none;
  }

  #dMain .is-sp {
    display: block;
  }
}

#aMainContents h2 {
  color: #5244a3 !important;
  font-size: clamp(21px, 2.6vw, 32px) !important;
  font-weight: 900;
  text-align: center;
  border-bottom: 1px solid #5244a3;
  background-image: none;
  background-color: unset;
}

/* ===========キービジュアル============== */

.dKeyVisual {
  width: 100%;
  border: none !important;
}

.dKeyVisual-bg {
  width: 100%;
  position: relative;
}

div#dKeyVisual img {
  width: 100%;
}

.dKeyVisual-container {
  position: absolute;
  transform: translateY(-50%);
  top: 50%;
  left: clamp(20px, 6vw, 120px);
}

.dKeyVisual-contents {
  color: #fff;
}

.dKeyVisual-label {
  display: inline-block;
  font-size: clamp(16px, 1.45vw, 28px) !important;
  border: 2px solid #fff;
  border-radius: 50px;
  padding: 5px 40px;
}

.dKeyVisual-ttl {
  font-size: clamp(21px, 1.25vw, 24px) !important;
  font-weight: 700;
  margin: clamp(15px, 1.04vw, 20px) 0 clamp(15px, 1.56vw, 30px) !important;
}

.dKeyVisual-ttl span {
  font-size: clamp(30px, 1.72vw, 22px);
  font-weight: 900;
}

.dKeyVisual-txt {
  font-size: clamp(18px, 1.25vw, 24px) !important;
}

.dKeyVisual-nav {
  display: flex;
  gap: 25px;
  margin-top: clamp(25px, 2.6vw, 50px);
}

.dKeyVisual-nav a {
  position: relative;
  font-size: clamp(14px, 0.8vw, 16px) !important;
  font-weight: 700;
  color: #fff !important;
  background-color: #ef7721;
  border: 3px solid #fff;
  border-radius: 50px;
  padding: clamp(10px, 0.7vw, 15px) clamp(60px, 3.645833333333333vw, 70px)
    clamp(10px, 0.7vw, 15px) clamp(40px, 2.60vw, 50px);
}

.dKeyVisual-nav a::after {
  position: absolute;
  content: "";
  background: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2219%22%20height%3D%2212%22%20viewBox%3D%220%200%2019%2012%22%20fill%3D%22none%22%3E%3Cpath%20d%3D%22M1%201.875L9.25%2010.125L17.5%201.875%22%20stroke%3D%22white%22%20stroke-width%3D%222%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%2F%3E%3C%2Fsvg%3E")
    no-repeat center;
  background-size: contain;
  width: 16px;
  height: 8px;
  transform: translateY(-50%);
  top: 50%;
  right: 20px;
}

@media screen and (max-width: 767px) {
  .dKeyVisual-container {
    width: 100%;
    transform: none;
    top: auto;
    bottom: 100px;
    left: 0;
  }
  .dKeyVisual-bg {
    height: clamp(693px, 72vw, 1386px);
  }
  .dKeyVisual-bg img {
    object-fit: cover;
    object-position: top;
    width: 100% !important;
    height: 100% !important;
  }
  .dKeyVisual-contents {
    text-align: center;
  }

  .dKeyVisual-ttl {
    font-size: 2.1rem;
  }
  .dKeyVisual-nav {
    width: 100%;
    flex-direction: column;
    gap: 15px;
  }

  .dKeyVisual-nav li {
    width: 70%;
    margin: 0 auto;
  }

  .dKeyVisual-nav a {
    display: block;
    text-align: center;
  }
}

/* ===========swiper============== */

.mv-swiper {
  position: relative;
  width: 590px;
  margin: 30px auto 70px;
}

.swiper-slide {
  aspect-ratio: 24 / 5;
  /* overflow: hidden; */
}

.swiper-slide img {
  width: 100% !important;
  height: 100% !important;
}

.swiper-pagination {
  bottom: -35px !important;
}

.mv-swiper .swiper-pagination-bullet {
  width: var(
    --swiper-pagination-bullet-width,
    var(--swiper-pagination-bullet-size, 15px)
  );
  height: var(
    --swiper-pagination-bullet-height,
    var(--swiper-pagination-bullet-size, 15px)
  );
}

@media screen and (max-width: 767px) {
  .mv-swiper {
    width: 95%;
    margin: 30px 0px 70px auto;
  }

  .mv-swiper .swiper-pagination-bullet {
    width: var(
      --swiper-pagination-bullet-width,
      var(--swiper-pagination-bullet-size, 12px)
    );
    height: var(
      --swiper-pagination-bullet-height,
      var(--swiper-pagination-bullet-size, 12px)
    );
  }
}

.swiper-pagination-bullet {
  background: #5244a3;
}

.swiper-pagination-bullet-active {
  background: #5244a3;
}

.section-bg {
  background: #f1efff;
  padding: clamp(40px, 4.16vw, 80px) 0;
}
.section-bg02 {
  background: #918ab9;
  padding: clamp(40px, 4.16vw, 80px) 0;
}

.sModSecNormal {
  background: #fff;
  box-shadow: 0 0 20px 0 rgba(82, 68, 163, 0.1);
  border-radius: 20px;
  padding: clamp(15px, 4.16vw, 50px);
}

.section {
  max-width: 1000px;
  margin: 0 auto clamp(40px, 4.16vw, 80px);
}

@media screen and (max-width: 1000px) {
  .section {
    width: 90%;
    max-width: none;
  }
}

/* ===========ETC専用料金所とは？============== */

.WhatEtcToll-contents {
  display: flex;
  align-items: center;
  gap: clamp(30px, 5vw, 60px);
  margin-top: clamp(25px, 3.33vw, 40px);
}

.WhatEtcToll-contents img {
  width: 45%;
}

.WhatEtcToll-txt-area {
  display: flex;
  flex-direction: column;
  gap: clamp(25px, 4vw, 50px);
  width: 55%;
}

.WhatEtcToll-txt {
  font-size: clamp(14px, 1.5vw, 18px) !important;
}

.WhatEtcToll-open button {
  position: relative;
  background: #dfd9fe;
  color: #5244a3;
  font-size: clamp(15px, 1.66vw, 20px);
  font-weight: 700;
  padding: 20px 50px 20px clamp(55px, 5.4vw, 65px);
  border-radius: 10px;
}

.WhatEtcToll-open button::before,
.WhatEtcToll-open button::after {
  position: absolute;
  content: "";
  transform: translateY(-50%);
  top: 51%;
}
.WhatEtcToll-open button::before {
  background: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2225%22%20height%3D%2225%22%20viewBox%3D%220%200%2025%2025%22%20fill%3D%22none%22%3E%3Cpath%20d%3D%22M11.25%2020H13.75V17.5H11.25V20ZM12.5%200C10.8585%200%209.23303%200.323322%207.71646%200.951506C6.19989%201.57969%204.8219%202.50043%203.66117%203.66117C1.31696%206.00537%200%209.18479%200%2012.5C0%2015.8152%201.31696%2018.9946%203.66117%2021.3388C4.8219%2022.4996%206.19989%2023.4203%207.71646%2024.0485C9.23303%2024.6767%2010.8585%2025%2012.5%2025C15.8152%2025%2018.9946%2023.683%2021.3388%2021.3388C23.683%2018.9946%2025%2015.8152%2025%2012.5C25%2010.8585%2024.6767%209.23303%2024.0485%207.71646C23.4203%206.19989%2022.4996%204.8219%2021.3388%203.66117C20.1781%202.50043%2018.8001%201.57969%2017.2835%200.951506C15.767%200.323322%2014.1415%200%2012.5%200ZM12.5%2022.5C6.9875%2022.5%202.5%2018.0125%202.5%2012.5C2.5%206.9875%206.9875%202.5%2012.5%202.5C18.0125%202.5%2022.5%206.9875%2022.5%2012.5C22.5%2018.0125%2018.0125%2022.5%2012.5%2022.5ZM12.5%205C11.1739%205%209.90215%205.52678%208.96447%206.46447C8.02678%207.40215%207.5%208.67392%207.5%2010H10C10%209.33696%2010.2634%208.70107%2010.7322%208.23223C11.2011%207.76339%2011.837%207.5%2012.5%207.5C13.163%207.5%2013.7989%207.76339%2014.2678%208.23223C14.7366%208.70107%2015%209.33696%2015%2010C15%2012.5%2011.25%2012.1875%2011.25%2016.25H13.75C13.75%2013.4375%2017.5%2013.125%2017.5%2010C17.5%208.67392%2016.9732%207.40215%2016.0355%206.46447C15.0979%205.52678%2013.8261%205%2012.5%205Z%22%20fill%3D%22%235244A3%22%2F%3E%3C%2Fsvg%3E")
    no-repeat center;
  background-size: contain;
  width: clamp(17px, 2.08vw, 24px);
  height: clamp(17px, 2.08vw, 24px);
  left: 20px;
}

.WhatEtcToll-open button::after {
  background: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2214%22%20height%3D%2215%22%20viewBox%3D%220%200%2014%2015%22%20fill%3D%22none%22%3E%3Cpath%20d%3D%22M14%208.5H8V14.5H6V8.5H0V6.5H6V0.5H8V6.5H14V8.5Z%22%20fill%3D%22%235244A3%22%2F%3E%3C%2Fsvg%3E")
    no-repeat center;
  background-size: contain;
  width: 14px;
  height: 14px;
  right: 20px;
}

/* ===========モーダル============== */
.modal {
  display: none;
  position: fixed;
  transform: translate(-50%, -50%);
  left: 50%;
  top: 50%;
  height: 100%;
  width: 100%;
  z-index: 9999;
}

.modal__overlay {
  background-color: rgba(0, 0, 0, 0.4);
  height: 100%;
  width: 100%;
}

.modal__container {
  width: 60%;
  position: absolute;
  display: flex;
  flex-direction: column;
  align-items: center;
  transform: translate(-50%, -50%);
  top: 50%;
  left: 50%;
}
.modal__heading-area {
  position: relative;
  width: 100%;
  background: #5244a3;
  border: 2px solid #5244a3;
  border-radius: 20px 20px 0 0;
  padding: 10px 0;
}

.modal__heading {
  color: #fff;
  font-size: clamp(20px, 1.35vw, 26px) !important;
  font-weight: bold;
  text-align: center;
}

.modal__close {
  position: absolute;
  transform: translateY(-50%);
  top: 50%;
  right: 20px;
  width: clamp(25px, 2.23vw, 43px);
  height: clamp(22px, 2.08vw, 40px);
  padding-bottom: 2px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #5244a3;
  font-size: clamp(22px, 1.66vw, 32px) !important;
  font-weight: bold;
  background-color: #fff;
  border-radius: 5px;
  cursor: pointer;
}

.modal__contents {
  width: 100%;
  border: 2px solid #5244a3;
  background: #ffffff;
  border-radius: 0 0 20px 20px;
  padding: clamp(25px, 2.6vw, 50px) 0;
}

.modal__contents-inner {
  width: 90%;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: clamp(15px, 1.56vw, 30px);
}

.modal__txt {
  font-size: clamp(14px, 0.83vw, 16px) !important;
}

.modal__list {
  display: flex;
  flex-direction: column;
  gap: 15px;
  background: #f1efff;
  border-radius: 20px;
  padding: clamp(15px, 1.56vw, 30px);
}

.modal__list li {
  position: relative;
  font-size: clamp(14px, 0.83vw, 16px) !important;
  padding-left: clamp(20px, 1.56vw, 30px);
}

.modal__list li::before {
  position: absolute;
  content: "";
  background: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2220%22%20height%3D%2220%22%20viewBox%3D%220%200%2020%2020%22%20fill%3D%22none%22%3E%3Cpath%20d%3D%22M8.40273%2013.9218L4.54545%2010.0636L5.83091%208.77818L8.40273%2011.3491L13.5445%206.20636L14.8309%207.49273L8.40273%2013.9218Z%22%20fill%3D%22%235244A3%22%2F%3E%3Cpath%20fill-rule%3D%22evenodd%22%20clip-rule%3D%22evenodd%22%20d%3D%22M0%2010C0%204.47727%204.47727%200%2010%200C15.5227%200%2020%204.47727%2020%2010C20%2015.5227%2015.5227%2020%2010%2020C4.47727%2020%200%2015.5227%200%2010ZM10%2018.1818C8.92555%2018.1818%207.86162%2017.9702%206.86895%2017.559C5.87629%2017.1478%204.97433%2016.5452%204.21458%2015.7854C3.45483%2015.0257%202.85216%2014.1237%202.44099%2013.131C2.02981%2012.1384%201.81818%2011.0745%201.81818%2010C1.81818%208.92555%202.02981%207.86162%202.44099%206.86895C2.85216%205.87629%203.45483%204.97433%204.21458%204.21458C4.97433%203.45483%205.87629%202.85216%206.86895%202.44099C7.86162%202.02981%208.92555%201.81818%2010%201.81818C12.17%201.81818%2014.251%202.68019%2015.7854%204.21458C17.3198%205.74897%2018.1818%207.83005%2018.1818%2010C18.1818%2012.17%2017.3198%2014.251%2015.7854%2015.7854C14.251%2017.3198%2012.17%2018.1818%2010%2018.1818Z%22%20fill%3D%22%235244A3%22%2F%3E%3C%2Fsvg%3E")
    no-repeat center;
  background-size: contain;
  width: clamp(14px, 0.98vw, 19px);
  height: clamp(14px, 0.98vw, 19px);
  transform: translateY(-50%);
  top: 50%;
  left: 0;
}

@media screen and (max-width: 1440px) {
  .modal__container {
    width: 70%;
  }
}

@media screen and (max-width: 767px) {
  .WhatEtcToll-contents {
    flex-direction: column;
  }
  .WhatEtcToll-contents img {
    width: 100%;
  }

  .WhatEtcToll-txt-area {
    width: 100%;
  }
  .WhatEtcToll-open button {
    width: 100%;
  }

  .modal__container {
    width: 90%;
  }
}

/* ===========ETC専用料金所マップ============== */

.map-info {
  margin: clamp(20px, 3.33vw, 40px) 0;
}

.map-info li {
  font-size: clamp(14px, 0.833vw, 16px);
}

.EtcTollMap-table-area {
  max-width: 700px;
  margin: 0 auto;
  margin-top: clamp(45px, 7.5vw, 90px);
}

.EtcTollMap-table-area table .asterisk {
  font-size: 12px;
  display: inline-block;
  margin-left: 5px;
}

.EtcTollMap-btn-wrap {
  display: flex;
  flex-direction: column;
  gap: clamp(15px, 2.5vw, 30px);
  margin-top: clamp(45px, 7.5vw, 90px);
}

.EtcTollMap-btn a,
.EtcTollMap-btn span {
  position: relative;
  display: block;
  width: auto;
  color: #a50319 !important;
  border: 2px solid #a50319;
  border-radius: 10px;
  padding: clamp(15px, 2vw, 25px) 30px;
  font-size: clamp(16px, 2vw, 24px);
  font-weight: 700;
  cursor: pointer;
}

.EtcTollMap-btn a::after,
.EtcTollMap-btn span::after {
  position: absolute;
  content: "";
  /* background: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2214%22%20viewBox%3D%220%200%2024%2014%22%20fill%3D%22none%22%3E%3Cpath%20d%3D%22M2%201.67334L12%2011.6733L22%201.67334%22%20stroke%3D%22%23A50319%22%20stroke-width%3D%223%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%2F%3E%3C%2Fsvg%3E")
    no-repeat center; */
  background-size: contain;
  width: 20px;
  height: 10px;
  transform: translateY(-50%);
  top: 50%;
  right: 30px;
}

.EtcTollMap-btn--blue a,
.EtcTollMap-btn--blue span {
  color: #1d238c !important;
  border: 2px solid #1d238c;
}

.EtcTollMap-btn--blue a::after,
.EtcTollMap-btn--blue span::after {
  background: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2214%22%20viewBox%3D%220%200%2024%2014%22%20fill%3D%22none%22%3E%3Cpath%20d%3D%22M2%2011.6733L12%201.67334L22%2011.6733%22%20stroke%3D%22%231D238C%22%20stroke-width%3D%223%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%2F%3E%3C%2Fsvg%3E")
    no-repeat center;
  background-size: contain;
}

@media screen and (max-width: 767px) {
  .EtcTollMap-btn a,
  .EtcTollMap-btn span {
    text-align: center;
    padding: 15px 0;
  }

  .EtcTollMap-btn a::after,
  .EtcTollMap-btn span::after {
    top: 50%;
    right: 15px;
  }

  .EtcTollMap-table-area table .asterisk {
    font-size: 10px;
    display: inline-block;
    margin-left: 5px;
  }
}

/* ===========ドライブコンパス============== */

.drive-compass {
  background: url("../etc/service/images/drive-compass-bg.webp") no-repeat
    center;
  background-size: cover;
  width: 100%;
  padding: clamp(50px, 5.2vw, 100px) 0 clamp(40px, 4.1vw, 80px);
}
.drive-compass .sModSecNormal {
  max-width: 840px;
  position: relative;
  text-align: center;
  padding: clamp(55px, 9.1vw, 110px) 0 clamp(35px, 5.83vw, 70px);
}

.drive-compass-ttl {
  width: 55%;
  position: absolute;
  color: #fff;
  font-size: clamp(13px, 1.83vw, 22px) !important;
  font-weight: 700;
  text-align: center;
  background: #5244a3;
  border-radius: 10px;
  padding: 20px 30px;
  transform: translateX(-50%);
  top: -15%;
  left: 50%;
}

.drive-compass-img a {
  display: inline-block;
  margin: 0 auto;
  border: 2px solid #ef7721;
  border-radius: 15px;
  box-shadow: 4px 4px 0 0 #ef7721;
  padding: clamp(15px, 2.5vw, 30px) clamp(35px, 5.83vw, 70px);
  transition: 0.25s all;
}

@media screen and (min-width: 1024px) {
  .drive-compass-img a:hover {
    box-shadow: none;
    transform: translateY(5px);
  }
}

.label-ttl {
  color: #5244a3;
  font-size: clamp(21px, 2.66vw, 32px) !important;
  font-weight: 900;
  text-align: center;
  background: #f1efff;
  padding: 10px 0;
}

@media screen and (max-width: 767px) {
  .drive-compass .sModSecNormal {
    max-width: none;
    width: 90%;
  }

  .drive-compass-ttl {
    width: 85%;
    padding: 10px 0;
  }

  .drive-compass-img a {
    width: 60%;
    margin: 0 auto;
  }
}

/* ===========faq============== */

.qa-wrap {
  margin-top: clamp(25px, 5vw, 60px);
  display: flex;
  flex-direction: column;
  gap: clamp(15px, 1.3vw, 25px);
  counter-reset: qa;
}

.qa-list {
  padding: clamp(20px, 1.041vw, 20px) clamp(15px, 1.5625vw, 30px);
  border-radius: 20px;
  border: 1px solid #D9D9D9;
}

.qa-ttl {
  font-size: clamp(17px, 1.041666666666667vw, 20px)!important;
  font-weight: 700;
  padding-left: clamp(43px, 3.75vw, 72px);
  padding-right: clamp(30px, 2.395vw, 46px);
  padding-top: clamp(10px, 0.963vw, 18.5px);
  padding-bottom: clamp(10px, 0.963vw, 18.5px);
  position: relative;
  cursor: pointer;
}

.qa-ttl::before {
  counter-increment: qa;
  content: "Q" counter(qa);
  font-family: "futura-pt";
  width: clamp(33px, 2.70vw, 52px);
  height: clamp(33px, 2.70vw, 52px);
  font-size: clamp(17px, 1.354vw, 26px);
  display: flex;
  align-items: center;
  justify-content: center;
  background: #5244A3;
  border-radius: 50%;
  color: #fff;
  font-weight: bold;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: 0;
}

.qa-ttl::after {
  content: "";
  background: url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyNyIgaGVpZ2h0PSIyNyIgdmlld0JveD0iMCAwIDI3IDI3IiBmaWxsPSJub25lIj48cGF0aCBkPSJNMjYuNjAxNiAxNS4yMDA5SDE1LjIwMDlWMjYuNjAxNkgxMS40MDA3VjE1LjIwMDlIMFYxMS40MDA3SDExLjQwMDdWMEgxNS4yMDA5VjExLjQwMDdIMjYuNjAxNlYxNS4yMDA5WiIgZmlsbD0iIzUyNDRBMyIvPjwvc3ZnPg==")no-repeat center center;
  background-size: contain;
  width: clamp(20px, 1.354vw, 26px);
  height: clamp(20px, 1.354vw, 26px);
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 0;

}

.qa-content {
  /* padding-left: 72px; */
  opacity: 0;
  border-top: 1px solid #D9D9D9;
  position: relative;
  font-size: clamp(14px, 0.833vw, 16px);
  line-height: 1.8;
  transition: 0.3s all;
  max-height: 0;
  overflow: hidden;
  display: flex;
  flex-direction: row-reverse;
  align-items: center;
  justify-content: flex-start;
  gap: clamp(10px, 1.041vw, 20px);
}

.qa-content::after {
  content: "A";
  font-family: "futura-pt";
  width: clamp(33px, 2.70vw, 52px);
  height: clamp(33px, 2.70vw, 52px);
  font-size: clamp(17px, 1.354vw, 26px);
  display: flex;
  align-items: center;
  justify-content: center;
  background: #fff;
  border: 2px solid #5244A3;
  border-radius: 50%;
  color: #5244A3;
  font-weight: bold;
}

.qa-answer {
  width: calc(100% - clamp(43px, 3.75vw, 72px));
}

.qa-answer ul {
  padding-left: clamp(20px, 1.041vw, 20px);
}
.qa-answer li {
  list-style: disc;
}

.qa-answer a {
  color: #000!important;
  text-decoration: underline!important;
  transition: 0.2s;
  color: #5244a3 !important;
}

.qa-answer a:hover {
  opacity: 0.7;
}

.qa-list.is-open .qa-content {
  max-height: 10000px;
  padding-top: 20px;
  margin-top: 20px;
  opacity: 1;
  
}

.qa-list.is-open .qa-ttl::after {
  content: "";
  background: url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyNyIgaGVpZ2h0PSI0IiB2aWV3Qm94PSIwIDAgMjcgNCIgZmlsbD0ibm9uZSI+IDxwYXRoIGQ9Ik0xNS4yMDA5IDMuODAwMjJIMjYuNjAxNlYwSDE1LjIwMDlIMTEuNDAwN0gwVjMuODAwMjJIMTEuNDAwN0gxNS4yMDA5WiIgZmlsbD0iIzUyNDRBMyIvPjwvc3ZnPg==") no-repeat center center;  
  background-size: contain;

}



/* ===========ETC専用料金所のご利用にあたって============== */

.EtcUse-contents {
  display: flex;
  flex-wrap: wrap;
  gap: 25px;
  margin-top: clamp(20px, 3.33vw, 40px);
}

.EtcUse-item {
  width: calc(33.333% - 60px);
  border: 1px solid #d9d9d9;
  border-radius: 20px;
  padding: clamp(15px, 2.5vw, 30px) clamp(18px, 1.66vw, 20px);
}

.EtcUse-item-ttl {
  font-size: clamp(18px, 1.66vw, 20px) !important;
  font-weight: 700;
  margin-bottom: clamp(10px, 1.66vw, 20px) !important;
}

.EtcUse-item-txt {
  font-size: clamp(14px, 1.33vw, 16px) !important;
}
.EtcUse-item-txt a {
  color: #2e2e2e !important;
  text-decoration: underline !important;
}

.EtcUse-item-btn {
  margin-top: clamp(15px, 2.5vw, 30px);
  text-align: center;
  display: flex;
  justify-content: center;
}

.EtcUse-item-btn a {
  position: relative;
  color: #fff !important;
  font-size: clamp(14px, 1.33vw, 16px) !important;
  background: #ef7721;
  border-radius: 50px;
  padding: 10px clamp(25px, 3.75vw, 45px) 10px clamp(15px, 2.08vw, 25px);
}

.EtcUse-item-btn a::after {
  position: absolute;
  content: "";
  background: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2215%22%20height%3D%2215%22%20viewBox%3D%220%200%2015%2015%22%20fill%3D%22none%22%3E%3Cpath%20d%3D%22M9.05556%200.585938V2.14149H11.8478L4.20222%209.78705L5.29889%2010.8837L12.9444%203.23816V6.03038H14.5V0.585938M12.9444%2013.0304H2.05556V2.14149H7.5V0.585938H2.05556C1.643%200.585938%201.24733%200.749826%200.955612%201.04155C0.663888%201.33327%200.5%201.72893%200.5%202.14149V13.0304C0.5%2013.4429%200.663888%2013.8386%200.955612%2014.1303C1.24733%2014.422%201.643%2014.5859%202.05556%2014.5859H12.9444C13.357%2014.5859%2013.7527%2014.422%2014.0444%2014.1303C14.3361%2013.8386%2014.5%2013.4429%2014.5%2013.0304V7.58594H12.9444V13.0304Z%22%20fill%3D%22white%22%2F%3E%3C%2Fsvg%3E")
    no-repeat center;
  background-size: contain;
  width: 14px;
  height: 14px;
  transform: translateY(-50%);
  top: 50%;
  right: clamp(10px, 1.66vw, 20px);
}

.EtcUse-item-img img {
  width: 100%;
}

@media screen and (max-width: 767px) {
  .EtcUse-contents {
    flex-direction: column;
  }

  .EtcUse-item {
    width: auto;
  }
}

/* ===========テーブルアコーディオン============== */

.table-asterisk {
  font-size: 14px!important;
  margin-bottom: 30px!important;
}

.table-ac .EtcTollMap-btn span::after {
  transform: translateY(-50%) rotate(180deg);
  transition: 0.2s;
}

.table-ac__item {
  max-height: 0;
  overflow: hidden;
  transition: 0.3s;
  opacity: 0;
}

.table-ac.is-open .EtcTollMap-btn span::after {
  transform: translateY(-50%) rotate(0deg);
}

.table-ac.is-open .table-ac__item {
  max-height: 10000px;
  opacity: 1;

}

@media screen and (max-width: 767px) {
  .table-asterisk {
    font-size: 12px!important;
    margin-bottom: 20px!important;
  }
}

/* ===========誤ってETC専用料金所に入ってしまった場合============== */

.attention-ttl span {
  display: inline-block;
  position: relative;

}

.attention-ttl span::after {
  content: "";
  background: url(../etc/service/images/attention-ttl_deco.png)no-repeat center center;
  background-size: contain;
  width: clamp(60px, 5.93vw, 114px);
  height: clamp(60px, 5.93vw, 114px);
  position: absolute;
  top: 40%;
  transform: translateY(-50%);
  left: clamp(-130px, -18.33vw, -240px);
  left: -20%;

}

.attention-sub-ttl {
  font-size: clamp(18px, 2.33vw, 28px) !important;
  font-weight: 700;
  text-align: center;
  margin: clamp(20px, 3.33vw, 40px) 0 clamp(20px, 2.604vw, 50px) !important;
}

.attention-area {
  width: 90%;
  margin: 0 auto;
}

.attention-label {
  color: #f00;
  font-size: clamp(16px, 1.66vw, 20px) !important;
  font-weight: 700;
  background: #ffe3e3;
  border-radius: 10px;
  padding: 10px 0;
  text-align: center;
}

.attention-txt {
  font-size: clamp(14px, 1.33vw, 16px) !important;
  text-align: center;
  margin-top: 20px;
}

.attention-img {
  display: flex;
  gap: clamp(25px, 4.16vw, 50px);
  margin-top: clamp(25px, 4.16vw, 50px);
}

.attention-img img {
  width: calc(50% - 25px);
}

@media screen and (max-width: 767px) {
  .attention-ttl span::after {
    top: 0%;
    transform: translateY(-80%);
    left: -14%;
  }
  .attention-area {
    width: 100%;
  }
  .attention-txt {
    text-align: left;
  }
  .attention-img {
    flex-direction: column;
  }
}

/* ===========ETC専用化のメリット============== */

.merit-wrap {
  display: flex;
  flex-wrap: wrap;
  gap: 0 30px;
  margin-top: clamp(25px, 5vw, 60px);
}

.merit-wrap li {
  width: calc(33.333% - 20px);
  display: flex;
  flex-direction: column;
  gap: clamp(15px, 2.5vw, 30px);
}

.merit-ttl {
  font-size: clamp(18px, 2vw, 24px) !important;
  font-weight: 700;
  text-align: center;
}

.merit-txt {
  font-size: clamp(14px, 1.33vw, 16px) !important;
}

.merit-img {
  position: relative;
}

.merit-img img {
  width: 100%;
}

.merit-point {
  position: absolute;
  font-family: "futura-pt";
  color: #fff;
  background: #5244a3;
  width: clamp(60px, 6.25vw, 75px);
  height: clamp(60px, 6.25vw, 75px);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  border-radius: 100%;
  font-size: clamp(12px, 1.25vw, 15px);
  text-align: center;
  font-weight: 600;
  top: -25px;
  left: -20px;
}
.merit-point span {
  font-size: clamp(26px, 2.75vw, 33px);
  line-height: 1;
}

@media screen and (max-width: 767px) {
  .merit-wrap {
    width: 90%;
    margin: 25px auto 0;
    flex-direction: column;
    gap: 35px 0;
  }

  .merit-wrap li {
    width: auto;
  }
}

/* ===========関連リンク============== */

.link-wrap {
  display: flex;
  flex-wrap: wrap;
  gap: 0 30px;
  margin-top: clamp(25px, 3.33vw, 40px);
}

.link-wrap li {
  width: calc(33.333% - 20px);
}

.link-wrap a {
  color: #000 !important;
  display: flex;
  flex-direction: column;
  gap: clamp(10px, 1.33vw, 16px) 0;
}

.link-img {
  overflow: hidden;
  border-radius: 10px;
}

.link-img img {
  transition: 0.25s all;
  width: 100%;
}

@media screen and (min-width: 1024px) {
  .link-wrap a:hover {
    text-decoration: none !important;
  }
  .link-wrap a:hover img {
    scale: 1.1;
  }
}

.link-ttl {
  color: #5244a3;
  font-size: clamp(17px, 2vw, 24px) !important;
  font-weight: 700;
}

.link-txt {
  font-size: clamp(14px, 1.33vw, 16px) !important;
}

@media screen and (max-width: 767px) {
  .link.section {
    width: 90%;
  }

  .link-wrap {
    flex-direction: column;
    gap: 25px 0;
  }

  .link-wrap li {
    width: auto;
  }
}

@media screen and (max-width: 767px) {
  .map-info {
    margin-bottom: 20px;
  }
}

@media screen and (max-width: 1000px) {
  div#dBreadCrumbs,
  div#dMain,
  div#dKeyVisual,
  div#dAside {
    width: 100% !important;
    margin: 0 auto;
  }
  div#dEmergency {
    width: 90%;
  }
  div#dEmergency div.dOpenBox p.pModEleRight {
    width: 90%;
  }
  div#dFavorite div.dOpenBox p.pModEleRight {
    width: 90%;
  }
  div#fGlobalFooter {
    width: 90%;
  }
  div#hGlobalHeader,
  div#nHeaderNav {
    width: 90%;
  }
  div.nGlobalNav {
    width: 90%;
  }
  div#nGlobalNav {
    width: 90%;
  }
  div#dFavorite div.dOpenBox div.dOpenDisp div.dFLWrapper div.dFavoriteLower {
    width: 90%;
  }
  div#dBreadCrumbs,
  div#dMain,
  div#dAside {
    width: 90%;
  }
  div#dAside {
    width: 90%;
  }
  div#dMain div#dMainH1 {
    width: 90%;
  }
  body.nosubnavi div#dMainColumn {
    width: 90%;
  }
  .global--area {
    min-width: 90%;
  }
  .global--area .inner,
  .rn .inner,
  footer .inner,
  header .inner {
    width: 100%;
  }
  /* .content.rn .pagetop--area {
        width: 90%;
    } */
  .div#aMainContents.article {
    width: 100%;
  }
  .rn .important--area {
    width: 100%;
  }
  footer .footer_sitemap--area {
    min-width: 90%;
  }

  .global--area .sf-menu .level--1 > a {
    font-size: 1.2rem;
  }
  header .inner {
    width: 95%;
    margin: 0 auto;
  }

  footer .inner {
    width: 95%;
    margin: 0 auto;
  }
  footer .footer_utility--area .footer_utility--nav {
    font-size: 1.1rem;
  }
  .content.rn .pagetop--area {
    width: 96%;
  }

  /* .content.rn {
        width: 96%;
        margin: 0 auto;
    } */
}
/* @media screen and (min-width: 768px) {
    .content.rn {
        width: 96%;
        margin: 0 auto;
    }
} */
@media screen and (max-width: 767px) {
  div#dBreadCrumbs,
  div#dAside {
    width: 96% !important;
    margin: 0 auto;
  }
  header .inner {
    width: 100%;
  }

  footer .inner {
    width: 100%;
  }
  .global--area {
    /* min-width: %!important; */
    width: 95%;
    margin: 0 auto;
  }
  footer .footer_sitemap--nav {
    width: 95%;
    margin: 0 auto;
  }
  /* .content.rn {
        width: 95%;
        margin: 0 auto;
    } */
  /* .global--area .inner, .rn .inner, footer .inner, header .inner {
        width: 100%;
    } */
  #dMain {
    width: 96% !important;
  }
}
