@charset "UTF-8";
.kv {
  border: none;
  padding: 0;
  width: 100vw;
  margin: 0 calc(50% - 50vw) 2em;
  text-align: center;
}
.kv img {
  margin: 0 auto;
  display: block;
}
.kv-company-wrap {
  padding: 1em;
  max-width: 640px;
  margin: 0 auto;
}
.kv-company {
  color: var(--deep-blue);
  padding: 1em;
  border: solid 2px var(--orange);
  border-radius: 10px;
}
.kv-company-txt {
  margin-bottom: 0.5em;
}
.kv-company img {
  max-width: 480px;
}

/* 見積ボタンエリア */
.estimate-wrap {
  display: flex;
  flex-direction: column;
  max-width: 780px;
  margin: 0 auto;
}
@media screen and (min-width: 769px) {
  .estimate-wrap {
    flex-direction: row;
  }
}
@media screen and (min-width: 769px) {
  .estimate {
    width: 50%;
  }
}
.estimate-ttl {
  font-weight: bold;
  text-align: center;
  font-size: 20px;
  margin-bottom: 0.5em;
}
.estimate-button-area {
  display: flex;
  flex-wrap: wrap;
  flex-direction: column;
}
.estimate-button {
  background: var(--orange);
  border: 1px solid var(--orange);
  font-weight: 600;
  height: 50px;
  font-size: 16px;
  color: #fff;
  border-radius: 5px;
  display: block;
  text-align: center;
  width: 100%;
  max-width: 500px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
}
@media screen and (min-width: 769px) {
  .estimate-button {
    max-width: 340px;
  }
}
@media screen and (min-width: 769px) {
  .estimate-button {
    font-size: 18px;
    height: 60px;
  }
}
.estimate-button+.estimate-button {
  margin-top: 1em;
}
.estimate-button span+span {
  font-size: 80%;
}
.estimate-button.inversion {
  background: #fff;
  color: var(--orange);
}
.estimate-button.inversion {
  background: #fff;
  color: var(--orange);
}

/* ご契約の方 */
.contracted {
  margin-top: 2em;
}
@media screen and (min-width: 769px) {
  .contracted {
    margin-top: 0;
    border-left: solid 1px #ccc;
  }
}
.contracted .estimate-button {
  background: var(--deep-blue);
  border-color: var(--deep-blue);
}
.contracted .estimate-button.inversion.two-more {
  border-color: var(--deep-blue);
  color: var(--deep-blue);
  background: #fff;
}
.contracted .estimate-button.inversion.emergency {
  border-color: var(--deep-red);
  color: var(--deep-red);
  background: #fff;
}

.consultation-tel-wrap {
  padding: 1em 0;
  font-weight: bold;
  margin-top: 1em;
}
.consultation-tel-ttl {
  margin-bottom: 0.5em;
  text-align: center;
}
@media screen and (min-width: 769px) {
  .consultation-tel-ttl {
    font-size: 18px;
  }
}
.consultation-tel {
  border: solid 1px var(--orange);
  padding: 1em 0.5em;
  border-radius: 4px;
  width: 90%;
  max-width: 500px;
  margin: 0 auto;
}
@media screen and (min-width: 769px) {
  .consultation-tel {
    display: flex;
    justify-content: center;
    align-items: center;
  }
}
.consultation-tel .df {
  justify-content: center;
  align-items: center;
}
.consultation-tel-mark {
  text-align: center;
  background: var(--orange);
  color: #fff;
  display: inline-block;
  padding: 0.5em;
  font-size: 10px;
  font-weight: normal;
  margin-right: 1em;
}
.consultation-tel .call {
  color: var(--orange);
  font-size: 24px;
}
@media screen and (min-width: 769px) {
  .consultation-tel .call {
    margin-right: 0.5em;
  }
}
.consultation-tel-time {
  font-weight: normal;
  font-size: 12px;
  margin-top: 1em;
  text-align: center;
}
@media screen and (min-width: 769px) {
  .consultation-tel-time {
    margin-top: 0;
  }
}
.three-point {
  margin-left: auto;
  margin-right: auto;
}
.three-point .h2-ttl {
  margin-bottom: 0.5em;
  text-align: center;
  font-weight: 600;
}
.three-point .h2-ttl span {
  background: linear-gradient(transparent 60%, #fcf69f 60%);
}
.three-point-anc {
  display: flex;
  flex-direction: column;
}
@media screen and (min-width: 769px) {
  .three-point-anc {
    flex-direction: row;
    justify-content: space-around;
  }
}
.three-point-anc a {
  border: solid 1px #ccc;
  font-size: 20px;
  font-size: min(6.25vw, 20px);
  line-height: 1;
  width: 100%;
  max-width: 500px;
  text-align: center;
  position: relative;
  border-radius: 4px;
  padding: 0.75em 16px;
  font-weight: bold;
  background: linear-gradient(to bottom, #fdfbfb 0%, #ebedee 100%);
  box-shadow: inset 1px 1px 1px #fff;
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin: 0 auto;
}
@media screen and (min-width: 769px) {
  .three-point-anc a {
    width: calc(100% / 3 - 20px);
    line-height: 1.2;
  }
}
.three-point-anc a+a {
  margin-top: 10px;
}
@media screen and (min-width: 769px) {
  .three-point-anc a+a {
    margin-top: 0;
  }
}
.three-point-anc i {
  font-family: "Segoe UI", Meiryo, system-ui, -apple-system, BlinkMacSystemFont, sans-serif;
  font-weight: bold;
  font-size: 36px;
  color: var(--orange);
  background: linear-gradient(180deg, #fff 0%, var(--orange) 40%, var(--deep-red) 90%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}
.three-point-anc a:after {
  content: "";
  width: 0.6em;
  height: 0.6em;
  border-right: solid 2px var(--orange);
  border-bottom: solid 2px var(--orange);
  transform: rotate(45deg);
}
.three-point-anc-txt {
  padding-top: 6px;
}
@media screen and (min-width: 769px) {
  .three-point-anc-txt {
    margin: 0 5px;
  }
}

.bn-anshinwatcher {
  max-width: 780px;
  margin: 2em auto 0;
}

[class^="point"] .h2-ttl {
  background: #f9f9f9;
  margin: 0 auto;
}
@media screen and (max-width: 768px) {
  [class^="point"] .h2-ttl {
    width: 100vw;
    margin: 0 calc(50% - 50vw) 2em;
  }
}
@media screen and (min-width: 769px) {
  [class^="point"] .h2-ttl {
    margin-bottom: 2em;
    border-top-left-radius: 10px;
  }
}
[class^="point"] .h2-ttl h2 {
  font-size: min(5.25vw, 32px);
  padding: 0.5em 0 10px 80px;
  font-weight: 600;
  position: relative;
  margin-right: 0.5em;
}
@media screen and (min-width: 769px) {
  [class^="point"] .h2-ttl h2 {
    padding-left: 100px;
  }
}
[class^="point"] .h2-ttl h2:after {
  content: "";
  position: absolute;
  bottom: 8px;
  left: 30px;
  width: calc(100% - 30px);
  height: 2px;
  background: var(--orange);
  line-height: 1;
}
[class^="point"] .h2-ttl h2:before {
  content: "";
  position: absolute;
  left: 10px;
  top: 50%;
  font-size: 30px;
  width: 60px;
  height: 60px;
  line-height: 60px;
  transform: translateY(-50%);
  color: #fff;
  background: var(--orange);
  border-radius: 50%;
  text-align: center;
  font-style: italic;
}
@media screen and (min-width: 769px) {
  [class^="point"] .h2-ttl h2:before {
    width: 80px;
    height: 80px;
    line-height: 80px;
    font-size: 46px;
  }
}

#point1 .h2-ttl h2:before {
  content: "1";
}
#point2 .h2-ttl h2:before {
  content: "2";
}
#point3 .h2-ttl h2:before {
  content: "3";
}

/* ポイント1：コンテンツ */
.point1 .maximum-point-wrap {
  max-width: 780px;
  margin: 0 auto;
}
.point1 .maximum-point {
  font-size: 16px;
  font-size: min(4vw, 24px);
  font-weight: bold;
  margin: 0 auto 2em;
  padding: 1.5em .5em;
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 4px;
  background: var(--light-orange);
  box-shadow: 0 0 0.5rem rgba(0, 0, 0, 0.2);
  border: 1px solid #e6e6e6;
}
.point1 .maximum-point img {
  width: 15%;
  max-width: 60px;
}
.point1 .maximum-point .txt-reduction {
  text-align: center;
}
.point1 .maximum-point .txt-saidai {
  font-weight: normal;
  color: #fff;
  font-size: 90%;
  background: var(--orange);
  border-radius: 50%;
  text-align: center;
  width: 3em;
  height: 3em;
  display: flex;
  align-items: center;
  justify-content: center;
}
.point1 .frame-orange img {
  width: 20%;
}
.point1 .frame-orange .frame-orange-content {
  display: flex;
  justify-content: center;
  align-items: center;
  font-weight: bold;
}

/* ポイント2：コンテンツ */
.point2 .point2-content {
  max-width: 860px;
  margin: 0 auto;
}
.point2 .illust-operator {
  margin-bottom: -10px;
  position: relative;
}
.point2 .illust-operator img {
  width: 25%;
  max-width: 100px;
  margin-left: 10px;
}
.point2 .illust-operator h3 {
  font-size: 16px;
  font-size: min(4.5vw, 30px);
  position: absolute;
  top: 50%;
  left: 5%;
  width: 95%;
  text-align: center;
  transform: translateY(-50%);
}
.point2 .illust-operator h3 span {
  background: linear-gradient(transparent 60%, var(--light-blue) 60%);
}
.point2 .reason {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 1.5em 0 1em;
}
.point2 .reason-img {
  width: 15%;
  max-width: 100px;
}
.point2 .reason-txt {
  font-weight: bold;
  margin-left: 0.5em;
  font-size: 18px;
  font-size: min(5vw, 26px);
}
@media(min-width: 769px) {
  .point2 .frame-orange-wrap {
    flex-wrap: wrap;
    justify-content: space-around;
  }
}
.point2 .frame-orange {
  text-align: center;
}
@media(min-width: 769px) {
  .point2 .frame-orange {
    width: 48%;
  }
}
@media(max-width: 768px) {
  .point2 .frame-orange+.frame-orange {
    margin-top: 0.75em;
  }
}
@media(min-width: 769px) {
  .point2 .frame-orange:nth-of-type(n+3) {
    margin-top: 0.75em;
  }
}

/* ポイント3：コンテンツ */
.point3 .illust-operator {
  display: flex;
  align-items: center;
  justify-content: center;
}
.point3 .illust-operator-txt {
  display: inline-block;
  position: relative;
  margin-right: 20px;
  padding: 1em;
  border-radius: 8px;
  background-color: var(--light-blue);
  text-align: center;
  font-size: 16px;
  font-size: min(4vw, 24px);
  font-weight: bold;
}
.illust-operator-txt::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 0;
  border-style: solid;
  border-width: 10px 0 10px 20px;
  border-color: transparent transparent transparent var(--light-blue);
  translate: 100% -50%;
}
.point3 .illust-operator img {
  width: 35%;
  max-width: 200px;
}
.point3 .anshin-point-wrap {
  max-width: 780px;
  margin: 0 auto;
}
.point3 .anshin-point-wrap .h3-ttl-wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 2em;
  margin-bottom: 0.5em;
  overflow: hidden;

}
.point3 .anshin-point-wrap .h3-ttl-wrap:before,
.point3 .anshin-point-wrap .h3-ttl-wrap:after {
  content: "";
  width: 100%;
  height: 0;
  border-top: solid 1px var(--basic-black);
}
.point3 .anshin-point-wrap .h3-ttl {
  text-align: center;
  font-weight: 600;
  white-space: nowrap;
  padding: 0 0.5em;
  margin: 1em auto 0.25em;
}
@media screen and (min-width: 769px) {
  .point3 .anshin-point-wrap .h3-ttl {
    font-size: 28px;
  }
}
.point3 .anshin-point-wrap .h3-ttl span {
  background: linear-gradient(transparent 60%, #fcf69f 60%);
}
.point3 .box-shadow-bg {
  padding: 2em 1em;
}
.point3 .box-shadow-bg+.box-shadow-bg {
  margin-top: 2em;
}
.point3 .box-shadow-bg h4 {
  color: var(--deep-blue);
  font-weight: bold;
  font-size: 14px;
  font-size: min(4.5vw, 24px);
  display: flex;
  justify-content: center;
  align-items: center;
}
.point3 .box-shadow-bg h4 .point-mark {
  color: #fff;
  background: var(--deep-blue);
  font-size: 0.7em;
  padding: 0.5em;
  margin-right: 0.75em;
  border-radius: 4px;
  white-space: nowrap;
}
.point3 .box-shadow-bg .anshin-point-car_handin {
  margin: 1em auto;
  max-width: 500px;
}
@media screen and (min-width: 769px) {
  .point3 .box-shadow-bg .anshin-point-car_handin {
    margin: 2em auto;
  }
}
@media screen and (max-width: 768px) {
  .point3 .adj01 {
    max-width: 400px;
    margin: 0 auto;
  }
  .point3 .adj01 .adj01-left {
    margin-bottom: 1em;
  }
  .point3 .adj01 .adj01-right {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
  }
  .point3 .adj01 .adj01-right img {
    width: calc(100% / 3 - 4px);
  }
}
@media screen and (min-width: 769px) {
  .point3 .adj01 {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    max-width: 560px;
    margin: 0 auto;
  }
  .point3 .adj01 .adj01-left {
    width: 60%;
  }
  .point3 .adj01 .adj01-right {
    width: calc(25.5% - 1em);
    padding-left: 1em;
  }
  .point3 .adj01 .adj01-right img+img {
    margin-top: 1em;
  }
  .point3 p.adj01 {
    display: flex;
    justify-content: center;
    max-width: 462px;
    margin-top: -0.5em;
  }
}
.point3 .triangle.dakara {
  position: relative;
  width: 200px;
  margin: 1em auto;
  font-weight: bold;
  height: 40px;
}
.point3 .triangle.dakara:before {
  position: absolute;
  top: 0;
  left: 0;
  content: "";
  width: 0;
  height: 0;
  border-style: solid;
  border-right: 100px solid transparent;
  border-left: 100px solid transparent;
  border-top: 40px solid var(--orange);
  border-bottom: 0;
}
.point3 .triangle.dakara:after {
  content: "だから";
  color: #fff;
  position: absolute;
  top: calc(50% - 0.25em);
  left: 50%;
  transform: translate(-50%, -50%);
}
.point3 .satisfaction-level {
  font-weight: bold;
  font-size: 22px;
  font-size: min(6vw, 26px);
  text-align: center;
  margin-bottom: 1em;
}
.point3 .satisfaction-level .satisfaction-level-txt1 {
  font-size: 0.8em;
}
.point3 .satisfaction-level .color-orange {
  font-size: 1.5em;
  padding-left: 0.25em;
}
.point3 .satisfaction-level sup {
  font-weight: normal;
}
.point3 .light-blue-bg {
  margin-top: 1em;
  background: var(--light-blue);
  padding: 1em;
  border-radius: 6px;
}
.point3 .light-blue-bg:has(.compensation) {
  padding: 1em 0.5em;
}
.point3 .light-blue-bg.option {
  margin-top: 0;
}
.point3 .light-blue-bg .sec01 {
  max-width: 680px;
  margin: 1em auto 0;
}
.point3 .light-blue-bg .sec01 h3 {
  font-size: 16px;
  font-size: min(4.5vw, 24px);
  font-weight: bold;
  color: var(--orange);
  text-align: center;
  width: 100vw;
  margin: 0 calc(50% - 50vw);
}
.point3 .light-blue-bg .sec01 h4 {
  font-weight: bold;
  color: var(--deep-blue);
  text-align: center;
  font-size: 20px;
  font-size: min(4.25vw, 20px);
  padding: 0.25em;
  margin-top: 1em;
  border-top: solid 1px var(--deep-blue);
  border-bottom: solid 1px var(--deep-blue);
}
.point3 .light-blue-bg .sec01 h4 .feature-mark {
  background: var(--deep-blue);
  color: #fff;
  padding: 0.25em 0.5em;
  font-size: 80%;
  font-style: normal;
  line-height: 1;
  margin-right: 0.5em;
  border-radius: 5px;
  position: relative;
  top: -0.1em;
}
@media screen and (max-width: 768px) {
  .point3 .light-blue-bg .sec01 img {
    display: block;
    max-width: 400px;
    margin: 0 auto;
  }
}
.point3 .sec02 .layout2-1 {
  max-width: 680px;
  margin: 0 auto;
}
.point3 .sec02 .ttl-alphabet-shadow span:before {
  content: "Road service";
}
.point3 .sec02 h4 {
  text-align: center;
  color: #fff;
  background: var(--orange);
  line-height: 1.2;
  padding: 0.5em;
  font-weight: bold;
  font-size: 16px;
  font-size: min(5vw, 20px);
  position: relative;
  max-width: 520px;
  margin: 0 auto;
  border-top-left-radius: 12px;
  border-bottom-right-radius: 12px;
  overflow: hidden;
}
.point3 .sec02 h4:before,
.point3 .sec02 h4:after {
  content: "";
  width: 100%;
  height: 0;
  border-top: solid 1px #fff;
  position: absolute;
  left: 0;
}
.point3 .sec02 h4:before {
  top: 3px;
}
.point3 .sec02 h4:after {
  bottom: 3px;
}
.point3 .light-blue-bg .sec02 .sec02-sub-ttl {
  color: #fff;
  background: var(--deep-blue);
  line-height: 1;
  padding: 0.5em;
  border-radius: 3em;
  text-align: center;
  width: 80%;
  margin: 1em auto;
  max-width: 240px;
  z-index: 1;
  position: relative;
  font-weight: bold;
}
.point3 .light-blue-bg .sec02 .sec02-layout1 {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0 1em;
  max-width: 640px;
  margin: -2em auto 2em;
  border: solid 1px var(--deep-blue);
  padding: 1.5em 0.5em 0.5em;
  border-radius: 6px;
  background: #fff;
  font-size: 14px;
}
@media screen and (min-width: 769px) {
  .point3 .light-blue-bg .sec02 .sec02-layout1 {
    padding: 2em 1em 1em;
    font-size: 16px;
  }
}
.point3 .light-blue-bg .sec02 .sec02-layout1-left {
  width: 30%;
}
.point3 .light-blue-bg .sec02 .sec02-layout1-right {
  width: calc(70% - 0.5em);
}
@media screen and (min-width: 769px) {
  .point3 .light-blue-bg .sec02 .sec02-layout1-right {
    width: calc(70% - 1.5em);
  }
}
.point3 .white-bg .sec02 {
  margin-top: 2em;
  padding: 1em;
}
.point3 .white-bg .sec02 h5 {
  font-weight: bold;
  color: var(--deep-blue);
  margin: 1.5em auto 0.25em;
  text-align: center;
  max-width: 680px;
  display: flex;
  align-items: center;
  white-space: nowrap;
  border: none;
}
.point3 .white-bg .sec02 h5:first-of-type {
  margin-top: 1em;
}
.white-bg .sec02 h5 span {
  padding-right: 0.5em;
}
.white-bg .sec02 h5:after {
  content: "";
  width: 100%;
  height: 0;
  border-top: solid 1px var(--deep-blue);
}
.point3 .consultation-txt-wrap {
  display: flex;
  justify-content: center;
}
.point3 .consultation-txt {
  font-weight: bold;
  text-align: center;
  border: solid 2px var(--orange);
  margin-top: 1em;
  padding: 0.5em;
  background: var(--light-yellow);
  border-radius: 6px;
  display: inline-block;
}
@media screen and (min-width: 769px) {
  .point3 .consultation-txt {
    padding: 1em;
    margin-top: 2em;
  }
}
.compensation-wrap h4 {
  font-weight: bold;
  text-align: center;
  margin-bottom: 0.75em;
}
.compensation-wrap h5 {
  font-weight: bold;
}
.point3 .compensation {
  background: #fff;
  padding: 1em 0.5em;
}
@media screen and (min-width: 769px) {
  .point3 .compensation {
    padding: 1em;
  }
}
.point3 .compensation-items-wrap {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin-top: 0.5em;
}
.point3 .compensation-items-wrap a {
  color: var(--link-blue);
  padding: 0.5em;
  border: solid 1px #ccc;
  width: calc(50% - 0.25em);
  text-align: center;
}
@media screen and (min-width: 769px) {
  .point3 .compensation-items-wrap a {
    width: 24%;
    margin-right: 0.5em;
  }
}
@media screen and (max-width: 768px) {
  .point3 .compensation-items-wrap a:nth-of-type(n+3) {
    margin-top: 0.5em;
  }
}
@media screen and (min-width: 769px) {
  .point3 .compensation-items-wrap a:nth-of-type(4) {
    margin-right: 0;
  }
}
.point3 .compensation-items-wrap a.spacer {
  pointer-events: none;
  border: none;
}
.point3 .compensation-items-wrap p,
.point3 .compensation .more {
  margin-top: 0.5em;
  color: var(--link-blue);
  position: relative;
  font-size: 12px;
}
@media screen and (min-width: 769px) {
  .point3 .compensation-items-wrap p,
  .point3 .compensation .more {
    font-size: 14px;
    font-size: min(1.5vw, 14px);
  }
}
.point3 .compensation-items-wrap p:after,
.point3 .compensation .more:after {
  content: "";
  width: 0.6em;
  height: 0.6em;
  border-top: solid 1px var(--link-blue);
  border-right: solid 1px var(--link-blue);
  position: absolute;
  margin-left: 0.25em;
  top: 50%;
  transform: translateY(-50%) rotate(45deg);
}
.point3 .compensation .more-wrap {
  text-align: right;
  margin: 0.5em 1em 0 0;
}
.point3 .compensation .more {
  display: inline-block;
}
.point3 .compensation-wrap .plus-mark {
  color: var(--orange);
}

/* よくあるご質問 */
/* アコーディオン */
.accordion-faq {
  background: #fdeee6;
  border-radius: 5px;
  position: relative;
  width: 100%;
  margin: 0 auto 10px;
}
@media screen and (min-width: 769px) {
  .accordion-faq {
    width: 82%;
  }
}
.accordion-faq.active {
  padding-bottom: .5em;
}
.accordion-faq .summary {
  display: block;
  position: relative;
  padding: 1em 2em 1em 2.8em;
  font-weight: 600;
  cursor: pointer;
  background: #fdeee6;
  color: var(--orange);
  border-radius: 5px;
  list-style: none;
}
.accordion-faq .summary::before,
.accordion-faq .summary::after {
  content: "";
  width: 1em;
  height: 2px;
  position: absolute;
  right: 0.5em;
  top: 50%;
  background: var(--orange);
  border-radius: 1px;
}
.accordion-faq .summary::before {
  transition: 0.2s;
  transform: rotate(90deg);
}
.accordion-faq.active .summary::before {
  transition: 0.2s;
  transform: rotate(0);
}
.accordion-faq .summary i {
  position: absolute;
  left: 0.4em;
  top: 0.6em;
}
.accordion-faq .summary i:before {
  content: "Q";
  color: var(--white);
  background: var(--orange);
  font-style: normal;
  width: 2em;
  height: 2em;
  line-height: 2em;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
}
.accordion-faq .ans-wrap {
  display: none;
  margin: 0.75em 0.5em 0;
  padding: 1em;
  background: var(--white);
  border-radius: 5px;
  position: relative;
}
.accordion-faq .ans-wrap:before {
  content: "A";
  color: var(--white);
  background: var(--deep-blue);
  font-style: normal;
  width: 2em;
  height: 2em;
  line-height: 2em;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  position: absolute;
  left: -0.1em;
  top: -1.2em;
  font-weight: 600;
}
.accordion-faq p+p {
  margin-top: 0.25em;
}
.accordion-faq p.faq-mt0 {
  margin-top: 0;
}
.accordion-faq p:has(span) {
  display: flex;
}
.accordion-faq p span {
  white-space: nowrap;
}
.accordion-faq p a {
  color: var(--link-blue);
  position: relative;
}
.accordion-faq p a:after {
  content: "";
  width: 0.6em;
  height: 0.6em;
  border-top: solid 1px var(--link-blue);
  border-right: solid 1px var(--link-blue);
  position: absolute;
  margin-left: 0.25em;
  top: 50%;
  transform: translateY(-50%) rotate(45deg);
}

.faq-other-btn {
  margin-top: 1.5em;
}
.faq-other-btn a {
  background: var(--deep-blue);
  font-weight: 600;
  height: 40px;
  font-size: 16px;
  color: var(--white);
  border-radius: 5px;
  text-align: center;
  width: 100%;
  max-width: 320px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  position: relative;
  line-height: 1;
}
@media screen and (min-width: 769px) {
  .faq-other-btn a {
    font-size: 18px;
    height: 50px;
  }
}
.faq-other-btn a:after {
  content: "";
  width: 0.5em;
  height: 0.5em;
  display: block;
  position: absolute;
  right: 1em;
  top: 50%;
  border-top: solid 2px var(--white);
  border-right: solid 2px var(--white);
  transform: translateY(-50%) rotate(45deg);
}

/***** よくある質問のみ *****/
.accordion-002 {
  margin: 0 8px;
}
.accordion-001:not([open]) {
  margin-bottom: 0;
}
.accordion-002+.accordion-002 {
  border-top: none;
}
.accordion-002>ul {
  padding: 1em 0;
}
.accordion-002>ul li>ul {
  margin-left: 0;
}
.accordion-002 ul li a {
  color: rgb(0, 102, 170);
  font-weight: normal;
}
.accordion-002 li p.asterisk2 {
  font-size: 11px;
  text-indent: -1em;
  margin-left: 1em;
}
@media screen and (min-width: 769px) {
  .accordion-002 li p.asterisk2 {
    font-size: 16px;
  }
}

/* gaya */
.gaya_inner,
.contract-flow {
  padding: 1em;
  overflow: hidden;
  border: solid 1px #ccc;
  box-shadow: 0 0 0.5rem rgba(0, 0, 0, 0.2);
  border-radius: 6px;
}
.gaya h3 {
  font-weight: bold;
  padding-bottom: 0.5em;
  text-align: center;
  color: var(--orange);
  font-size: 20px;
  font-size: min(5vw, 24px);
}
@media screen and (min-width: 769px) {
  .gaya h3 {
    font-size: 2em
  }
}
.gaya h4 {
  padding-top: 0;
  background: none;
  text-align: center;
  font-weight: bold;
  font-size: 16px;
}
@media screen and (min-width: 769px) {
  .gaya h4 {
    font-size: 24px;
  }
}
.gaya .five-merit {
  max-width: 680px;
  margin: 0 auto;
  display: block;
}
.gaya .app-btn {
  font-size: 16px;
  color: var(--link-blue);
  line-height: 1;
  padding: 0.5em;
  display: flex;
  justify-content: center;
  border: solid 1px var(--link-blue);
  border-radius: 1em;
  margin: 1em auto 0;
  width: 90%;
  max-width: 360px;
}
@media screen and (min-width: 769px) {
  .gaya .app-btn {
    font-size: 20px;
  }
}
.gaya .fi_car_img13 {
  margin: 0 auto;
  max-width: 680px;
}

/* ガヤアコーディオン */
.gaya .colorBox {
  border-radius: 6px;
  margin: 0.5em auto 0;
}
.toggle {
  display: none;
}
.accordion .option {
  position: relative;
  padding: 0;
  margin: 0;
}
.accordion .title,
.content {
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  transform: translateZ(0);
  transition: all 0.3s;
  border-radius: 6px;
}
.accordion .title {
  cursor: pointer;
  display: block;
  color: #ffffff;
  background: var(--orange);
  border-radius: 6px 6px 6px 6px;
  text-align: center;
  font-weight: 700;
  font-size: 16px;
  line-height: 1.2;
  padding: 1em 3em;
  margin: 0 0 0.5rem 0;
}
@media screen and (min-width: 769px) {
  .accordion .title {
    font-size: 20px;
  }
  .accordion .title br {
    display: none;
  }
}
.accordion .title:after,
.accordion .title:before {
  content: "";
  position: absolute;
  right: 2em;
  top: 2em;
  width: 2px;
  height: 1em;
  background-color: #ffffff;
  transition: all 0.3s;
}
.title:after {
  transform: rotate(90deg);
}
.accordion .content {
  max-height: 0;
  overflow: hidden;
}
.accordion .content_inner {
  padding: 1em 3em;
}
.accordion .content p {
  text-align: left;
  margin: 0;
  line-height: 1.5;
}
@media screen and (min-width: 769px) {
  .accordion .title:after,
  .title:before {
    position: absolute;
    right: 2em;
    top: 1em;
  }
}
.accordion .toggle:checked+.title+.content {
  max-height: 4000px;
  transition: all 1.0s;
}
.accordion .toggle:checked+.title:before {
  transform: rotate(90deg) !important;
}
@media screen and (min-width: 769px) {
  #toggle4 .accordion .title:after,
  .title:before {
    position: absolute;
    right: 2em;
    top: 1em;
  }
}
.accordion02 .option {
  position: relative;
  padding: 0;
  margin: 0;
}
.accordion02 .title,
.content {
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  transform: translateZ(0);
  transition: all 0.3s;
  border-radius: 6px;
}
.accordion02 .title {
  cursor: pointer;
  display: block;
  color: var(--orange);
  background: #FFF;
  border: 1px solid var(--orange);
  border-radius: 6px;
  text-align: center;
  font-weight: 700;
  line-height: 1.4;
  padding: 0.5em 2.5em;
  margin: 0 0 0.5em 0;
}
@media screen and (min-width: 769px) {
  .accordion02 .title {
    font-size: 20px;
  }
  .accordion02 .title br {
    display: none;
  }
}
.accordion02 .title:after,
.accordion02 .title:before {
  content: "";
  position: absolute;
  right: 2em;
  top: 2em;
  width: 2px;
  height: 1em;
  background-color: var(--orange);
  transition: all 0.3s;
}
.title:after {
  transform: rotate(90deg);
}
.accordion02 .content {
  max-height: 0;
  overflow: hidden;
  background-color: #F3F3F3;
}
.accordion02 .content_inner {
  padding: 0.5em 0;
  background: #fff;
}
.accordion02 .content p {
  text-align: left;
  line-height: 1.5;
}
@media screen and (min-width: 769px) {
  .accordion02 .title:after,
  .title:before {
    position: absolute;
    right: 2em;
    top: 1em;
  }
}
.accordion02 .toggle:checked+.title+.content {
  max-height: 4000px;
  transition: all 1.0s;
}
.accordion02 .toggle:checked+.title:before {
  transform: rotate(90deg) !important;
}
@media screen and (min-width: 769px) {

  #toggle4 .accordion02 .title:after,
  .title:before {
    position: absolute;
    right: 2em;
    top: 1em;
  }
}
@media screen and (min-width: 769px) {
  .accordion02 .title {
    line-height: 1.2;
  }
}
.accordion03 .option {
  position: relative;
  padding: 0;
  margin: 0;
}
.accordion03 .title,
.content {
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  transform: translateZ(0);
  transition: all 0.3s;
  border-radius: 6px;
}
.accordion03 .title {
  cursor: pointer;
  display: block;
  color: var(--orange);
  background: #FFF;
  border: 1px solid var(--orange);
  border-radius: 6px 6px 6px 6px;
  text-align: center;
  font-weight: 700;
  font-size: 15px;
  line-height: 1.6;
  padding: 0.8em 3rem;
  margin: 0 0 0.5rem 0;
}
@media screen and (min-width: 769px) {
  .accordion03 .title {
    font-size: 20px;
  }
  .accordion03 .title br {
    display: none;
  }
}
.accordion03 .title:after,
.accordion03 .title:before {
  content: "";
  position: absolute;
  right: 2em;
  top: 1.1em;
  width: 2px;
  height: 1em;
  background-color: var(--orange);
  transition: all 0.3s;
}
.title:after {
  transform: rotate(90deg);
}
.accordion03 .content {
  max-height: 0;
  overflow: hidden;
  background-color: #F3F3F3;
}
.accordion03 .content_inner {
  padding: 1em;
  background: #fff;
}
.accordion03 .content p {
  text-align: left;
  margin: 0;
  line-height: 1.5;
}
@media screen and (min-width: 769px) {
  .accordion03 .title:after,
  .title:before {
    position: absolute;
    right: 2em;
    top: 1em;
  }
}
.accordion03 .toggle:checked+.title+.content {
  max-height: 4000px;
  transition: all 1.0s;
}
.accordion03 .toggle:checked+.title:before {
  transform: rotate(90deg) !important;
}
@media screen and (min-width: 769px) {

  #toggle4 .accordion03 .title:after,
  .title:before {
    position: absolute;
    right: 2em;
    top: 1em;
  }
}
@media screen and (min-width: 769px) {
  .accordion03 .title {
    line-height: 1.2;
  }
}
.gaya .accordion02 .title:before,
.gaya .accordion02 .title:after {
  content: "";
  position: absolute;
  right: 1em;
  top: 50%;
  transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  width: 2px;
  height: 1em;
  background-color: var(--orange);
  transition: all 0.3s;
}
.gaya .accordion02 .title:after {
  transform: translateY(-50%) rotate(90deg);
  -webkit-transform: translateY(-50%) rotate(90deg);
}
.gaya .accordion02 .toggle:checked+.title:before {
  transform: translateY(-50%) rotate(90deg) !important;
  -webkit-transform: translateY(-50%) rotate(90deg) !important;
}

/* つよやさクーポン */
.colorBox_item {
  margin-top: 2em;
  display: block;
}
@media screen and (min-width: 769px) {
  .colorBox_item {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
  }
}
.gaya .colorBox .item__box {
  width: 100%;
  border: 1px solid #ed6b0b;
  text-align: left;
  margin-bottom: 1.5em;
}
@media screen and (min-width: 769px) {
  .gaya .colorBox .item__box {
    width: 32%;
  }
}
.gaya .colorBox .item__inner {
  padding: 1em;
}
.gaya .colorBox .item__title {
  color: #fff;
  font-size: 16px;
  font-weight: 700;
  text-align: center;
  padding: 10px 5px;
  background: var(--orange);
}
.gaya .colorBox .item__txt {
  padding: 1rem 0;
}

/* オリジナル特典 */
.gaya .colorBox .colorBox_carlife {
  text-align: left;
  font-size: 16px;
}
.gaya .colorBox .carlife__item {
  margin: 2em 0;
}
.gaya .colorBox .carlife__title {
  font-weight: 700;
  line-height: 1.4;
  padding-bottom: .2rem;
}
.gaya .colorBox .carlife__box {
  display: block;
}
@media screen and (min-width: 769px) {
  .gaya .colorBox .carlife__box {
    display: flex;
    justify-content: space-between;
    flex-wrap: nowrap;
  }
}
.gaya .colorBox .carlife__box_left {
  width: 100%;
}
@media screen and (min-width: 769px) {
  .gaya .colorBox .carlife__box_left {
    width: 70%;
  }
}
.gaya .colorBox .carlife__text {
  padding: .5rem 2rem .5rem 0;
}
.gaya .colorBox .carlife__box li,
.gaya .mod-note li {
  line-height: 1.4;
  text-indent: -1em;
  padding-left: 1em;
}
.gaya .colorBox .carlife__box li {
  font-weight: 700;
}
.gaya .colorBox .carlife__box li:before,
.gaya .mod-note li:before {
  content: "・";
  white-space: nowrap;
}
.gaya .colorBox .carlife__box li .red-txt {
  color: #c00;
}
.gaya .colorBox .carlife__image {
  padding-top: .5rem;
  width: 100%;
  text-align: center;
}
@media screen and (min-width: 769px) {
  .gaya .colorBox .carlife__image {
    width: 30%;
  }
}
.gaya .colorBox .carlife__image img {
  width: 80%;
}
@media screen and (min-width: 769px) {
  .gaya .colorBox .carlife__image img {
    width: 100%;
  }
}

/* 契約の流れ */
.gaya .contract-flow h3 {
  color: var(--basic-black);
}
.gaya .contract-flow p {
  text-align: center;
}
.gaya .contract-flow p.contract-flow-txt2 {
  margin-bottom: 0.5em;
}
@media screen and (max-width: 768px) {
  .gaya .contract-flow p.contract-flow-txt2 {
    text-align: left;
  }
}
.gaya .contract-flow .kai {
  max-width: 680px;
  margin: 0 auto;
}

/******* 保険料例:slick *******/
@media (max-width: 768px) {
  .car-model-wrap-ttl {
    margin-bottom: 1em;
  }
  .car-model-wrap-ttl p {
    font-size: 18px;
  }
  .car-model-wrap {
    width: 100vw;
    margin: 0 calc(50% - 50vw);
    position: relative;
  }

  .box-shadow-bg {
    padding: 2em 0 0;
  }
  .car-model-wrap .car-model-left {
    color: var(--orange);
  }
  .car-model,
  .car-age {
    font-size: min(6vw, 18px);
  }
  .car-model-wrap .car-model-right {
    background: var(--orange);
    color: #fff;
    width: 100%;
    padding: 1em 1em;
    border-bottom-left-radius: 6px;
    border-bottom-right-radius: 6px;
  }
  .car-model-wrap .payment-method .payment-text1 span {
    background: #fff;
    color: var(--deep-blue);
  }
  .car-model-wrap .payment-method .payment-text2 {
    margin-left: 10px;
  }
  .car-model-wrap .payment-method.lump .payment-text2 span {
    color: #fff;
  }
}
.speechBubble-wrap {
  margin-top: 0.5em;
}
.car-model-wrap .car-model-more {
  margin-bottom: 1em;
}
.illust-operator-lp {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 2em;
  margin-bottom: 2em;
}
.illust-operator-txt-lp {
  display: inline-block;
  position: relative;
  margin-right: 20px;
  padding: 1em;
  border-radius: 8px;
  background-color: var(--light-blue);
  text-align: center;
  font-size: 16px;
  font-size: min(4vw, 20px);
  font-weight: bold;
  max-width: 288px;
}
.illust-operator-txt-lp::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 0;
  border-style: solid;
  border-width: 10px 0 10px 20px;
  border-color: transparent transparent transparent var(--light-blue);
  translate: 100% -50%;
}
.illust-operator-lp img {
  width: 35%;
  max-width: 200px;
}

/* pc */
@media (min-width: 769px) {
  .car-model-wrap {
    max-width: 100%;
    display: block;
  }
  .car-model-wrap .box-shadow-bg {
    margin-bottom: 1em;
  }
  .car-model-wrap .car-model-right {
    flex-direction: column;
    justify-content: center;
  }
  .car-model-wrap .car-model-right .car-model-right-inner {
    width: 100%;
  }
  .speechBubble-wrap {
    margin-left: 10px;
    margin-right: auto;
  }
  .speechBubble:before,
  .speechBubble:after {
    left: 45%;
  }
  .car-model-wrap .car-model-more {
    margin-bottom: 3em;
  }
}

/* ------------------------------
  mv-carousel
------------------------------ */
.mv-carousel-wrap {
  position: relative;
}
.mv-carousel {
  margin-top: 2px;
}
.mv-carousel .slick-list {
  overflow: visible;
}
.mv-carousel-slide {
  background: #FFF;
  padding: 1px;
  -webkit-transition: 0.3s cubic-bezier(0.445, 0.05, 0.55, 0.95);
  transition: 0.3s cubic-bezier(0.445, 0.05, 0.55, 0.95);
}
@media (max-width: 768px) {
  .mv-carousel-slide {
    padding: 0;
  }
}
.mv-carousel-slide:not(.slick-now) {
  opacity: 0.2;
  pointer-events: none;
}
.mv-carousel-ui {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}
.tpl-icon-arrow {
  text-align: center;
  width: 1.5em;
  height: 1.5em;
  line-height: 1;
  box-shadow: 0 0 0.5rem rgba(0, 0, 0, 0.2);
  border-radius: 50%;
}
.tpl-icon-arrow::before {
  content: "\e409";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  font-size: 0.75em;
  height: 1em;
  padding-left: 0.05em;
}
.tpl-icon-arrow.prev::before {
  -webkit-transform: scaleX(-1);
  transform: scaleX(-1);
}
.tpl-icon-arrow-corner::before,
.tpl-icon-arrow::before {
  font-family: "Material Icons";
  font-style: normal !important;
}

/* ------------------------------
 Slick
------------------------------ */
.slick-arrow {
  color: #fff;
  pointer-events: auto;
  z-index: 1;
  background: var(--deep-blue);
  position: relative;
}
@media (min-width: 751px) {
  .slick-arrow {
    font-size: 3em;
  }
}
@media (max-width: 768px) {
  .slick-arrow {
    font-size: 2em;
  }
}
.slick-arrow.prev {
  position: absolute;
  top: 50vw;
  left: 5px;
}
.slick-arrow.next {
  position: absolute;
  top: 50vw;
  right: 5px;
}
.slick-arrow.slick-disabled {
  display: none !important;
}
.slick-arrow.static.next {
  -webkit-box-ordinal-group: 4;
  -ms-flex-order: 3;
  order: 3;
}
@media (max-width: 768px) {
  .slick-arrow.sp-static {
    position: static;
    margin: 0;
    -webkit-transform: translateY(0);
    transform: translateY(0);
  }
  .slick-arrow.sp-static.next {
    -webkit-box-ordinal-group: 4;
    -ms-flex-order: 3;
    order: 3;
  }
}
.slick-dots {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  margin: 0 1em;
  pointer-events: auto;
}
@media (min-width: 751px) {
  .slick-dots {
    font-size: 1.5em;
  }
}
@media (max-width: 768px) {
  .slick-dots {
    font-size: 1em;
  }
}
.slick-dots li {
  margin: 0 0.3em;
}
.slick-dots button {
  display: block;
  font-size: 10px;
  width: 1em;
  height: 1em;
  border-radius: 50%;
  overflow: hidden;
  text-indent: -999%;
  background: #e6e6e6;
  border: #FFF 1px solid;
}
.slick-dots li.slick-active button {
  background-color: #eb7000;
}
.mv-carousel .slick-list {
  overflow: hidden;
}
.mv-carousel-slide:not(.slick-now) {
  opacity: 1;
  pointer-events: auto;
}
.mv-carousel-slide {
  padding: 0 10px;
  position: relative;
}
@media(max-width: 749px) {
  .mv-carousel-slide {
    padding: 0 0.5em;
  }
}
.slick-slide .img-bd-adj {
  border: 1px solid #f45501;
}

.roadservice .h3-ttl-wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 2em;
  margin-bottom: 0.5em;
  overflow: hidden;
}
.roadservice .h3-ttl {
  text-align: center;
  font-weight: 600;
  white-space: nowrap;
  padding: 0 0.5em;
}
@media screen and (min-width: 769px) {
  .roadservice .h3-ttl {
    font-size: 28px;
  }
}
.roadservice .h3-ttl span {
  background: linear-gradient(transparent 60%, #fcf69f 60%);
}
.roadservice .flow {
  max-width: 560px;
  margin: 1em auto 0;
}
.roadservice .flow .box-shadow-bg {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  padding: 1em;
}
.roadservice .flow .flow-left {
  width: 30%;
}
.roadservice .flow .flow-right {
  width: calc(70% - 1em);
  font-weight: bold;
  font-size: 18px;
  text-align: center;
}
@media screen and (min-width: 769px) {
  .roadservice .flow .flow-right {
    font-size: 24px;
  }
}
.roadservice .triangle {
  text-align: center;
  font-size: 30px;
  color: var(--orange);
}
@media screen and (min-width: 769px) {
  .roadservice .triangle {
    font-size: 46px;
  }
}
.point3 .lp-support01 {
  margin: 0 auto;
}
.point3 .lp-support01-ttl {
  color: var(--orange);
  font-weight: bold;
  font-size: 18px;
}
.point3 .lp-support01 img {
  display: block;
  max-width: 560px;
  margin: 1em auto;
}
.point3 .roadservice .adj05 {
  background: #fff;
}
.roadservice .sec02 h3 {
  text-align: center;
  color: #fff;
  background: var(--orange);
  line-height: 1.2;
  padding: 0.5em;
  font-weight: bold;
  font-size: 16px;
  font-size: min(5vw, 20px);
  position: relative;
  max-width: 520px;
  margin: 0 auto;
  border-top-left-radius: 12px;
  border-bottom-right-radius: 12px;
  overflow: hidden;
}
.roadservice .sec02 h3:before,
.roadservice .sec02 h3:after {
  content: "";
  width: 100%;
  height: 0;
  border-top: solid 1px #fff;
  position: absolute;
  left: 0;
}
.roadservice .sec02 h3:before {
  top: 3px;
}
.roadservice .sec02 h3:after {
  bottom: 3px;
}
.roadservice .sec02 .sec02-sub-ttl {
  color: #fff;
  background: var(--deep-blue);
  padding: 0.5em;
  border-radius: 3em;
  text-align: center;
  width: 80%;
  margin: 1em auto;
  max-width: 240px;
  z-index: 1;
  position: relative;
  font-weight: bold;
  line-height: 1;
}
@media screen and (max-width: 768px) {
  .roadservice .sec02 .sec02-sub-ttl.adj01 {
    line-height: 1.4;
  }
}
@media screen and (min-width: 769px) {
  .roadservice .sec02 .sec02-sub-ttl.adj01 {
    max-width: 580px;
  }
}
@media screen and (max-width: 768px) {
  .roadservice .sec02 .sec02-layout1.adj04 {
    margin-top: -4.15em;
    padding-top: 3.6em;
  }
}
.accordion-001 li p.num {
  text-align: right;
}

/* あんしんウォッチャー */
.anshinwatcher {
  border: solid 1px var(--deep-pink);
  padding: 1em;
  background: var(--light-pink);
  border-radius: 6px;
}
.anshinwatcher .color-deep-pink {
  color: var(--deep-pink);
}
.anshinwatcher1 {
  max-width: 780px;
  margin: 0 auto;
}
.anshinwatcher .h2-ttl {
  position: relative;
  margin-bottom: 0.25em;
  text-align: center;
  font-weight: 600;
  display: inline-block;
  font-size: min(5.5vw, 26px);
  text-align: center;
  line-height: 1.2;
}
.anshinwatcher .h2-ttl i {
  font-style: normal;
}
.anshinwatcher .h3-ttl {
  font-weight: bold;
  color: var(--deep-blue);
  font-size: min(5vw, 24px);
  margin-bottom: 0.5em;
}
.anshinwatcher .h3-ttl .feature-mark {
  background: var(--deep-blue);
  color: #fff;
  font-size: 80%;
  padding: 0.25em 0.5em;
  margin-right: 0.5em;
  position: relative;
  top: -0.1em;
  border-radius: 5px;
  font-style: normal;
}
.anshinwatcher .box-shadow-bg {
  padding: 1em;
  background: #fff;
}
.anshinwatcher .box-shadow-bg .triangle {
  display: flex;
  justify-content: center;
  align-items: center;
  max-width: 640px;
  margin: 2em auto 0;
}
.anshinwatcher .box-shadow-bg .triangle-ttl {
  border: solid 1px var(--deep-blue);
  color: var(--deep-blue);
  line-height: 1;
  padding: 0.5em;
  text-align: center;
  border-radius: 1em;
  margin-bottom: 1em;
  font-size: 14px;
  font-weight: bold;
}
.anshinwatcher .box-shadow-bg .triangle-ttl-left,
.anshinwatcher .box-shadow-bg .triangle-ttl-right {
  display: flex;
  flex-direction: column;
}
.anshinwatcher .box-shadow-bg .triangle img {
  height: 50vw;
  max-height: 400px;
  width: auto;
}
.anshinwatcher .box-shadow-bg .triangle-mark {
  display: inline-block;
  width: 0;
  height: 0;
  border-style: solid;
  border-top: 20px solid transparent;
  border-bottom: 20px solid transparent;
  border-left: 20px solid var(--deep-pink);
  border-right: 0;
  margin: 0 3%;
}
.anshinwatcher .box-shadow-bg h4 {
  background: var(--deep-blue);
  color: #fff;
  padding: 0.5em;
  line-height: 1;
  width: 80%;
  max-width: 360px;
  margin: 0 auto 1em;
  text-align: center;
  border-radius: 2px;
  font-size: 18px;
}
.anshinwatcher .anshinwatcher2-content {
  max-width: 780px;
  margin: 1em auto 0;
}
.anshinwatcher2 .anshinwatcher2-content {
  max-width: 780px;
  margin: 1em auto 0;
}
.anshinwatcher3 .anshinwatcher3-content {
  max-width: 780px;
  margin: 1em auto 0;
}
.anshinwatcher3-ttl {
  background: #fff;
  padding: 0.5em;
  border-radius: 6px;
  display: inline-block;
  text-align: left;
  border: solid 2px var(--deep-blue);
  margin-bottom: 0.5em;
}
@media screen and (min-width: 769px) {
  .anshinwatcher3-ttl {
    padding: 0.5em 2em;
    display: block;
    text-align: center;
  }
}
.anshinwatcher3 .battery {
  position: relative;
  margin-top: 1em;
  margin-bottom: 2em;
}
.anshinwatcher3 .battery-left {
  width: 40%;
  display: inline-block;
}
.anshinwatcher3 .battery .battery-right {
  width: calc(60% - 1em);
  position: absolute;
  top: 63%;
  transform: translateY(-50%);
  display: inline-block;
  margin-left: 16px;
  padding: 1em;
  border-radius: 12px;
  background-color: var(--light-pink);
  text-align: left;
  font-size: 14px;
  font-weight: 400;
  line-height: 1.5;
}
@media screen and (min-width: 769px) {
  .anshinwatcher3 .battery .battery-right {
    font-size: 16px;
  }
}
.anshinwatcher3 .battery .battery-right::after {
  content: "";
  position: absolute;
  top: 55%;
  left: 0;
  border-style: solid;
  border-width: 8px 16px 8px 0;
  border-color: transparent var(--light-pink) transparent transparent;
  translate: -100% -50%;
  transform: skew(0, -10deg);
  transform-origin: right;
}

/* 注意事項 */
.anshinwatcher-notice li {
  display: flex;
}
.anshinwatcher-notice li .decimal {
  white-space: nowrap;
  margin-right: 0.5em;
}
.anshinwatcher-notice li a {
  color: var(--link-blue);
}
.anshinwatcher-notice li+li:not(.through) {
  margin-top: 0.5em;
}
.anshinwatcher-notice .specifications {
  margin-top: 1em;
  max-width: 872px;
}
.anshinwatcher-notice .specifications table {
  border-collapse: collapse;
}
.anshinwatcher-notice .specifications table th,
.anshinwatcher-notice .specifications table td {
  border: 1px solid #333;
  padding: 0.5em;
  font-size: 14px;
}
@media screen and (min-width: 769px) {
  .anshinwatcher-notice .specifications table th,
  .anshinwatcher-notice .specifications table td {
    font-size: 16px;
  }
}
.anshinwatcher-notice .specifications table th {
  white-space: nowrap;
  background: #f9f9f9;
}
.anshinwatcher-notice .setting a {
  border: solid 1px var(--basic-black);
  padding: 0.5em;
  display: block;
  margin: 1em 0 0.5em;
  font-size: 16px;
  font-weight: bold;
  position: relative;
  border-radius: 6px;
  text-align: center;
  max-width: 500px;
}
@media (min-width: 769px) {
  .anshinwatcher-notice .setting a {
    font-size: 18px;
  }
}
.anshinwatcher-notice .setting a:after {
  content: "";
  width: 0.6em;
  height: 0.6em;
  border-top: 2px solid var(--basic-black);
  border-right: 2px solid var(--basic-black);
  position: absolute;
  right: 0.5em;
  top: 50%;
  transform: translateY(-50%) rotate(45deg);
}

.footer {
  padding: 2em 0;
  background-color: #F3F3F3;
}
.footer-wrap {
  max-width: 980px;
  margin: 0 auto;
}
.footer-detail {
  margin: 0 10px;
  line-height: 1.3;
  font-size: 12px;
}
.footer-detail dl {
  display: table;
  margin: 0.6em 0;
}
.footer-detail dl:nth-child(3) {
  margin-bottom: 1.5em;
}
.footer-detail dl dt,
.footer-detail dl dd {
  display: table-cell;
}
.footer-detail dl dt {
  padding-right: 1em;
  width: 7em;
}
.footer-txt {
  line-height: 1.6;
  color: #888888;
  font-size: 12px;
}
@media screen and (min-width: 769px) {
  .footer {
    padding: 3em 0;
  }
  .footer-detail {
    font-size: 14px;
  }
  .footer-detail dl dt {
    padding-right: 1em;
    width: 100px;
  }
}

.footer2 {
  padding: 1.5em 0;
  background-color: #fff;
  text-align: center;
}
.footer-logo {
  margin: 0 auto 1.5em;
}
.footer-logo img {
  width: 200px;
}
.footer-links {
  display: flex;
  justify-content: center;
  gap: 2em;
}
.footer-links a {
  text-decoration: underline;
  color: #0072c4;
  font-size: 13px;
}
@media screen and (min-width: 769px) {
  .footer2 {
    padding: 2.5em 0;
  }
}