@import url("https://fonts.googleapis.com/css2?family=Zen+Maru+Gothic&display=swap");
/*------------------------------------*\
    breakpoint vars
\*------------------------------------*/
/*------------------------------------*\
    breakpoint mixin
\*------------------------------------*/
/** Break desktop first**/
:root {
  --base-width: 800;
}

@media (min-width: 768px) {
  :root {
    --base-width: 1920;
  }
}
.scroll-menu ul {
  margin: 0;
  padding: 0;
  list-style: none;
}

.content-more__button h4, .content-more__button h5, .content-more h3, .faqs__item--suggest h4, .faqs__item > h3, .points__box h3, .solves h2, .about__row h3, .section-heading h2, .section-heading h3 {
  padding: 0;
  margin: 0;
  border: 0;
}
.content-more__button h4::before, .content-more__button h5::before, .content-more h3::before, .faqs__item--suggest h4::before, .faqs__item > h3::before, .points__box h3::before, .solves h2::before, .about__row h3::before, .section-heading h2::before, .section-heading h3::before, .content-more__button h4::after, .content-more__button h5::after, .content-more h3::after, .faqs__item--suggest h4::after, .faqs__item > h3::after, .points__box h3::after, .solves h2::after, .about__row h3::after, .section-heading h2::after, .section-heading h3::after {
  display: none;
}

body {
  /*
  &.admin-bar {
      .scroll-menu {
          @include breakpoint(992px) {
              top: 85px;
          }
      }
  } */
}
body.is-tpms-page {
  overflow: visible;
}

.container-new {
  padding-inline: calc(40 / var(--base-width) * 100vw);
  max-width: 1130px;
  margin-inline: auto;
}
@media only screen and (min-width: 768px) {
  .container-new {
    padding-inline: 20px;
  }
}

.text-red {
  color: #e71f1c;
}

.section--yellow {
  background: #f5a518;
}
.section--green {
  background: #2b9e4d;
}

.section-heading {
  font-family: "source-han-sans-japanese", sans-serif;
  text-align: center;
  margin-bottom: calc(60 / var(--base-width) * 100vw);
}
@media only screen and (min-width: 768px) {
  .section-heading {
    margin-bottom: 60px;
  }
}
.section-heading h3 {
  font-size: calc(24 / var(--base-width) * 100vw);
  font-weight: 700;
  color: #2b9e4d;
  line-height: 1.4;
  margin: 0 0 calc(15 / var(--base-width) * 100vw);
}
@media only screen and (min-width: 768px) {
  .section-heading h3 {
    font-size: 20px;
    margin: 0 0 12px;
  }
}
@media only screen and (min-width: 992px) {
  .section-heading h3 {
    font-size: 24px;
  }
}
.section-heading h2 {
  font-size: calc(51 / var(--base-width) * 100vw);
  font-weight: 700;
  line-height: 1.2;
}
@media only screen and (min-width: 768px) {
  .section-heading h2 {
    font-size: 36px;
  }
}
@media only screen and (min-width: 992px) {
  .section-heading h2 {
    font-size: 51px;
  }
}
.section-heading--white h2,
.section-heading--white h3 {
  color: #fff;
}

@media only screen and (min-width: 768px) {
  .hide-pc {
    display: none;
  }
}

@media only screen and (max-width: 767px) {
  .hide-sp {
    display: none;
  }
}

.banner picture {
  display: block;
}
.banner picture img {
  display: block;
  width: 100%;
}

.scroll-menu {
  background: #2b9e4d;
  font-family: "source-han-sans-japanese", sans-serif;
  /*
  @include breakpoint(992px) {
      position: sticky;
      top: 52px;
      z-index: 20;
  }
      */
}
.scroll-menu ul {
  display: flex;
}
.scroll-menu ul li {
  flex-basis: 0;
  flex-grow: 1;
  margin: 0;
}
.scroll-menu ul li a {
  color: #fff;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: calc(8 / var(--base-width) * 100vw);
  font-weight: 700;
  font-size: calc(22 / var(--base-width) * 100vw);
  min-height: calc(108 / var(--base-width) * 100vw);
}
@media only screen and (min-width: 768px) {
  .scroll-menu ul li a {
    flex-direction: row;
    font-size: 20px;
    min-height: 75px;
    gap: 12px;
  }
}
.scroll-menu ul li a::after {
  content: "";
  width: calc(21 / var(--base-width) * 100vw);
  height: calc(23 / var(--base-width) * 100vw);
  background: url("../images/tpms/arrow-double.png") no-repeat 0 0/100%;
}
@media only screen and (min-width: 768px) {
  .scroll-menu ul li a::after {
    width: 15px;
    height: 16px;
  }
}
.scroll-menu ul li a:hover {
  text-decoration: none;
  opacity: 0.8;
  color: #fff;
}
.scroll-menu ul li.active a {
  background: #f5a518;
}

.about-section {
  padding-block: calc(80 / var(--base-width) * 100vw) calc(10 / var(--base-width) * 100vw);
  font-family: "source-han-sans-japanese", sans-serif;
  background: #fff;
}
@media only screen and (min-width: 768px) {
  .about-section {
    padding-block: 50px 10px;
  }
}

.about__row {
  padding-block: calc(65 / var(--base-width) * 100vw);
  font-size: calc(26 / var(--base-width) * 100vw);
  line-height: 1.92;
}
@media only screen and (min-width: 768px) {
  .about__row {
    padding-left: 15px;
    padding-block: 65px;
    font-size: 18px;
    line-height: 1.77;
  }
}
.about__row + .about__row {
  border-top: 1px solid #F5A518;
}
.about__row h3 {
  font-size: calc(45 / var(--base-width) * 100vw);
  font-weight: 700;
  color: #2b9e4d;
  line-height: 1.2;
  margin: 0 0 calc(14 / var(--base-width) * 100vw);
}
@media only screen and (min-width: 768px) {
  .about__row h3 {
    font-size: 36px;
    margin: 0 0 12px -15px;
  }
}
@media only screen and (min-width: 992px) {
  .about__row h3 {
    font-size: 45px;
  }
}
.about__row h3 span {
  font-family: futura-pt, sans-serif;
  font-size: calc(60 / var(--base-width) * 100vw);
  font-weight: 500;
  margin-right: calc(8 / var(--base-width) * 100vw);
  display: inline-block;
  line-height: 1;
}
@media only screen and (min-width: 768px) {
  .about__row h3 span {
    font-size: 60px;
    margin-right: 8px;
  }
}
@media only screen and (min-width: 992px) {
  .about__row h3 span {
    font-size: 80px;
  }
}
.about__row p {
  margin: 0 0 calc(50 / var(--base-width) * 100vw);
}
@media only screen and (min-width: 768px) {
  .about__row p {
    margin: 0 0 26px;
  }
}
.about__row p:last-of-type {
  margin: 0;
}
.about__row p small {
  font-size: calc(22 / var(--base-width) * 100vw);
}
@media only screen and (min-width: 768px) {
  .about__row p small {
    font-size: 16px;
  }
}
.about__row > figure {
  text-align: center;
  margin-top: calc(70 / var(--base-width) * 100vw);
}
@media only screen and (min-width: 768px) {
  .about__row > figure {
    margin-top: 60px;
  }
}
.about__logo {
  display: flex;
  margin-bottom: calc(12 / var(--base-width) * 100vw);
  align-items: flex-end;
  gap: calc(30 / var(--base-width) * 100vw);
  font-weight: 700;
}
@media only screen and (min-width: 768px) {
  .about__logo {
    margin-bottom: 12px;
    gap: 18px;
  }
}
.about__logo img {
  max-width: calc(452 / var(--base-width) * 100vw);
}
@media only screen and (min-width: 768px) {
  .about__logo img {
    max-width: 323px;
  }
}
.about__logo p {
  margin: 0;
}
.about__image {
  margin-top: calc(56 / var(--base-width) * 100vw);
}
@media only screen and (min-width: 768px) {
  .about__image {
    margin-top: 26px;
    display: grid;
    grid-template-columns: 1fr 175px;
    gap: 0 30px;
  }
}
.about__image figure {
  margin: 0;
  text-align: center;
  margin-bottom: calc(26 / var(--base-width) * 100vw);
}
@media only screen and (min-width: 768px) {
  .about__image figure {
    grid-column: 2/3;
    grid-row: 1/4;
    margin-bottom: 0;
  }
}
@media only screen and (min-width: 768px) {
  .about__image figure img {
    width: 100%;
  }
}

.solves {
  font-family: "source-han-sans-japanese", sans-serif;
  position: relative;
  padding-block: calc(110 / var(--base-width) * 100vw) calc(100 / var(--base-width) * 100vw);
  background: #E5F3E9;
}
@media only screen and (min-width: 768px) {
  .solves {
    padding-block: 165px 150px;
  }
}
.solves::before {
  content: "";
  clip-path: polygon(100% 0, 0 0, 50% 100%);
  position: absolute;
  top: -1px;
  left: 0;
  width: 100%;
  height: calc(50 / var(--base-width) * 100vw);
  background: #fff;
  z-index: 2;
}
@media only screen and (min-width: 768px) {
  .solves::before {
    height: 90px;
  }
}
.solves h2 {
  text-align: center;
  font-size: calc(38 / var(--base-width) * 100vw);
  font-weight: 700;
  margin: 0 0 calc(15 / var(--base-width) * 100vw);
}
@media only screen and (min-width: 768px) {
  .solves h2 {
    margin: 0 0 15px;
    font-size: 38px;
  }
}
.solves figure {
  text-align: center;
  font-size: calc(24 / var(--base-width) * 100vw);
  margin: 0 0 calc(40 / var(--base-width) * 100vw);
}
@media only screen and (min-width: 768px) {
  .solves figure {
    font-size: 24px;
    margin: 0 0 50px;
  }
}
.solves figure img {
  max-width: calc(550 / var(--base-width) * 100vw);
}
@media only screen and (min-width: 768px) {
  .solves figure img {
    max-width: 550px;
  }
}
.solves figure figcaption {
  margin-top: calc(4 / var(--base-width) * 100vw);
}
@media only screen and (min-width: 768px) {
  .solves figure figcaption {
    margin-top: 2px;
  }
}
.solves picture {
  display: block;
  text-align: center;
}

.points {
  font-family: "source-han-sans-japanese", sans-serif;
  padding-block: calc(90 / var(--base-width) * 100vw) calc(130 / var(--base-width) * 100vw);
}
@media only screen and (min-width: 768px) {
  .points {
    padding-block: 90px 160px;
  }
}
.points__box {
  border-radius: 15px;
  padding: calc(30 / var(--base-width) * 100vw) calc(20 / var(--base-width) * 100vw) calc(40 / var(--base-width) * 100vw);
  background: #fff;
  box-shadow: 0 0 calc(9 / var(--base-width) * 100vw) calc(18 / var(--base-width) * 100vw) rgba(0, 0, 0, 0.1);
  font-size: calc(26 / var(--base-width) * 100vw);
  line-height: 1.4;
}
@media only screen and (min-width: 768px) {
  .points__box {
    padding: 30px 15px 40px;
    box-shadow: 0 0 9px 18px rgba(0, 0, 0, 0.1);
    text-align: center;
    font-size: 20px;
  }
}
@media only screen and (min-width: 992px) {
  .points__box {
    font-size: 26px;
  }
}
.points__box.points__box {
  margin-top: calc(40 / var(--base-width) * 100vw);
}
@media only screen and (min-width: 768px) {
  .points__box.points__box {
    margin-top: 30px;
  }
}
.points__box h3 {
  text-align: center;
  font-weight: 700;
  border-bottom: calc(3 / var(--base-width) * 100vw) solid #f5a518;
  padding-bottom: calc(12 / var(--base-width) * 100vw);
  margin: 0 0 calc(36 / var(--base-width) * 100vw);
  line-height: 1.3;
  font-size: calc(41 / var(--base-width) * 100vw);
}
@media only screen and (min-width: 768px) {
  .points__box h3 {
    font-size: 32px;
    padding-bottom: 12px;
    margin: 0 0 30px;
    border-bottom-width: 3px;
  }
}
@media only screen and (min-width: 992px) {
  .points__box h3 {
    font-size: 41px;
  }
}
.points__box h3 span {
  color: #2b9e4d;
}
.points__box small {
  font-size: calc(20 / var(--base-width) * 100vw);
}
@media only screen and (min-width: 768px) {
  .points__box small {
    font-size: 15px;
  }
}
@media only screen and (min-width: 992px) {
  .points__box small {
    font-size: 17px;
  }
}

.faqs {
  font-family: "source-han-sans-japanese", sans-serif;
  background: #fff;
  padding-block: calc(100 / var(--base-width) * 100vw) calc(130 / var(--base-width) * 100vw);
}
@media only screen and (min-width: 768px) {
  .faqs {
    padding-block: 110px 150px;
  }
}
.faqs__item > h3 {
  font-size: calc(28 / var(--base-width) * 100vw);
  font-weight: 700;
  padding: calc(40 / var(--base-width) * 100vw) calc(75 / var(--base-width) * 100vw) calc(40 / var(--base-width) * 100vw) calc(20 / var(--base-width) * 100vw);
  display: flex;
  align-items: center;
  gap: calc(20 / var(--base-width) * 100vw);
  background: url("../images/tpms/plus.png") no-repeat calc(100% - 15px) 50%/calc(37 / var(--base-width) * 100vw);
  cursor: pointer;
}
@media only screen and (min-width: 768px) {
  .faqs__item > h3 {
    background-position: calc(100% - 25px) 50%;
    background-size: 25px;
    gap: 20px;
    font-size: 28px;
    padding: 40px 70px 40px 15px;
  }
}
.faqs__item > h3::before {
  content: "Q";
  width: calc(78 / var(--base-width) * 100vw);
  min-width: calc(78 / var(--base-width) * 100vw);
  height: calc(78 / var(--base-width) * 100vw);
  font-family: "Zen Maru Gothic", sans-serif;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: calc(38 / var(--base-width) * 100vw);
  background: #f5a518;
  color: #fff;
  border-radius: 50%;
  font-weight: 700;
  line-height: 1;
}
@media only screen and (min-width: 768px) {
  .faqs__item > h3::before {
    width: 80px;
    min-width: 80px;
    height: 80px;
    font-size: 38px;
  }
}
.faqs__item p {
  margin-bottom: 26px;
}
.faqs__item p:last-of-type {
  margin-bottom: 0;
}
.faqs__item--body {
  background: #E5F3E9;
  display: none;
  font-size: calc(23 / var(--base-width) * 100vw);
  line-height: 1.565;
}
@media only screen and (min-width: 768px) {
  .faqs__item--body {
    font-size: 18px;
    line-height: 1.8;
  }
}
@media only screen and (min-width: 992px) {
  .faqs__item--body {
    font-size: 20px;
  }
}
.faqs__item--answer {
  padding: calc(40 / var(--base-width) * 100vw) calc(35 / var(--base-width) * 100vw) calc(40 / var(--base-width) * 100vw) calc(118 / var(--base-width) * 100vw);
  min-height: calc(160 / var(--base-width) * 100vw);
  position: relative;
  display: flex;
  align-items: center;
}
@media only screen and (min-width: 768px) {
  .faqs__item--answer {
    padding: 40px 35px 40px 115px;
    min-height: 160px;
  }
}
.faqs__item--answer::before {
  content: "A";
  width: calc(78 / var(--base-width) * 100vw);
  min-width: calc(78 / var(--base-width) * 100vw);
  height: calc(78 / var(--base-width) * 100vw);
  font-family: "Zen Maru Gothic", sans-serif;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: calc(38 / var(--base-width) * 100vw);
  background: #fff;
  color: #000;
  border-radius: 50%;
  position: absolute;
  left: calc(15 / var(--base-width) * 100vw);
  top: calc(40 / var(--base-width) * 100vw);
  font-weight: 700;
  line-height: 1;
}
@media only screen and (min-width: 768px) {
  .faqs__item--answer::before {
    width: 80px;
    min-width: 80px;
    height: 80px;
    font-size: 38px;
    left: 15px;
    top: 50%;
    transform: translateY(-50%);
  }
}
.faqs__item--suggest {
  padding: calc(50 / var(--base-width) * 100vw) calc(50 / var(--base-width) * 100vw) calc(35 / var(--base-width) * 100vw) calc(118 / var(--base-width) * 100vw);
  background: url("../images/tpms/light.png") no-repeat calc(40 / var(--base-width) * 100vw) calc(35 / var(--base-width) * 100vw)/calc(45 / var(--base-width) * 100vw) #FDF3E2;
  font-weight: 500;
}
@media only screen and (min-width: 768px) {
  .faqs__item--suggest {
    background-size: 45px;
    background-position: 40px 35px;
    padding: 50px 50px 35px 115px;
  }
}
.faqs__item--suggest h4 {
  font-size: calc(30 / var(--base-width) * 100vw);
  font-weight: 700;
  color: #f5a518;
  margin: 0 0 calc(15 / var(--base-width) * 100vw);
}
@media only screen and (min-width: 768px) {
  .faqs__item--suggest h4 {
    font-size: 24px;
    margin: 0 0 15px;
  }
}
@media only screen and (min-width: 992px) {
  .faqs__item--suggest h4 {
    font-size: 30px;
  }
}
.faqs__item--suggest p img {
  vertical-align: baseline;
  margin: 0 calc(5 / var(--base-width) * 100vw);
  height: calc(32 / var(--base-width) * 100vw);
}
@media only screen and (min-width: 768px) {
  .faqs__item--suggest p img {
    height: 24px;
    margin: 0 5px;
  }
}
@media only screen and (min-width: 992px) {
  .faqs__item--suggest p img {
    height: 29px;
  }
}
.faqs__item--suggest > figure {
  margin: calc(50 / var(--base-width) * 100vw) 0 0;
}
@media only screen and (min-width: 768px) {
  .faqs__item--suggest > figure {
    margin-top: 35px;
  }
}
.faqs__item--media {
  display: grid;
  gap: calc(32 / var(--base-width) * 100vw);
  grid-template-columns: 1fr;
}
@media only screen and (min-width: 768px) {
  .faqs__item--media {
    grid-template-columns: 1fr 210px;
    gap: 20px;
  }
}
@media only screen and (min-width: 768px) {
  .faqs__item--media-md {
    grid-template-columns: 1fr 275px;
    gap: 20px;
  }
}
.faqs__item.show > h3 {
  background-image: url("../images/tpms/minus.png");
}

.content-more {
  padding-block: calc(100 / var(--base-width) * 100vw) calc(80 / var(--base-width) * 100vw);
  font-family: "source-han-sans-japanese", sans-serif;
  text-align: center;
  color: #fff;
  font-weight: 500;
  font-size: calc(23 / var(--base-width) * 100vw);
  line-height: 1.826;
}
@media only screen and (min-width: 768px) {
  .content-more {
    padding-block: 75px 65px;
    font-size: 18px;
    line-height: 1.7;
  }
}
@media only screen and (min-width: 992px) {
  .content-more {
    font-size: 20px;
  }
}
.content-more p {
  margin-bottom: calc(42 / var(--base-width) * 100vw);
}
@media only screen and (min-width: 768px) {
  .content-more p {
    margin-bottom: 28px;
  }
}
@media only screen and (min-width: 992px) {
  .content-more p {
    margin-bottom: 34px;
  }
}
.content-more h3 {
  font-size: calc(26 / var(--base-width) * 100vw);
  color: #ffe63d;
  font-weight: 700;
  line-height: 1.416;
}
@media only screen and (min-width: 768px) {
  .content-more h3 {
    font-size: 20px;
  }
}
@media only screen and (min-width: 992px) {
  .content-more h3 {
    font-size: 24px;
  }
}
.content-more__button {
  margin-top: calc(50 / var(--base-width) * 100vw);
}
@media only screen and (min-width: 768px) {
  .content-more__button {
    margin-top: 55px;
  }
}
.content-more__button h5 {
  font-size: calc(20 / var(--base-width) * 100vw);
  font-weight: 400;
  margin: 0 0 calc(12 / var(--base-width) * 100vw);
}
@media only screen and (min-width: 768px) {
  .content-more__button h5 {
    font-size: 18px;
    margin: 0 0 15px;
  }
}
.content-more__button h4 {
  font-size: calc(22 / var(--base-width) * 100vw);
  font-weight: 700;
  margin: calc(18 / var(--base-width) * 100vw) 0 0;
}
@media only screen and (min-width: 768px) {
  .content-more__button h4 {
    font-size: 22px;
    margin: 20px 0 0;
  }
}
.content-more__button a {
  width: 100%;
  max-width: calc(495 / var(--base-width) * 100vw);
  min-height: calc(99 / var(--base-width) * 100vw);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #fff;
  border-radius: 999px;
  box-shadow: 0 calc(6 / var(--base-width) * 100vw) 0 0 #205730;
}
@media only screen and (min-width: 768px) {
  .content-more__button a {
    max-width: 495px;
    min-height: 99px;
    box-shadow: 0 6px 0 0 #205730;
  }
}
.content-more__button a img {
  max-width: calc(336 / var(--base-width) * 100vw);
}
@media only screen and (min-width: 768px) {
  .content-more__button a img {
    max-width: 336px;
  }
}
.content-more__button a:hover {
  opacity: 0.8;
}

.btn-contact {
  padding-block: calc(80 / var(--base-width) * 100vw);
  background: #F1F1F1;
  text-align: center;
}
@media only screen and (min-width: 768px) {
  .btn-contact {
    padding-block: 60px 80px;
  }
}
.btn-contact .btn_02 {
  max-width: calc(372 / var(--base-width) * 100vw);
  font-weight: 700;
  text-decoration: none;
  min-height: calc(90 / var(--base-width) * 100vw);
  padding: calc(10 / var(--base-width) * 100vw) calc(20 / var(--base-width) * 100vw);
  width: 100%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: calc(22 / var(--base-width) * 100vw);
}
@media only screen and (min-width: 768px) {
  .btn-contact .btn_02 {
    max-width: 470px;
    min-height: 62px;
    padding: 10px 20px;
    font-size: 18px;
  }
}

/*# sourceMappingURL=tpms.css.map */
