.main_title_col{
  width:100%;
  background:#0f488b;
  margin-top: 40px;
}
.main_title_col:first-of-type {
  margin-top: 0;
}
.main_title_container{
  margin:0 auto;
  text-align:center;
  display:flex;
  justify-content: center;
  align-items:center;
}
.main_title_box img{
  max-width:100%;
}
.main_title_box .main_title_box_txt{
  display:flex;
  justify-content: center;
  align-items:center;
}
.main_title_box .main_title_box_txt p{
  margin-left:20px;
  font-size:3.0em;
  font-weight:700;
  color:#FFF;
}
.main_title_box .main_title_box_txt p span{
  margin-left:20px;
  padding:5px 10px;
  font-size:0.5em;
  color:#FFF;
  border:1px solid #FFF;
}
@media only screen and (max-width:768px) {
  .main_title_container{
    display:block;
    width:100%;
    padding:10px 0px;
  }
  .main_title_box .main_title_box_txt p{
    margin-left:10px;
    font-size: clamp(1.8em, 4vw, 2.2rem);
  }
  .main_title_box .main_title_box_txt p span{
    margin-left:10px;
    padding:3px 7px;
    font-size:0.5em;
  }
}

.product_col{
  padding:0px 20px;
}
@media only screen and (max-width:768px) {
  .product_col{
    padding:0px 0px;
  }
}
.product_ttl{
  width:100%;
  margin:30px auto;
  text-align:center;
  font-size: 2.8em;
  font-family: serif;
  font-weight: bold;
  color:#004ea2;
}
@media only screen and (max-width:768px) {
  .product_ttl{
    font-size: clamp(1.5em, 6.4vw, 2.8em);
  }
}
.product_body{
  font-size: 1.2em;
}

.keeper_img_container{
  display:flex;
  justify-content: center;
  align-items: center;
}
.coating_img_container {
  margin: 32px 0 40px;
}
.keeper_img_box{
  width:50%;
}
.keeper_img_desc{
  display:flex;
  flex-direction: column;
}
.keeper_img_desc {
  position: relative;
  top: 20px;
  margin-bottom: 20px;
}
.keeper_img_desc_box {
  margin:5px 0px;
  padding:10px 20px;
  text-align:center;
  border:2px solid #000;
}
.keeper_img_desc_box.text01{
  background:#fad9c6;
}
.keeper_img_desc_box.text02{
  background:#bae3f9;
}
.keeper_img_desc_box .text03{
  background:#dcdcdc;
}
.coating_img_desc_box.text01{
  background:#D2E6D4;
}
.coating_img_desc_box.text02{
  background:#B6E1F9;
}
.ultra-coating_img_desc_box.text01{
  background:#E8F3FA;
}
.ultra-coating_img_desc_box.text02{
  background:#B6E1F9;
}
.coating_img_desc_box .text03{
  background:#DCDCDC;
}
.keeper_img_desc{
  font-size:1.6em;
}
@media only screen and (max-width:768px) {
  .keeper_img_desc_box {
    margin:2px 0px;
    padding:0px 10px;
  }
  .keeper_img_desc{
    padding-top:20px;
    font-size:1.0em;
  }
}
.keeper_img_box p{
  font-size:1.0em;
  text-align:right;
}


.keeper_img_case{
  display:flex;
  flex-wrap:wrap;
  justify-content: center;
}
.keeper_img_case_box{
  width:48%;
  margin:10px 5px;
}
@media screen and (max-width:768px) {
  .keeper_img_case_box{
    width:46%;
  }
}
.keeper_img_case_box img{
  max-width:100%;
}

.effect-term {
  font-size: 20px;
  display: grid;
  grid-template-columns: min-content 1fr;
  border: 3px solid #221914;
}
.effect-term__period {
  display: grid;
  place-content: center;
  white-space: nowrap;
  font-size: 1.3em;
  color: #F0F0F0;
  background-color: #221914;
  padding: 0 1.2em;
}
.effect-term__term {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  padding: .8em 1.2em;
  gap: .2em 1.2em;
}
.effect-term__number {
  font-size: 3em;
  font-weight: 900;
  white-space: nowrap;
  line-height: 1;
}
.effect-term__note {
  min-width: 110px;
  position: relative;
  font-size: 1.2em;
  line-height: 1.2;
  padding-left: 1em;
}
.effect-term__note::before {
  content: "※";
  display: block;
  position: absolute;
  left: 0;
}
@media (max-width: 768px) {
  .effect-term {
    font-size: clamp(10px, 1.9vw, 13.2px);
  }
  .effect-term__note {
    padding-left: 1.2em;
  }
}
.construction-fee {
  font-size: 20px;
  margin: 32px 0 ;
}
.construction-fee__label {
  font-size: 1.3em;
  display: inline-block;
  background-color: #0A478D;
  color: #FFFFFF;
  border: 3px solid #000000;
  border-bottom: none;
  padding: 0 .5em .1em;
}
.construction-fee__body {
  width: 100%;
  display: grid;
  grid-template-columns: 1.3fr 1fr;
  border: 3px solid #000000;
}
.construction-fee__item {
  font-weight: bold;
  background-color: #FFFADA;
  padding: .44em 1.76em .22em;
  border-bottom: 2px solid #000000;
}
.construction-fee__size {
  font-size: 2.2em;
  line-height: 1;
}
.construction-fee__size-unit {
  font-size: 1.5em;
  margin: 0 .2em;
}
.construction-fee__pricing {
  font-size: 2.2em;
  font-weight: bold;
  line-height: 1;
  padding: .2em .8em .1em;
  border-bottom: 2px solid #000000;
}
.construction-fee__item:nth-last-child(2), .construction-fee__pricing:last-of-type {
  border-bottom: none;
}
.construction-fee__pricing-unit {
  font-size: .5em;
}
.construction-fee__text {
  font-size: 1.2em;
  line-height: 1.2;
  margin-top: 10px;
  padding: 0 12px;
}
@media (max-width: 768px) {
  .construction-fee {
    font-size: clamp(10px, 2vw, 12px);
  }
  .construction-fee__label {
    font-size: 2em;
  }
  .construction-fee__body {
    display: block;
  }
  .construction-fee__item {
    border: none;
  }
  .construction-fee__pricing {
    padding-bottom: .3em;
  }
  .construction-fee__text {
    font-size: 16px;
  }
}
.coating-pictures {
  display: grid;
  grid-template-columns: repeat(auto-fit, clamp(150px, 45%, 300px));
  justify-content: center;
  gap: 18px 16px;
  margin: 40px 0;
}
.coating-picture {
  margin: 0;
}
.coating-img {
  width: 100%;
  aspect-ratio: 300/176;
  object-fit: cover;
}
.coating-figcaption {
  font-size: 16px;
  font-weight: bold;
  margin-top: 4px;
  text-align: center;
}
.coating-figcaption-small {
  display: block;
}
@media (max-width: 768px) {
  .coating-figcaption {
    font-size: 14px;
  }
}
.mall_top {
  display: flex;
  place-content: center;
  flex-wrap: wrap;
  margin: 40px 0;
  padding-bottom: 24px;
  gap: 12px 8px;
  border-bottom: 1px solid #333333;
}
.mall_top_img {
  width: 200px;
  max-width: 50%;
  display: grid;
  place-content: center;
}
.mall_top_txt, .mall_top_txt_note {
  font-size: 2.8em;
  font-weight: 500;
  line-height: 1.2;
  white-space: nowrap;
  text-align: center;
}
.mall_top_txt_note {
  font-size: 2.4em;
  white-space: inherit;
}
@media (max-width: 767px) {
  .mall_top {
    margin: 24px 0;
  }
  .mall_top_txt {
    font-size: clamp(1.8em, 4vw, 2.2rem);
  }
  .mall_top_txt_note {
    font-size: clamp(1.75em, 3.8vw, 2.1rem);
  }
}
.mall_pricing_boxes {
  width: 90%;
  margin: 40px auto 24px;
  border: 2px solid #000;
  background-color: #FFFADA;
}
.mall_pricing_box {
  font-size: 2.4em;
  padding: 1em 0 1em 7em;
  position: relative;
}
.mall_pricing_box:first-of-type {
  border-bottom: 2px solid #000;
}
.mall_box_label {
  font-size: 1em;
  font-weight: 500;
  padding: .2em 1em;
  position: absolute;
  top: 50%;
  left: .8em;
  background-color: #FFFFFF;
  transform: translateY(-50%);
}
.mall_pricing {
  font-size: 1.05em;
  font-weight: 500;
  line-height: 1.2;
}
.mall_box_single {
  width: 90%;
  border: 2px solid #000;
  background-color: #FFFADA;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 0 auto 24px;
  padding: 1em;
  font-size: 2.4em;
  gap: .5em;
}
.mall_box_single_text {
  font-size: 1em;
  font-weight: 500;
  line-height: 1;
  white-space: nowrap;
}
@media (max-width: 767px) {
  .mall_pricing_boxes {
    width: 100%;
  }
  .mall_box_label {
    position: static;
    transform: none;
    margin-bottom: .5em;
  }
  .mall_pricing_box, .mall_box_single {
    width: 100%;
    font-size: clamp(20px, 2.4vw, 24px);
    padding: .5em 1em;
  }
}
/* 比較表コンテンツ追加 20231205 */
.chart-table table {
  background: #fff;
  color: #1A3D64;
  border-collapse: collapse;
  width: 1000px;
}
.chart-table th,
.chart-table td {
  max-width: 254px;
  padding: 10px 0;
  border: #1A3D64 2px solid;
  line-height: 1;
  font-size: 1rem;
  text-align: center;
}
.chart-table th {
  font-weight: bold;
  padding: 15px 0;
}
.chart-table tr:last-child td a {
  transition: all 0.3s;
}
.chart-table tr:last-child td a:hover {
  opacity: 0.7;
}
@media only screen and (max-width: 767px) {
  .chart-table {
    overflow: scroll;
  }
  .chart-table table {
    width: 1000px;
  }
  .main_title_box .main_title_box_txt {
    display: block;
  }
}

/* 20240321 対応車種一覧追加 */
.main_title_container {
  margin: 20px auto 0;
  text-align: center;
  display: flex;
  justify-content: center;
  align-items: center;
}
.main_title_col {
width: 100%;
background: #0f488b;
margin-top: 40px;
}
.main_title_box .main_title_box_txt {
display: flex;
justify-content: center;
align-items: center;
}
.main_title_box .main_title_box_txt p {
margin-left: 20px;
font-size: 3.0em;
font-weight: 700;
color: #FFF;
}
td.car_brandname{
width: 200px;
}
@media only screen and (max-width: 768px) {
.main_title_container {
    display: block;
    width: 100%;
    padding: 10px 0px;
}
.main_title_box .main_title_box_txt p {
  margin-left: 10px;
  font-size: clamp(1.8em, 4vw, 2.2rem);
}
.main_title_box .main_title_box_txt {
    display: block;
}
}
.carcare_car_models table {
margin: 50px auto;
}
.carcare_car_models td {
border-collapse: collapse;
border: 1px solid #000;
}
.carcare_car_models td {
position: relative;
min-width: 5em;
padding: 10px;
border: #1A3D64 2px solid;
line-height: 1.4;
font-size: 1rem;
}
.carcare_car_models tr:first-of-type td:first-of-type {
width: 6rem;
background: #efefef;
}
.carcare_car_models td .other_txt {
position: absolute;
right: 10px;
}
@media only screen and (max-width: 767px) {
.carcare_car_models {
  overflow: scroll;
}
.carcare_car_models table {
  width: 1000px;
}
}

/* 20240501 */
.cmn-chart-table-tr td a {
  font-size:0.75rem;
  /* white-space:nowrap; */
}

/* 20240507 板金やコーティングの流れ追加 */
.section__flow-tab-nav-list {
  display: grid;
  grid-template-columns: 1fr 1fr;
  margin-top: 100px;
  gap: 20px;
  width: 100%;
  color: #333;
}
.section__flow-tab-nav-list li {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 1em 1em;
  cursor: pointer;
  text-align: center;
  background-color: #fff;
  border: 1px solid #bbb;
  font-size: 12px;
}
.section__flow-tab-nav-list li.on {
  background-color: #4672c0;
  color: #fff;
  border: 0;
}
.section__flow-tab-wrap {
  background: White;
  display: flex;
  flex-wrap: wrap;
  padding: 20px 0 20px;
}
.section__flow-tab-content {
  height: 0;
  opacity: 0;
  padding: 0 0;
  pointer-events: none;
  transform: translateX(-50px);
  transition: transform 0.3s 80ms, opacity 0.3s 80ms;
  width: 100%;
  color: #333;
  counter-reset: number 0;
}
.section__flow-tab-content.on {
  height: auto;
  opacity: 1;
  order: 1;
  pointer-events: auto;
  transform: translateX(50px);
  transform: translateX(0);
}
.section__flow-tab-content.on~.tab-content {
  transform: translateX(50px);
}
.section__flow-tab-content li {
  margin-bottom: 1em;
  padding: 1em 1em;
  border: 1px solid #bbb;
}
.section__flow-tab-content li dt {
  margin-bottom: 1em;
  padding: 0.5em 1em;
  background-color: #4672c0;
  color: #fff;
}
.section__flow-tab-content li dt:before {
  counter-increment: number;
  content: counter(number) ".";
}
@media (min-width: 768px) {
  .section__flow-tab-nav-list {
    gap: 30px;
  }
  .section__flow-tab-nav-list li {
    font-size: 14px;
  }
}