@charset "UTF-8";

/* 下層ページ　共通設定 */
.sub-mv .sub-title {
    text-align: center;
    background-color: #DC000C;
    padding: 24px 0;
}
.sub-mv .sub-title p {
    color: #FFAF00;
    font-size: 22px;
    margin-bottom: 6px;
}
.sub-mv .sub-title h1 {
    color: #fff;
    font-size: 40px;
}
@media screen and (max-width: 960px) {
  .sub-mv .sub-title p {
    font-size: 20px;
  }
  .sub-mv .sub-title h1 {
    font-size: 32px;
  }
}
@media screen and (max-width: 767px) {
  .sub-mv .sub-title p {
    font-size: 18px;
  }
  .sub-mv .sub-title h1 {
    font-size: 26px;
  }
}
@media screen and (max-width: 540px) {
  .sub-mv .sub-title p {
    font-size: 16px;
  }
  .sub-mv .sub-title h1 {
    font-size: 22px;
  }
}

/* 料金一覧 rental */
.price {
    padding-top: 60px;
    margin-bottom: 60px;
}
.price .title-area {
    position: relative;
}
.price h2 {
    font-size: 22px;
    background-color: #0092E5;
    color: #fff;
    text-align: left;
    padding: 20px 30px;
}
#kw1 .title-area h2,#kw2 .title-area h2 {
    background-color: #DC000C;
}
.price .title-area img {
    position: relative;
    top: -40px;
    left: 50%;
    transform: translateX(-50%);
    width: 540px;
    object-fit: contain;
    display: flex;
}
.price .title-area .van4-img {
    top: -20px;
}
.price .kome-area {
    margin-bottom: 30px;
}
.price .kome-area p {
    font-size: 14px;
    margin-bottom: 6spx;
}
.price .class {
    margin-bottom: 30px;
}
.price .class h3 {
    font-size: 20px;
    margin-bottom: 10px;
}
.price table {
    width: 100%;
    border-collapse: collapse;
    text-align: center;
    color: #1A1311;
}
.price .table-title {
    background-color: #FFAF00;
    color: #1A1311;
    font-size: 18px;
    font-weight: bold;
    padding: 10px 0;
    text-align: center;
}
.price thead th:not(.table-title) {
    background-color: #0092E5;
    color: #fff;
    padding: 10px 8px;
    font-weight: bold;
    border: 1px solid #1A1311;
    text-align: center;
}
.price tbody .row-header {
    background-color: #CDEAFA;
    font-weight: bold;
    padding-left: 15px;
}
.price tbody td {
    padding: 15px 8px;
    border: 1px solid #1A1311;
    font-weight: bold;
    letter-spacing: 1px;
}
#kw1 .table-title,#kw2 .table-title {
    background-color: #0092E5;
    color: #fff;
}
#kw1 th:not(.table-title),#kw2 th:not(.table-title) {
    background-color: #FFAF00;
    color: #1A1311;
}
#kw1 tbody .row-header,#kw2 tbody .row-header {
    background-color: #FFEFCD;
}
.price .table-br {
  display: none;
}
@media screen and (max-width: 960px) {
.price {
    padding-top: 40px;
    margin-bottom: 40px;
}
.price h2 {
  font-size: 20px;
  padding: 15px 20px;
}
.price .title-area img {
  width: 60%;
  top: 20px;
  margin-bottom: 30px;
}
.price .title-area .van4-img {
  top: 20px;
}
.price .class h3 {
    font-size: 18px;
}
.price .table-title {
  font-size: 16px;
}
.price thead th:not(.table-title),.price tbody td {
  font-size: 14px;
  letter-spacing: .3px;
}
}
@media screen and (max-width: 600px) {
  .price h2 {
    font-size: 16px;
    padding: 10px;
  }
  .price .class h3 {
      font-size: 16px;
  }
  .price .title-area img {
    width: 80%;
  }
  .price .table-title {
      font-size: 14px;
  }
  .price thead th:not(.table-title),.price tbody td {
  font-size: 12px;
  }
  .price .table-container {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  width: 100%;
  }
  .price table {
     width: 100%;
     border-collapse: collapse;
  }
  .price table th,.price table td {
    white-space: nowrap;
  }
  .price .table-br {
    display: block;
  }
}
@media screen and (max-width: 390px) {
    .price h2 {
        font-size: 14px;
    }
    .price .class h3 {
        font-size: 14px;
    }
}

/* ご予約の流れ flow */
#flow {
  padding: 60px 0;
  overflow: hidden;
}
#flow ul {
  display: flex;
  flex-direction: column;
  row-gap: 60px;
}
#flow .step {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  column-gap: 40px;
}
#flow .step-area {
  max-width: 84px;
  margin-bottom: 20px;
}
#flow .text-box {
  padding-left: 20px;
}
#flow .text-box h2 {
  font-size: 24px;
  color: #0092E5;
  margin-bottom: 20px;
}
#flow .text-box .kome {
  font-size: 14px;
  padding-top: 20px;
  margin-bottom: 30px;
}
#flow .text-box .btn-area {
  display: flex;
  justify-content: center;
}
#flow .text-box .btn-area .btn {
  display: block;
  background-color: #06C755;
  border-radius: 20px;
  color: #fff;
  font-size: 24px;
  font-weight: bold;
  padding: 10px;
  width: 400px;
  text-align: center;
  box-shadow: 3px 3px 6px #DADADA;
}
#flow .text-box .fax-btn-area {
  padding-top: 40px;
  margin-bottom: 20px;
}
#flow .text-box .fax-btn-area .btn {
  background-color: #DC000C;
}
@media screen and (max-width: 1200px) {
  #flow .step {
    column-gap: 3%;
  }
}
@media screen and (max-width: 1024px) {
  #flow .step-area {
    max-width: 70px;
    margin-bottom: 10px;
  }
  #flow .text-box .btn-area .btn {
    font-size: 20px;
    width: 350px;
  }
  #flow .text-box .kome {
    margin-bottom: 20px;
  }
}
  @media screen and (max-width: 960px) {
  #flow {
  padding: 40px 0 60px;
  }
  #flow .text-box .fax-btn-area {
      padding-top: 20px;
  }
  }
  @media screen and (max-width: 767px) {
  #flow .step-area {
    max-width: 56px;
  }
  #flow .text-box h2 {
    font-size: 22px;
    margin-bottom: 10px;
  }
  #flow .text-box {
      padding-left: 0px;
  }
  #flow .text-box .kome {
    font-size: 12px;
    padding-top: 10px;
  }
  #flow .text-box .fax-btn-area {
    margin-bottom: 10px;
  }
  #flow .text-box .btn-area .btn {
      font-size: 15px;
      width: 250px;
  }
}
@media screen and (max-width: 600px) {  
    #flow .step {
      display: flex;
      flex-direction: column;
      row-gap: 20px;
      width: 80%;
      margin: 0 auto;
    }
    #flow .step-reverse {
      flex-direction: column-reverse;
    }
    #flow .text-box h2 {
    font-size: 20px;
    }
}
@media screen and (max-width: 540px) {
    #flow ul {
      row-gap: 50px;
    }
    #flow .step {
      width: 100%;
    }
    #flow .step-area {
      margin: 0 auto 10px;
    }
    #flow .text-box h2 {
    font-size: 18px;
    text-align: center;
    }
}

/* ご予約の流れ insurance */
#insurance {
  background-color: #CCE9FA;
  position: relative;
}
#insurance .title-wrapper {
    top: -40px;
    margin-right: 60%;
    width: 40%;
    position: relative;
    display: flex;
    justify-content: center;
    background-color: #0092E5;
    border-radius: 0 40px 40px 0;
    height: 80px;
}
#insurance .title-inner {
    max-width: 1200px;
    width: 100%;
    box-sizing: border-box;
    position: relative;
    margin-left: 10%;
    display: flex;
    justify-content: center;
}
#insurance .title-area {
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
}
#insurance .title-area h2 {
    color: #fff;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    margin-left: 0;
    text-align: center;
}
#insurance .section-inner {
    padding: 20px 30px 60px;
}
#insurance .content {
  background-color: #fff;
}
#insurance .content01 {
  padding: 20px;
}
#insurance .content ul li {
  margin-bottom: 40px;
}
#insurance .content ul .list03 {
  margin-bottom: 0;
}
#insurance h3 {
  position: relative;
  font-size: 28px;
  color: #0092E5;
  padding-left: 34px;
  margin-bottom: 10px;
}
#insurance h3::before {
  content: '';
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 28px;
  height: 28px;
  background: #0092E5;
  border-radius: 50%;
  box-sizing: border-box;
}
#insurance .kome {
  padding-top: 20px;
  margin-bottom: 20px;
  font-weight: bold;
}
#insurance .list01 table {
    width: 100%;
    border-collapse: collapse;
    background-color: #fff;
}
#insurance .list01 thead th {
    background-color: #0092E5;
    color: white;
    padding: 10px;
    text-align: center;
    border: 1px solid #0056b3;
}
#insurance .list01 tbody td {
    background-color: #fff;
    padding: 10px;
    text-align: center;
    font-weight: bold;
    border: 1px solid #0056b3;
}
#insurance .list02 .container {
    display: grid;
    grid-template-columns: repeat(2,1fr);
    column-gap: 30px;
    justify-content: center;
}
#insurance .list02 .car-card {
    border: 1px solid #DC000B;
    background-color: #fff;
    display: flex;
    flex-direction: column;
}
#insurance .list02 .card-header {
    background-color: #DC000C;
    color: #fff;
    padding: 10px 20px;
    text-align: center;
    font-weight: bold;
    display: flex;
    align-items: center;
    justify-content: center;
}
#insurance .list02 .card-header p {
    padding-left: 150px;
}
#insurance .list02 .card-body {
    display: flex;
    align-items: center;
    padding: 15px;
    background-color: #fff;
    min-height: 40px;
    position: relative;
}
#insurance .list02 .car-image {
    margin-right: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    position: absolute;
    top: -50px;
    left: 24%;
    transform: translateX(-50%);
}
#insurance .list02 .car-image img {
    max-width: 100%;
    height: auto;
    display: block;
}
#insurance .list02 .car-card01 .car-image {
  width: 140px;
}
#insurance .list02 .car-card02 .car-image {
  width: 170px;
}
#insurance .list02 .car-details {
    flex-grow: 1;
    text-align: center;
    padding-left: 140px;
    color: #1A1311;
    font-weight: bold;
}
#insurance .list02 .car-details p {
    margin: 0;
}
#insurance .list03 ul {
  display: grid;
  grid-template-columns: repeat(2,1fr);
  column-gap: 30px;
}
#insurance .list03 ul li {
  display: grid;
  grid-template-columns: 60% 40%;
  border: 1px solid #DC000B;
}
#insurance .list03 ul li .left {
  background-color: #DC000C;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 10px;
  font-size: 16px;
}
#insurance .list03 ul li .right {
  background-color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  font-weight: bold;
  padding: 10px;
}
#insurance .content02 {
  border: 5px solid #0092E4;
  border-radius: 20px 20px 0 0;
  overflow: hidden;
}
#insurance .content02 .title-area {
  background-color: #0092E5;
  text-align: center;
  padding: 15px;
  display: block;
}
#insurance .content02 .title-area h3 {
  color: #fff;
  margin-bottom: 0;
  padding-left: 0;
}
#insurance .content02 .title-area h3::before {
  display: none;
}
#insurance .content02 .title-area p {
  color: #fff;
  font-weight: bold;
}
#insurance .content02 ol {
  padding: 30px 60px;
  counter-reset: step;
}
#insurance .content02 ol li {
  position: relative;
  padding-left: 48px;
  margin-bottom: 24px;
  list-style: none;
  counter-increment: step;
}
#insurance .content02 ol li h4 {
 font-size: 22px; 
}
#insurance .content02 ol li .text-box {
  padding-top: 10px;
}
#insurance .content02 ol li::before {
  content: counter(step);
  position: absolute;
  left: 0;
  top: 15px;
  transform: translateY(-50%);
  width: 36px;
  height: 36px;
  font-size: 42px;
  background: #0092E5;
  color: #fff;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: bold;
  font-size: 24px;
}
  #insurance .list03 ul li .br2{
    display: none;
  }
@media (max-width: 1700px) {
  #insurance .title-wrapper {
    margin-right: 65%;
    width: 35%;
  } 
  #insurance .title-inner {
    margin-left: 0;
  }
}
@media (max-width: 1250px) {
  #insurance .title-wrapper {
      height: 70px;
  }
  #insurance .title-area {
  justify-content: left;
  padding-left: 30px;
  }
  #insurance .title-area h2 {
      font-size: 26px;
  }
  #insurance h3 {
    font-size: 26px;
  }
  #insurance h3::before {
    width: 26px;
    height: 26px;
  }
  #insurance .list03 ul li .br2{
    display: block;
  }
}
@media (max-width: 960px) {
  #insurance .title-wrapper {
      height: 60px;
      top: -30px;
  }
  #insurance .title-area h2 {
      font-size: 22px;
  }
  #insurance .section-inner {
      padding: 0px 20px 40px;
  }
  #insurance h3 {
    font-size: 24px;
  }
  #insurance h3::before {
    width: 24px;
    height: 24px;
  }
  #insurance .list01 thead th {
    font-size: 14px;
  }
  #insurance .list01 tbody td {
    font-size: 14px;
  }
  #insurance .list02 .container {
    column-gap: 3%;
  }
  #insurance .list02 .car-image {
    top: -35px;
    left: 24%;
  }
   #insurance .list02 .car-card01 .car-image {
    width: 110px;
  }
  #insurance .list02 .car-card02 .car-image {
    width: 130px;
  }
  #insurance .list02 .car-details {
    font-size: 14px;
    padding-left: 120px;
  }
  #insurance .list03 ul {
    column-gap: 3%;
  }
  #insurance .list03 ul li {
    grid-template-columns: 65% 35%;
  }
  #insurance .list03 ul li .left {
    font-size: 13px;
  }
  #insurance .content02 .title-area p {
    font-size: 14px;
  }
  #insurance .content02 ol li::before {
    width: 32px;
    height: 32px;
    font-size: 20px;
  }
  #insurance .content02 ol li h4 {
    font-size: 20px;
  }
}
@media (max-width: 767px) {
  #insurance .title-wrapper {
      height: 50px;
      width: 280px;
      top: -25px;
  }
  #insurance .title-area h2 {
      font-size: 18px;
  }
  #insurance h3 {
    font-size: 22px;
  }
    #insurance h3::before {
    width: 22px;
    height: 22px;
  }
  #insurance .list01 tbody th {
    padding: 10px 5px;
  }
  #insurance .list01 tbody td {
    font-size: 12px;
    padding: 10px 5px;
    letter-spacing: 1px;
  }
  #insurance .list02 .container {
    display: flex;
    flex-direction: column;
    width: 80%;
    margin: 0 auto;
    row-gap: 20px;
  }
  #insurance .list03 ul {
    display: flex;
    flex-direction: column;
    width: 80%;
    margin: 0 auto 40px;
    row-gap: 20px;
  }
  #insurance .list03 ul li {
    grid-template-columns: 60% 40%;
    margin-bottom: 0;
  }
  #insurance .content02 .title-area p {
    text-align: left;
  }
  #insurance .content02 ol {
    padding: 20px 30px;
  }
  #insurance .content02 ol li {
    padding-left: 40px;
    margin-bottom: 20px;
  }
  #insurance .content02 ol li h4 {
    font-size: 18px;
  }
  #insurance .content02 ol li::before {
    width: 28px;
    height: 28px;
    font-size: 18px;
  }
  #insurance .content02 ol li .text-box p {
    padding-left: 1em;
    text-indent: -1em;
  }
}
@media (max-width: 600px) {
  #insurance h3 {
    font-size: 20px;
    padding-left: 26px;
  }
    #insurance h3::before {
    width: 20px;
    height: 20px;
  }
#insurance .list01 .container {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  width: 100%;
}
#insurance .list01 table {
  width: 100%;
  border-collapse: collapse;
}
#insurance .list01 thead th,#insurance .list01 thead td {
  white-space: nowrap;
  font-size: 12px;
}
  #insurance .list02 .container {
    width: 100%;
  }
  #insurance .list03 ul {
    width: 100%;
  }
  #insurance .content02 ol li h4 {
    font-size: 16px;
  }
  #insurance .content02 ol li::before {
    width: 26px;
    height: 26px;
    font-size: 16px;
    top: 12px;
    padding-left: 2px;
  }
}
@media (max-width: 540px) {
  #insurance .title-wrapper {
    height: 40px;
    width: 240px;
    top: -20px;
  }
  #insurance .title-area h2 {
      font-size: 16px;
  }
  #insurance .content02 ol {
    padding: 20px;
  }
  #insurance .content02 ol li {
    padding-left: 34px;
  }
  #insurance .content02 ol li .text-box p,  #insurance .content02 .last-kome {
    font-size: 12px;
  }
}
@media (max-width: 430px) {
  #insurance .list03 ul li {
    grid-template-columns: 65% 35%;
  }
  #insurance .list03 ul li .left {
    font-size: 11px;
  }
  #insurance .kome {
    font-size: 12px;
    padding-top: 10px;
  }
  #insurance .content02 ol li {
    padding-left: 30px;
  }
  #insurance .content02 ol li h4 {
    font-size: 14px;
  }
  #insurance .content02 ol li::before {
    width: 22px;
    height: 22px;
    font-size: 14px;
  }
}
@media (max-width: 390px) {
  #insurance h3 {
    font-size: 16px;
    padding-left: 22px;
  }
    #insurance h3::before {
    width: 16px;
    height: 16px;
  }
  #insurance .list02 .card-header p {
    padding-left: 120px;
}
  #insurance .list02 .card-body {
    padding: 6px;
  }
  #insurance .list02 .car-card01 .car-image {
    width: 100px;
  }
  #insurance .list02 .car-card02 .car-image {
    width: 110px;
    top: -30px;
  }
  #insurance .list02 .car-details {
    font-size: 12px;
    letter-spacing: .5px;
    padding-left: 100px;
  }
  #insurance .list03 ul li {
    display: flex;
    flex-direction: column;
  }
  #insurance .list03 ul li .left {
    font-size: 12px;
  }
  #insurance .list03 ul li .right {
    height: 50px;
  }
  #insurance .content02 .title-area h3::before {
    display: none;
  }
  #insurance .content02 .title-area {
    padding: 10px;
  }
  #insurance .content02 .title-area p {
    font-size: 10px;
  }
  #insurance .content02 ol {
    padding: 20px 10px;
  }
}

/* お問い合わせ contact */
#contact {
    padding: 30px 0 60px;
}
#contact .text-area1 {
    font-size: 16px;
    margin-bottom: 80px;
}
.contact-form {
  max-width: 1000px;
  margin: 0 auto;
}
.form-item {
  display: flex;
}
.form-item:first-child {
  border-top: none;
}
.form-item dt {
  width: 25%;
  display: flex;
  align-items: start;
  justify-content: right;
  line-height: 1.2;
  padding: 20px 15px 15px;
  display: flex;
  align-items: flex-start;
}
.form-item dt label {
  font-size: 16px;
  font-weight: bold;
  display: flex;
  align-items: center;
}
.form-item dt label span{
  color: #fff;
  background-color: #DC000C;
  font-size: 12px;
  font-weight: initial;
  padding: 6px 10px;
  border-radius: 10px;
  margin-left: 6px;
}
.form-item dd {
  width: 75%;
  display: flex;
  align-items: center;
  padding: 15px;
}
.form-item dd p {
    width: 100%;
}

/* 年齢入力欄のグループ */
.form-item dd.age-group {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
}
.age-input-wrapper {
    display: flex;
    align-items: center;
    margin-bottom: 5px;
}
.caution-text {
    font-size: 14px;
    margin-left: 0;
}
.form-item .age-group input {
  width: 100px;
  margin-right: 10px;
}
.form-checkbox-group {
  column-gap: 40px;
}
.form-checkbox-group label{
  display: flex;
  align-items: center;
}
input[type="checkbox"] {
  position: relative;
  width: 14px;
  height: 14px;
  border: 1px solid #1A1311;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
}
input[type="checkbox"]:checked:before {
  position: absolute;
  top: 3px;
  left: 7px;
  transform: rotate(50deg);
  width: 5px;
  height: 10px;
  border-right: 2px solid #1A1311;
  border-bottom: 2px solid #1A1311;
  content: '';
}
input[type="radio"] {
  position: relative;
  width: 18px;
  height: 18px;
  border: 1px solid #1A1311;
  border-radius: 50%;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  vertical-align: middle;
  margin-right: 5px;
}
input[type="radio"]:checked:before {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background-color: #1A1311;
}
.form-control {
  border: 1px solid #1A1311;
  padding: 10px 15px;
  width: 100%;
  line-height: 1.2;
  font-size: 16px;
  text-align: left;
}
.form-control:focus,
.form-textarea:focus {
  border-color: #007bff;
  outline: none;
  box-shadow: 0 0 0 0.2rem rgba(0, 123, 255, 0.25);
}
.form-textarea {
  border: 1px solid #1A1311;
  width: 100%;
  height: 150px;
  padding: 10px 15px;
  font-size: 16px;
  text-align: left;
}
#contact .text-area2 {
    padding-top: 50px;
}
#contact .text-area2 h2 {
    font-size: 22px;
    margin-bottom: 30px;
    text-align: center;
}
#contact .text-area2 .text-box {
    border: 1px solid #1A1311;
    padding: 30px;
    max-width: 1000px;
    margin: 0 auto;
}
#contact .text-area2 .text {
    margin-bottom: 30px;
}
#contact .text-area2 p {
    font-size: 14px;
    line-height: 1.5;
}
#contact .check-area {
    text-align: center;
    padding-top: 40px;
    margin-bottom: 50px;
}
#contact .check-area label{
    font-weight: bold;
    display: flex;
    align-items: center;
    justify-content: center;
}
#contact .check-area .confirm-checkbox {
    width: 20px;
    height: 20px;
    margin-right: 10px;
    vertical-align: middle;
    border: 1px solid #1A1311;
}
.submit-area {
  padding-top: 40px;
  text-align: center;
}
.submit-button {
  display: flex;
  align-items: center;
  font-size: 24px;
  font-weight: bold;
  letter-spacing: 2px;
  color: #fff;
  background-color: #DC000C;
  padding: 12px;
  min-width: 400px;
  position: relative;
  margin: 0 auto 20px;
  justify-content: center;
  border-radius: 20px;
}
@media screen and (max-width: 1024px) {
  #contact .text-area1 {
    margin-bottom: 50px;
  }
  .form-item dt {
    width: 30%;
  }
  .form-item dd {
    width: 70%;
  }
}
@media screen and (max-width: 960px) {
  .form-item dt {
    padding: 15px 10px 15px 0;
  }
  .form-item dt label span {
    font-size: 10px;
  }
  .form-item dt label,.form-checkbox-group label {
    font-size: 14px;
  }
  .form-control,.form-textarea {
    font-size: 14px;
  }
  .form-checkbox-group {
    column-gap: 3%;
  }
  .caution-text {
    font-size: 12px;
  }
}
@media screen and (max-width: 767px) {
.form-item {
  flex-direction: column;
}
.form-item dt {
  width: 100%;
  justify-content: left;
  padding: 0px 10px 0 0;
}
.form-item dd {
    width: 100%;
}
.submit-area {
  padding-top: 0;
}
.submit-button {
    font-size: 20px;
    min-width: 300px;
}
}
@media screen and (max-width: 600px) {
#contact .text-area1 {
    font-size: 14px;
}
#contact .text-area2 h2 {
    font-size: 18px;
    margin-bottom: 20px;
}
#contact .text-area2 .text-box {
  padding: 20px;
}
#contact .text-area2 .text {
    margin-bottom: 20px;
}
#contact .text-area2 p {
  font-size: 12px;
}
#contact .check-area {
    padding-top: 30px;
    margin-bottom: 30px;
}
.submit-button {
    font-size: 16px;
    min-width: 240px;
}
}
@media screen and (max-width: 540px) {
.form-textarea {
  height: 200px;
}
.form-checkbox-group {
  flex-wrap: wrap;
}
.form-checkbox-group label {
  margin-bottom: 10px;
}
}
@media screen and (max-width: 390px) {
  .form-item dd {
    padding: 15px 0;
  }
}