@charset "UTF-8";
/* CSS Document */


/* -- common -- */

.cnt_inner {
  width: 1000px;
  margin: 0 auto;
}

.sp_br {
  display: none;
}


/* animation */
.anm {
  opacity: 0;
  transform: translateY(40px);
  transition: all 0.8s;
  backface-visibility: hidden;
}

.anm.visible {
  opacity: 1;
  transform: translateY(0px);
}


/* -- kv -- */

#kv {
  margin-bottom: 35px;
  overflow: hidden;
}

#kv h1 {
  position: absolute;
  color: #fff;
}

#kv .kv_slider {
  position: relative;
}

#kv .kv_slider img {
  display: block;
  width: 100%;
}

/* animation */
/* #kv h1 {
  opacity: 0;
  transform: scale(1.15);
  transition: all 1.2s;
  backface-visibility: hidden;
}

.loaded #kv h1 {
  opacity: 1;
  transform: scale(1);
} */


/* -- intro -- */

#intro {
  margin-bottom: 45px;
  font-size: 22px;
  text-align: center;
  line-height: 1.8;
}

#intro .underline_txt {
  display: table;
  margin: 0 auto;
  font-weight: 700;
  /* line-height: 1.9; */
  text-align: center;
}

#intro .underline_txt span {
  position: relative;
}

#intro .underline_txt .line::before {
  content: "";
  position: absolute;
  bottom: -0.22em;
  left: 0;
  width: 100%;
  height: 15px;
  background-color: #fff100;
}

#intro .notes_txt {
  margin-top: 16px;
  font-size: 13px;
}


/* -- features -- */

#features {
  position: relative;
  padding-bottom: 30px;
}

#features::before {
  content: "";
  position: absolute;
  top: 340px;
  left: 0;
  width: 100%;
  height: calc(100% - 340px);
  background-color: #1b365d;
}

#features .features_head {
  position: relative;
  padding-bottom: 30px;
  margin-bottom: 55px;
}

#features .features_head .inner {
  width: 580px;
  margin-left: 105px;
  padding-top: 25px;
}

#features h2 {
  margin-bottom: 12px;
  font-size: 40px;
  font-weight: 700;
  text-align: center;
  letter-spacing: 0.075em;
}

#features .features_list {
  padding: 33px 0 25px 56px;
  background-color: #84754e;
  border-radius: 15px;
}

#features .features_list li {
  padding-bottom: 8px;
}

#features .features_list a {
  padding-left: 40px;
  color: #fff;
  font-size: 26px;
  line-height: 1.55;
  text-decoration: none;
  background-repeat: no-repeat;
  background-position: 0 8px;
  background-size: 28px;
}

#features .features_list li:nth-child(1) a {
  background-image: url(../img/no_1.svg);
}

#features .features_list li:nth-child(2) a {
  background-image: url(../img/no_2.svg);
}

#features .features_list li:nth-child(3) a {
  background-image: url(../img/no_3.svg);
}

#features .features_list li:nth-child(4) a {
  background-image: url(../img/no_4.svg);
}

#features .features_list li:nth-child(5) a {
  background-image: url(../img/no_5.svg);
}

#features .features_list li:nth-child(6) a {
  background-image: url(../img/no_6.svg);
}

#features .features_list .line {
  position: relative;
}

#features .features_list .line::before {
  content: "";
  position: absolute;
  bottom: 1px;
  left: 0;
  width: 100%;
  height: 1px;
  background-color: #fff;
  opacity: 0.7;
}

#features .product {
  position: absolute;
  bottom: 104px;
  right: 47px;
  width: 218px;
}

#features .sticker {
  position: absolute;
  bottom: 40px;
  right: 8px;
  width: 120px;
  height: 120px;
  padding-top: 17px;
  background-color: #61d7ff;
  color: #fff;
  font-size: 16px;
  line-height: 1.38;
  text-align: center;
  border-radius: 50%;
  box-sizing: border-box;
}

#features .notes {
  position: absolute;
  bottom: 0px;
  right: 0px;
  width: 280px;
  color: #fff;
  font-size: 10px;
  line-height: 1.4;
}


/* feature_set */
#features .feature_set {
  position: relative;
  padding-top: 20px;
  padding-bottom: 80px;
} 

#features .feature_set .feature_h {
  position: relative;
  display: table;
  margin: 0 auto;
  padding-bottom: 15px;
  color: #fff;
  font-size: 36px;
  line-height: 1.37;
}

#features .feature_set .feature_h .no,
#features .feature_set .feature_h .txt {
  display: table-cell;
  vertical-align: top;
}

#features .feature_set .feature_h .no img {
  display: block;
  margin-right: 10px;
  padding-top: 3px;
}

#features .feature_set .feature_h .txt {
  padding-bottom: 2px;
  font-weight: bold;
}

#features .feature_set .feature_h::before {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 7px;
  background-color: #84754e;
}

#features .feature_set .feature_body {
  padding: 40px 70px 50px;
  background-color: #fff;
  font-size: 18px;
}

#features .feature_set .annotation_list {
  margin-top: 8px;
  text-indent: -2em;
  padding-left: 2em;
  font-size: 13px;
}

#features .feature_set .annotation_list_1em {
  margin-top: 8px;
  text-indent: -1.3em;
  padding-left: 1.3em;
  font-size: 13px;
} 

/* feature_1 */
#features #feature_1 .img_1 {
  width: 716px;
  margin: 35px 0 0 92px;
}

#features #feature_1 .txt_01 {
  margin-bottom: 5px;
  color: #1b365d;
  font-size: 28px;
  font-weight: bold;
  text-align: center;
} 

#features #feature_1 .img_txt_box {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 20px 25px;
  width: 90%;
  margin: 0 auto;
  align-items: center;
} 

#features #feature_1 .img_txt_box dt {
  width: 130px;
}

#features #feature_1 .img_txt_box dt img {
  width: 100%;
}

#features #feature_1 .img_txt_box dd {
  text-indent: -1.8em;
  padding-left: 1.8em;
  color: #1b365d;
  font-size: 22px;
  font-weight: bold;
  line-height: 1.6;
}

#features #feature_1 .img_txt_box dd .num {
  display: inline-block;
  width: 1.5em;
  padding: 0.2em 0 0 1px;
  margin-right: 0.3em;
  aspect-ratio: 1 / 1;
  background-color: #1b365d;
  color: #fff;
  font-size: 20px;
  line-height: 1;
  text-align: center;
  text-indent: 0;
  border-radius: 999px;
  box-sizing: border-box;
  letter-spacing: normal;
}

#features #feature_1 .img_txt_box dd .line {
  border-bottom: 1px solid #1b365d;
}

/* feature_2 */
#features #feature_2 .img_flex {
  display: flex;
  justify-content: space-between;
  margin-top: 45px;
}

#features #feature_2 .img_flex .img {
  width: 405px;
}

#features #feature_2 .img_flex .img img {
  width: 100%;
}

#features #feature_2 .img_flex .img_txt {
  margin-top: 12px;
  color: #1b365d;
  font-size: 22px;
  font-weight: bold;
  line-height: 1.45;
  text-align: center;
}

#features #feature_2 .img_flex .img_txt span {
  margin: 0 2px;
  color: #ea0000;
  font-weight: bold;
}

/* feature_3 */
#features #feature_3 .pattern {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0px 60px;
  width: 100%;
  margin: 35px auto 0px;
}

#features #feature_3 .pattern .box {
  display:contents;
  display: grid;
  grid-template-rows: subgrid;
  grid-row: span 5;
  gap: 0px;
  margin-bottom: 50px;
}

#features #feature_3 .pattern img {
  width: 100%;
}

#features #feature_3 .pattern .h_pattern .txt_01 {
  width: fit-content;
  padding: 4px 12px 6px;
  margin-bottom: 2px;
  background-color: #1b365d;
  line-height: 1;
  border-radius: 999px;
  color: #fff;
  font-size: 16px;
  letter-spacing: 0.1em;
}

#features #feature_3 .pattern .h_pattern .txt_02 {
  padding-bottom: 6px;
  font-size: 21px;
  font-weight: bold;
  line-height: 1.4;
}

#features #feature_3 .pattern .h_pattern .txt_02 span {
  display: inline-block;
  font-size: 16px;
  color: #000;
  line-height: 1;
  border: 1px solid #000;
  padding: .3em .4em;
}

#features #feature_3 .pattern .example .h {
  font-size: 15px;
  font-weight: bold;
}

#features #feature_3 .pattern .example .txt {
  margin-bottom: 8px;
  font-size: 15px;
  line-height: 1.5;
}

#features #feature_3 .pattern .img {
  display: block;
  width: 70%;
  margin: 15px auto;
}

#features #feature_3 .pattern .img--100p {
  width: 100%;
}

#features #feature_3 .pattern .img_caption {
  font-size: 11px;
  font-weight: 300;
  text-align: center;
  margin-top: -0.4em;
}

#features #feature_3 .pattern .example_name {
  margin-top: 2px;
  margin-bottom: 5px;
  font-size: 15px;
  font-weight: bold;
}

#features #feature_3 .pattern .annotation_list_1em {
  margin-top: 6px;
  line-height: 1.6;
} 

#features #feature_3 .options {
  display: grid;
  grid-template-rows: auto 1fr;
}

#features #feature_3 .options_list {
  display: grid;
  grid-template-rows: 1fr auto;
  background-color: #F2F2F2;
  border-radius: 6px;
}

#features #feature_3 .options_list > ul {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: auto auto;
  gap: 5px 12px;
  padding: 18px 18px 10px;
}

#features #feature_3 .options_list > ul li {
  /* subgridに対応していないスマホ環境のため、jsで高さ調整 */
  /*display: grid;
  grid-template-rows: subgrid;
  grid-row: span 2;*/
}

#features #feature_3 .options_list > ul li .option_name {
  margin-bottom: 6px;
  font-size: 13px;
  line-height: 1.4;
}

#features #feature_3 .options_list > ul li .option_img {
  margin-bottom: 15px;
}

#features #feature_3 .options_list > ul .option_annotation {
  margin-top: 8px;
  text-indent: -1.3em;
  padding-left: 1.3em;
  font-size: 11px;
  line-height: 1.5;
}

#features #feature_3 .options_list .options_price {
  padding: 2px 0 20px;
  font-size: 15px;
  font-weight: bold;
  text-align: center;
  line-height: 1.6;
}

#features #feature_3 .annotation_txt {
  margin-top: -10px;
  margin-bottom: 20px;
  color: #ea0000;
  font-size: 19px;
  font-weight: bold;
}

/* feature_4 */
#features #feature_4 .img_1 {
  display: block;
  width: 774px;
  margin: 38px auto 0;
}

/* feature_5 */
#features #feature_5 .modal-04-inner-upper {
  width: 908px;
  margin: 50px -24px 0;
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: space-between;
  align-items: flex-start;
}

#features #feature_5 .modal-04-inner-upper .left_img {
  margin-top: -20px;
}

#features #feature_5 .modal-04-inner-upper-right {
  margin-left: 50px;
  background: #F2F2F2;
  padding: 18px 30px 25px;
  width: 100%;
  line-height: 1.5;
  border-radius: 6px;
}

#features #feature_5 .modal-04-inner-upper-right .before_after {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0 77px;
  margin-bottom: 20px;
}
#features #feature_5 .modal-04-inner-upper-right .before_after > div {
  /* subgridに対応していないスマホ環境のため、jsで高さ調整 */
  /*display: grid;
  grid-template-rows: auto auto auto;
  grid-row: span 3;*/
  position: relative;
}

#features #feature_5 .modal-04-inner-upper-right .before_after .h {
  display: table-cell;
  vertical-align: bottom;
  padding-top: 0;
  font-size: 14px;
  font-weight: bold;
}
#features #feature_5 .modal-04-inner-upper-right .before_after p {
  display: block;
  padding-top: 4px;
  font-size: 14px;
}
#features #feature_5 .modal-04-inner-upper-right .before_after .before:after {
  content: url(../img/feature_5_arrow.png);
  position: absolute;
  top: 102px;
  right: -45px;
}

#features #feature_5 .modal-04-inner-upper-right .before_after img {
  width: 100%;
  padding-top: 6px;
  margin-bottom: 2px;
}

#features #feature_5 .modal-04-inner-upper-right ul li {
  font-size: 12px;
}
#features #feature_5 .modal-04-inner-bottom {
  width: 908px;
  margin: 25px -24px 0;
  border: 1px solid #84754e;
  padding: 20px 20px 18px;
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: space-between;
  align-items: flex-start;
  box-sizing: border-box;
  font-size: 17px;
  line-height: 1.5;
}
#features #feature_5 .modal-04-inner-bottom .txt_box {
  padding-right: 30px;
}
#features #feature_5 .modal-04-inner-bottom .ttl {
  font-weight: bold;
  margin-bottom: 10px;
}

#features #feature_5 .modal-04-inner-bottom .img {
  width: 163px;
}

/* feature_6 */
#features #feature_6 .img_1 {
  display: block;
  width: 885px;
  margin: 40px -12px 0 -13px;
}


/* -- lineup -- */

#lineup {
  padding-top: 80px;
}

#lineup h2 {
  margin-bottom: 22px;
  font-size: 40px;
  font-weight: 700;
  text-align: center;
  letter-spacing: 0.075em;
}

#lineup .table-area {
  margin-bottom: 60px;
}

#lineup table {
  width: 100%;
  font-size: 15px;
  line-height: 1.5;
  font-weight: normal;
  letter-spacing: 0.03em;
  box-sizing: border-box;
}

#lineup table tr:nth-child(even) {
  background: #F2F2F2;
}
#lineup table th,
#lineup table td {
  border: 1px solid #707070;
  padding: 6px 8px;
  vertical-align: middle;
  box-sizing: border-box;
}
#lineup table th {
  font-weight: normal;
  white-space: nowrap;
}
#lineup table thead td {
  text-align: center;
}
#lineup table tbody th {
  text-align: left;
}

#lineup table tbody th span {
  font-size: 80%;
}

#lineup table .small {
  font-size: 84%;
  display: block;
}

#lineup table .img {
  width: 180px;
  margin: 8px 0;
}

#lineup table .btn {
  width: 200px;
  background: #1B365D;
  color: #FFF;
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: center;
  align-items: center;
  text-decoration: none;
  padding: 10px 0;
  transition: .2s;
  margin: 0 auto;
  border-radius: 3px;
} 

#lineup table .btn_cell th,
#lineup table .btn_cell td {
  height: 90px;
}


/* table-2box */
#lineup .table-2box tbody tr:first-child th:nth-child(1) {
  width: 16%;
}

#lineup .table-2box tbody tr:first-child td:nth-child(2) {
  width: 42%;
}


/* table-3box */
#lineup .table-3box tbody tr:first-child th:nth-child(1) {
  width: 16%;
}

#lineup .table-3box tbody tr:first-child td:nth-child(2),
#lineup .table-3box tbody tr:first-child td:nth-child(3) {
  width: 27%;
}


/* replacement_parts */
#lineup #replacement_parts {
  width: 570px;
  margin: 0 auto 60px;
}

#lineup #replacement_parts table tbody tr:nth-child(odd) {
  background: #F2F2F2;
}

#lineup #replacement_parts table tbody tr:nth-child(even) {
  background: none;
}

#lineup #replacement_parts .img_replacement_filter {
  width: 239px;
}

#lineup #replacement_parts .notes {
  margin-top: 25px;
  font-size: 13px;
  text-align: right;
}

/* kadai */
#lineup #kadai .center {
  text-align: center;
}

#lineup #kadai .col_h {
  width: 126px;
}

#lineup #kadai .img_custom_made {
  display: block;
  width: 518px;
  margin: 0 auto;
}

#lineup #kadai .txt_custom_made {
  margin-top: 40px;
  text-align: right;
}



/* -- contact -- */

#contact {
  padding: 100px 0;
  background: #F2F2F2;
  position: relative;
  text-align: center;
}
#contact .cnt_inner {
  position: relative;
  z-index: 10;
}
#contact:before {
  position: absolute;
  content: "";
  display: block;
  width: 1034px;
  height: 370px;
  background: url(../img/contact_bg_01.png) no-repeat;
  background-size: cover;
  top: 0;
  right: 0;
  z-index: 1;
}
#contact:after {
  position: absolute;
  content: "";
  display: block;
  width: 1034px;
  height: 370px;
  background: url(../img/contact_bg_02.png) no-repeat;
  background-size: cover;
  bottom: 0;
  left: 0;
  content: "";
}
#contact .form-area {
  z-index: 20;
  background: #FFF;
  box-shadow: 0px 0px 7px 1px #ccc;
  padding: 50px;
}
#contact .form-area h2 {
  font-size: 36px;
  line-height: 1.5;
  letter-spacing: 0.075em;
  margin-bottom: 30px;
  text-align: center;
  position: relative;
}
#contact .form-area h2:before {
  content: "";
  display: block;
  width: 30px;
  position: absolute;
  bottom: -12px;
  border-bottom: 2px solid #84754e;
  left: calc((100% - 30px) / 2);
}
#contact .form-area .formTable {
  width: 800px;
  margin: 50px auto;
  text-align: left;
}
#contact .form-area .formTable th,
#contact .form-area .formTable td {
  padding: 10px 0;
  font-weight: normal;
}
#contact .form-area .formTable th {
  letter-spacing: 0.075em;
}
#contact .form-area .formTable th.up,
#contact .form-area .formTable td.up {
  vertical-align: top;
  padding-top: 20px;
}
#contact .form-area .formTable input,
#contact .form-area .formTable textarea {
  padding: 10px;
  width: 100%;
  border: 1px solid #C1B9B9;
  font-size: 16px;
  line-height: 1.4;
  font-weight: normal;
  letter-spacing: 0;
  font-family: "Noto Sans JP", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", verdana, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", Sans-Serif;
  box-sizing: border-box;
}
/* radio */
#contact .formTable input[type=radio] {
  display: inline-block;
  margin-right: 6px;
}

#contact .formTable input[type=radio] + label {
  position: relative;
  display: inline-block;
  margin-right: 12px;
  cursor: pointer;
}

#contact .formTable input[type=radio] {
  display: none;
  margin: 0;
  padding:0;
}

#contact .formTable input[type=radio] + label {
  padding: 0 0 0 26px;
  margin:0;
}

#contact .formTable input[type=radio] + label::before{
  content: "";
  position: absolute;
  top: 4px;
  left: 0;
  box-sizing: border-box;
  display: block;
  width: 20px;
  height: 20px;
  border-radius: 30px;
  border: 1px solid #c0c0c0;
  background:#fff;
}

#contact .formTable input[type=radio] + label::after {
  -webkit-transition: opacity 0.2s linear;
  transition: opacity 0.2s linear;
  content: "";
  position: absolute;
  display: block;
  top: 6px;
  left: 5px;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  width: 10px;
  height: 10px;
  margin-top: 3px;
  background: #aa9f71;
  border-radius: 10px;
  opacity: 0;
}

#contact .formTable input[type=radio]:checked + label::after {
	opacity: 1;
}

#contact .formTable .radio_document_request {
  display: flex;
  padding: 5px 0;
}

#contact .formTable .radio_document_request li {
  margin-right: 20px;
}
#contact .form-area .att {
  font-size: 12px;
}
#contact .form-area .btn-area {
  margin: 50px auto 0;
}
#contact .form-area .btn-area input {
  width: 215px;
  background: #84754e;
  color: #FFF;
  font-size: 16px;
  line-height: 1;
  font-weight: normal;
  letter-spacing: 0.1em;
  padding: 15px 0;
  border: none;
  cursor: pointer;
}
#contact .form-area .btn-area input:hover {
  background: #D1C498;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
}



@media screen and ( max-width:767px) {

  /* -- common -- */

  .cnt_inner {
    width: 92%;
  }

  .pc_br {
    display: none;
  }

  .sp_br {
    display: inline;
  }


  /* -- kv -- */

  #kv {
    margin-bottom: 25px;
  }


  /* -- intro -- */

  #intro {
    margin-bottom: 30px;
    font-size: calc(100vw / ( 375 / 17 ));
  }

  #intro .underline_txt .line {
    display: inline-block;
  }

  #intro .underline_txt .line::before {
    bottom: 0;
    height: 11px;
  }

  #intro .notes_txt {
    margin-top: 16px;
    font-size: calc(100vw / ( 375 / 11 ));
  }


  /* -- features -- */

  #features {
    position: relative;
    padding: 10px 0 30px;
  }

  #features .cnt_inner {
    width: 100%;
  }

  #features::before {
    top: 65.7vw;
    height: calc(100% - 65.7vw);
  }

  #features .features_head {
    width: 92%;
    padding-bottom: 11.3%;
    margin: 0 auto 30px;
  }

  #features .features_head .inner {
    width: 100%;
    margin-left: 0;
    padding-top: 0;
  }

  #features h2 {
    margin-bottom: 10px;
    font-size: calc(100vw / ( 375 / 26 ));
  }

  #features .features_list {
    width: 76.8%;
    padding: 5.5% 0 4.5% 6.2%;
    border-radius: 10px;
    box-sizing: border-box;
  }

  #features .features_list li {
    padding-bottom: 2.5%;
  }

  #features .features_list a {
    padding-left: 0;
    font-size: calc(100vw / ( 375 / 18 ));
    background-position: 0 5px;
    background-size: 5.3vw;
  }

  #features .features_list .line {
    margin-left: 11%;
    display: inline-block;
  }

  #features .features_list .line::before {
    bottom: 3px;
  }

  #features .product {
    bottom: 0;
    right: -1%;
    padding-bottom: 29.4%;
    width: 29%;
  }

  #features .sticker {
    position: absolute;
    bottom: 36px;
    right: 0%;
    width: 20vw;
    height: 20vw;
    padding-top: 3%;
    font-size: calc(100vw / ( 375 / 10 ));
    letter-spacing: normal;
  }

  #features .notes {
    bottom: 0px;
    right: 0px;
    width: 76%;
    font-size: 9px;
  }

  /* feature_set */
  #features .feature_set {
    position: relative;
    padding-top: 20px;
    padding-bottom: 30px;
  } 

  #features .feature_set .feature_h {
    padding-bottom: 10px;
    font-size: calc(100vw / ( 375 / 23 ));
  }

  #features .feature_set .feature_h .no img {
    width: 8vw;
    margin-right: 7px;
    padding-top: 1px;
  }

  #features .feature_set .feature_h::before {
    height: 5px;
  }

  #features .feature_set .feature_body {
    padding: 30px 4% 40px;
    font-size: 14px;
    line-height: 1.75;
  }

  #features .feature_set .annotation_list {
    margin-top: 10px;
    font-size: 11px;
  }

  #features .feature_set .annotation_list_1em {
    margin-top: 10px;
    font-size: 11px;
  }

  /* feature_1 */
  #features #feature_1 .img_1 {
    width: 100%;
    margin: 30px 0 0 0px;
  }

  #features #feature_1 .txt_01 {
    padding-top: 5px;
    margin-bottom: 20px;
    font-size: calc(100vw / ( 375 / 20 ));
}

  #features #feature_1 .img_txt_box {
    gap: 20px 10px;
    width: auto;
  } 
  
  #features #feature_1 .img_txt_box dt {
    width: 90px;
  }
  
  #features #feature_1 .img_txt_box dt img {
    width: 100%;
  }
  
  #features #feature_1 .img_txt_box dd {
    font-size: calc(100vw / ( 375 / 16 ));
  }
  
  #features #feature_1 .img_txt_box dd .num {
    padding: 0.15em 0 0 1px;
    font-size: calc(100vw / ( 375 / 15 ));
  }
  
  #features #feature_1 .img_txt_box dd .line {
    border-bottom: 1px solid #1b365d;
  }

  /* feature_2 */
  #features #feature_2 .img_flex {
    justify-content: center;
    flex-wrap: wrap;
    margin-top: 35px;
  }

  #features #feature_2 .img_flex .img {
    width: 80%;
  }

  #features #feature_2 .img_flex .img:nth-child(1) {
    margin-bottom: 35px;
  }

  #features #feature_2 .img_flex .img_txt {
    margin-top: 8px;
    font-size: calc(100vw / ( 375 / 18 ));
  }
  
  #features #feature_2 .img_flex .img_txt span {
    margin: 0 1px;
    font-size: calc(100vw / ( 375 / 21 ));
  }

  /* feature_3 */
  #features #feature_3 .pattern {
    grid-template-columns: 1fr;
    gap: 0px 20px;
    width: 100%;
    margin: 30px auto 0px;
  }

  #features #feature_3 .pattern .box {
    gap: 0px;
    margin-bottom: 40px;
  }

  #features #feature_3 .pattern .h_pattern .txt_01 {
    padding: 3px 9px 4px;
    font-size: 12px;
    margin-bottom: 5px;
  }

  #features #feature_3 .pattern .h_pattern .txt_02 {
    padding-bottom: 6px;
    font-size: 17px;
    line-height: 1.5;
  }

  #features #feature_3 .pattern .h_pattern .txt_02 span {
    font-size: 14px;
    padding: .3em .3em;
  }

  #features #feature_3 .pattern .example .h {
    font-size: 13px;
  }

  #features #feature_3 .pattern .example .txt {
    margin-bottom: 8px;
    font-size: 12px;
  }

  #features #feature_3 .pattern .img {
    width: 50%;
    margin: 8px auto;
  }

  #features #feature_3 .pattern .img.img--100p {
    width: 70%;
    margin: 8px auto;
  }

  #features #feature_3 .pattern .example_name {
    margin-top: 2px;
    font-size: 13px;
    line-height: 1.5;
  }

  #features #feature_3 .pattern .annotation_list_1em {
    margin-top: 6px;
    line-height: 1.5;
  } 
  
  #features #feature_3 .options_list > ul {
    padding: 20px 16px 8px 20px;
  }
  
  #features #feature_3 .options_list > ul li .option_name {
    font-size: 12px;
  }
  
  #features #feature_3 .options_list > ul li .option_img {
    margin-bottom: 18px;
  }
  
  #features #feature_3 .options_list > ul .option_annotation {
    margin-top: 10px;
    font-size: 10px;
  } 

  #features #feature_3 .options_list .options_price {
    font-size: 14px;
  }

  #features #feature_3 .annotation_txt {
    font-size: 16px;
    line-height: 1.6;
  }

  /* feature_4 */
  #features #feature_4 .img_1 {
    width: 100%;
    margin-top: 25px;
  }

  /* feature_5 */
  #features #feature_5 .modal-04-inner-upper {
    width: 100%;
    margin: 20px 0 0;
    display: block;
  }

  #features #feature_5 .modal-04-inner-upper > p {
    width: 92%;
    margin: 0 auto;
  }

  #features #feature_5 .modal-04-inner-upper .left_img {
    margin-top: 0;
  }

  #features #feature_5 .modal-04-inner-upper-right {
    margin-left: 0;
    margin-top: 20px;
    padding: 15px;
    box-sizing: border-box;
  }

  #features #feature_5 .modal-04-inner-upper-right .before_after {
    margin-bottom: 10px;
    gap: 0 16%;
  }
  #features #feature_5 .modal-04-inner-upper-right .before_after .h {
    font-size: 13px;
  }
  #features #feature_5 .modal-04-inner-upper-right .before_after .before:after {
    right: -40px;
    top: 88px;
  }
  #features #feature_5 .modal-04-inner-upper-right .before_after p {
    font-size: 11px;
  }

  #features #feature_5 .modal-04-inner-upper-right ul li {
    font-size: 10px;
  }

  #features #feature_5 .modal-04-inner-bottom {
    width: 100%;
    margin: 20px 0 0;
    padding: 14px 10px;
    font-size: 12px;
  }

  #features #feature_5 .modal-04-inner-bottom .txt_box {
    width: 54%;
    padding-right: 0;
  }

  #features #feature_5 .modal-04-inner-bottom .ttl {
    font-size: 13px;
    margin-bottom: 6px;
  }

  #features #feature_5 .modal-04-inner-bottom .img_box {
    width: 41%;
  } 
  
  #features #feature_5 .modal-04-inner-bottom .img {
    width: 100%;
  }

  /* feature_6 */
  #features #feature_6 .img_1 {
    width: 100%;
    margin: 30px auto 0;
  }


  /* -- lineup -- */

  #lineup {
    padding-top: 38px;
  }

  #lineup h2 {
    margin-bottom: 20px;
    font-size: calc(100vw / ( 375 / 26 ));
  }

  #lineup .table_area_flex {
    flex-wrap: wrap;
  }

  #lineup .table-area {
    width: 100%;
    margin-bottom: 30px;
    padding-bottom: 12px;
    overflow: scroll;
  }

  #lineup table {
    font-size: 12px;
  }

  #lineup table th,
  #lineup table td {
    padding: 6px 8px;
  }

  #lineup table .img {
    width: 140px;
    margin: 8px 0;
  }

  #lineup table .btn {
    width: 180px;
  } 

  /* replacement_parts */
  #lineup #replacement_parts {
    width: 100%;
    margin-bottom: 40px;
  }

  #lineup #replacement_parts .img_replacement_filter {
    width: 180px;
  }

  #lineup #replacement_parts .notes {
    margin-top: 10px;
    font-size: 11px;
    text-align: left;
  }

  /* kadai */
  #lineup #kadai {
    width: 100%;
  }

  #lineup #kadai .col_h {
    width: auto;
  }

  #lineup #kadai .img_custom_made {
    width: 390px;
  }

  #lineup #kadai .txt_custom_made {
    margin-top: 30px;
  }


  /* -- contact -- */

  #contact {
    padding: 30px 0;
  }

  #contact:before {
    width: 70%;
    height: 50vw;
  }

  #contact:after {
    width: 70%;
    height: 50vw;
  }

  #contact .form-area {
    padding: 10px;
    background: none;
    box-shadow: none;
  }

  #contact .form-area h2 {
    font-size: calc(100vw / ( 375 / 23 ));
    line-height: 1.5;
    letter-spacing: 0.075em;
    margin-bottom: 20px;
  }

  #contact .form-area h2:before {
    bottom: -8px;
  }

  #contact .form-area .formTable {
    width: 100%;
    margin: 20px auto;
  }

  #contact .form-area .formTable th,
  #contact .form-area .formTable td {
    display: block;
    padding: 5px 0;
  }

  #contact .form-area .btn-area {
    margin-top: 20px;
  }

}



.img2{
width:250px;
}



/* ==========

修正対応用

========== */

.kakunin {
  color: red;
  background-color: rgb(248, 224, 224);
}