@charset "UTF-8";
@media screen and (min-width: 769px) {
  .rates {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
  }
}
.rates .car-model-wrap{
  padding: 0;
}
.rates .car-model-wrap+.car-model-wrap {
    margin-top: 2em;
}
.rates .car-model-wrap .car-model-wrap-ttl{
  margin: 0 0 1em;
}
.rates .car-model-wrap .car-model-wrap-ttl h2,.rates .car-model-wrap .car-model-wrap-ttl p{
  color: var(--basic-black);
  font-size: 18px;
}
.rates .car-model-wrap .box-shadow-bg{
  position: relative;
}
@media screen and (max-width: 768px) {
  .rates .car-model-wrap .box-shadow-bg{
    padding: 2em 0 3em;
  }
}
@media screen and (min-width: 769px) {
  .rates .car-model-wrap .box-shadow-bg{
    padding: 2em 1em;
  }
}
@media screen and (max-width: 768px) {
  .rates .car-model-wrap .car-model-right{
    margin-bottom: 1.5em;
  }
}
.rates .car-model-wrap .box-shadow-bg .more-detail{
  text-align: right;
  position: absolute;
  right: 1em;
  bottom: 1em;
}
@media screen and (max-width: 768px) {
  .rates .car-model-wrap .box-shadow-bg .more-detail{
    right: 1.5em;
    bottom: 1.75em;
  }
}

.rates .illust-operator{
  display: flex;
  align-items: center;
  justify-content: center;
  margin:1em 0 2em;
}
.rates .illust-operator-txt {
  display: inline-block;
  position: relative;
  margin-right: 20px;
  padding: 1em;
  border-radius: 8px;
  background-color: var(--light-blue);
  font-size: 16px;
  font-size: min(4vw, 24px);
  font-weight: bold;
  color: var(--basic-black);
}
.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%;
}
.rates .illust-operator img{
  width: 35%;
  max-width: 200px;
}
.rates .anshin-point-wrap{
  max-width: 780px;
  margin: 0 auto;
}
.rates .anshin-point-wrap .ttl-alphabet-shadow span:before {
  content: "Safety points";
}

/* 吹き出し */
.speechBubble {
  position: relative;
  display: inline-block;
  margin-top: 18px;
  padding: 0.5em;
  border: 2px solid var(--orange);
  border-radius: 8px;
  background-color: var(--light-orange);
  text-align: center;
  font-size: 14px;
  font-weight: 400;
  line-height: 1.5;
  color: var(--basic-black);
}

.speechBubble::before {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  border-style: solid;
  border-width: 0 10px 20px 10px;
  border-color: transparent transparent var(--orange);
  translate: -50% -100%;
}

.speechBubble::after {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  border-style: solid;
  border-width: 0 7.8px 15.5px 7.8px;
  border-color: transparent transparent var(--light-orange);
  translate: -50% -100%;
}
.speechBubble .fwb{
  font-size: 150%;
}
.box-shadow-bg{
  border: solid 1px #ccc;
  box-shadow: 0 0 0.5rem rgba(0, 0, 0, 0.2);
  padding: 2em 0;
  border-radius: 6px;
}

/* 保険料例詳細 */
.rates-3rd-cmn .img-wrap{
  max-width: 480px;
  width: 65%;
  margin: 1em auto 0;
}
.rates-3rd-cmn table{
  border-collapse: collapse;
  width: 100%;
  margin-top: 0.5em;
}
.rates-3rd-cmn table th,.rates-3rd-cmn table td{
  border: solid 1px #ccc;
  padding: 1em 0.25em;
  text-align: center;
  vertical-align: middle;
}
.rates-3rd-cmn table sup{
  font-weight: normal;
}
.rates-3rd-cmn table th{
  background: var(--gray);
}
/* テーブル：保険料 */
.rates-3rd-cmn .rates-table01{
  max-width: 640px;
}
.rates-3rd-cmn .rates-table01 th,.rates-3rd-cmn .rates-table01 td{
  width: 50%;
}
/* テーブル：補償内容 */
.rates-3rd-cmn .rates-table02 th{
  width: 30%;
  padding: 1em 0.5em;
}
.rates-3rd-cmn .rates-table02 td{
  width: 70%;
  padding: 1em;
  text-align: left;
}
@media screen and (min-width: 769px) {
  .rates-3rd-cmn .rates-table02 th{
    width: 25%;
  }
  .rates-3rd-cmn .rates-table02 td{
    width: 75%;
  }
}
.rates-3rd-cmn h3{
  font-size: 18px;
  font-weight: bold;
}
.rates-3rd-cmn h3:nth-of-type(n+2){
  margin-top: 1em;
}
