.text01{
    color: #fff;
    font-size: 1.8rem;
    padding: 2rem;
}

/*--------------------
  price
------------------- */
.sub_price {
  background-color: #343434;
  padding: 8rem 0 2rem;
}

.sub_price_ttl {
  color: #fff;
  font-size: 6rem;
  font-weight: 900;
  letter-spacing: calc(200em/1000);
  position: relative;
  text-align: center;
}


.sub_price_ttl span {
  position: relative;
}

.sub_price_car_list {
  display: flex;
  gap: 4.5rem;
  justify-content: center;
  margin-top: 5rem;
  position: relative;
}

.sub_price_car_list .car {
  background-color: #fff;
  max-width: 35rem;
}

.sub_price_car_list.slick {
  display: block;
  margin: 5rem auto 0;
  max-width: 158rem;
}

.sub_price_car_list.slick .car {
  margin: 0 2.25rem;
  max-width: none;
}

.sub_price_car_list.slick .slick-prev {
  background-image: url(/assets/img/top/icon_price_car_list_prev.webp);
  background-repeat: no-repeat;
  background-size: cover;
  font-size: 0;
  height: 7.3rem;
  left: -9.55rem;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 7.3rem;
}

.sub_price_car_list.slick .slick-next {
  background-image: url(/assets/img/top/icon_price_car_list_next.webp);
  background-repeat: no-repeat;
  background-size: cover;
  font-size: 0;
  height: 7.3rem;
  position: absolute;
  right: -9.55rem;
  top: 50%;
  transform: translateY(-50%);
  width: 7.3rem;
}

.sub_price_car_list .car .ttl {
  color: #00abb9;
  font-size: 2.3rem;
  font-weight: 900;
  margin-top: 2rem;
  text-align: center;
}

.sub_price_car_list .car .content {
  padding: 2.5rem;
}

.sub_price_car_list .car .normal {
  align-items: center;
  display: flex;
}

.sub_price_car_list .car .normal dt {
  align-items: center;
  border: #343434 1px solid;
  border-radius: .3rem;
  display: flex;
  font-size: 1.8rem;
  font-weight: 500;
  height: 2.9rem;
  justify-content: center;
  width: 7.3rem;
}

.sub_price_car_list .car .normal dd {
  margin-left: 1rem;
}

.sub_price_car_list .car .normal .yen {
  font-size: 1.8rem;
  font-weight: 700;
}

.sub_price_car_list .car .normal .num {
  font-size: 2.7rem;
  font-weight: 900;
}

.sub_price_car_list .car .normal .slash {
  font-size: 2rem;
  font-weight: 500;
  margin: 0 .25em;
}

.sub_price_car_list .car .normal .time {
  font-size: 2rem;
  font-weight: 900;
}

.sub_price_car_list .car .campaign {
  margin-top: 1rem;
}

.sub_price_car_list .car .campaign dt {
  background-color: #ff6c00;
  color: #fff;
  font-size: 1.7rem;
  letter-spacing: calc(100em/1000);
  line-height: 2.2rem;
  text-align: center;
}

.sub_price_car_list .car .campaign dd {
  color: #ff6c00;
  margin-top: 1rem;
  text-align: center;
}

.sub_price_car_list .car .campaign .yen {
  font-size: 2.4rem;
  font-weight: 700;
}

.sub_price_car_list .car .campaign .num {
  font-size: 3.6rem;
  font-weight: 900;
}

.sub_price_car_list .car .campaign .slash {
  font-size: 2.5rem;
  font-weight: 500;
  margin: 0 .25em;
}

.sub_price_car_list .car .campaign .time {
  font-size: 2.5rem;
  font-weight: 900;
}

.sub_price_car_list .car .btn {
  background-color: #06b455;
  background-image: url(/assets/img/top/bg_top_price_car_btn.webp);
  background-position: .8rem center;
  background-repeat: no-repeat;
  background-size: 3.5rem auto;
  border-radius: .5rem;
  color: #fff;
  display: block;
  font-size: 2rem;
  font-weight: 900;
  letter-spacing: calc(100em/1000);
  margin-top: 3rem;
  padding: .3rem 0 .3rem 8.5rem;
}

.sub_price_car_list .car .btn span:first-child {
  font-size: 3.4rem;
}

.sub_price_car_list .car .btn span:last-child {
  font-size: 2.8rem;
}

@media screen and (max-width:767px) {
  .sub_price {
    padding: 3.5rem 0 1rem;
  }

  .sub_price_ttl {
    font-size: 3rem;
  }

  .sub_price_ttl::before {
    background-position: center 2rem;
    background-size: 8.8rem;
    height: 18.2rem;
    top: -11.5rem;
    width: 18.2rem;
  }

  .sub_price_car_list.slick {
    margin-top: 2.5rem;
    max-width: calc(100vw - 5rem);
  }

  .sub_price_car_list.slick .car {
    margin: 0 1rem;
  }

  .sub_price_car_list.slick .slick-prev {
    height: 1.8rem;
    left: -1.7rem;
    width: 1.8rem;
  }

  .sub_price_car_list.slick .slick-next {
    height: 1.8rem;
    right: -1.7rem;
    width: 1.8rem;
  }

  .sub_price_car_list .car .ttl {
    font-size: 1.1rem;
    margin-top: 1rem;
  }

  .sub_price_car_list .car .content {
    padding: 1rem;
  }

  .sub_price_car_list .car .normal dt {
    font-size: 1rem;
    height: 1.2rem;
    width: 3.1rem;
  }

  .sub_price_car_list .car .normal dd {
    margin-left: .5rem;
  }

  .sub_price_car_list .car .normal .yen {
    font-size: 1rem;
  }

  .sub_price_car_list .car .normal .num {
    font-size: 1.2rem;
  }

  .sub_price_car_list .car .normal .slash {
    font-size: 1rem;
  }

  .sub_price_car_list .car .normal .time {
    font-size: 1rem;
  }

  .sub_price_car_list .car .campaign {
    margin-top: .5rem;
  }

  .sub_price_car_list .car .campaign dt {
    font-size: 1rem;
    zoom: .8;
  }

  .sub_price_car_list .car .campaign dd {
    margin-top: .5rem;
  }

  .sub_price_car_list .car .campaign .yen {
    font-size: 1.2rem;
  }

  .sub_price_car_list .car .campaign .num {
    font-size: 1.6rem;
  }

  .sub_price_car_list .car .campaign .slash {
    font-size: 1.2rem;
  }

  .sub_price_car_list .car .campaign .time {
    font-size: 1.2rem;
  }

  .sub_price_car_list .car .btn {
    margin-top: 1rem;
  }

  .sub_price_car_list .car .btn {
    background-size: 1.5rem auto;
    border-radius: .2rem;
    font-size: 1rem;
    margin-top: 1rem;
    padding: .3rem 0 .3rem 3.5rem;
  }

  .sub_price_car_list .car .btn span:first-child {
    font-size: 1.5rem;
  }

  .sub_price_car_list .car .btn span:last-child {
    font-size: 1.2rem;
  }
}
/*--------------------
  flow
------------------- */
.sub_flow {
  padding-bottom: 11rem;
}

.sub_flow_content {
  background-color: #ff6c00;
  margin: 25rem auto 0rem auto;
  max-width: 155rem;
  padding: 8rem 0 11rem;
}

.sub_flow_ttl {
  color: #fff;
  font-size: 6rem;
  font-weight: 900;
  letter-spacing: calc(200em/1000);
  position: relative;
  text-align: center;
}

.sub_flow_ttl::before {
  background-color: #ff6c00;
  background-image: url(/assets/img/top/icon_top_flow_ttl.webp);
  background-position: center 4.3rem;
  background-repeat: no-repeat;
  background-size: 12.7rem;
  border-radius: 19rem;
  content: '';
  height: 36.5rem;
  left: 50%;
  position: absolute;
  top: -23.4rem;
  transform: translateX(-50%);
  width: 36.5rem;
}

.sub_flow_ttl span {
  position: relative;
}

.sub_flow_step {
  position: relative;
}

.sub_flow_step::before {
  background-color: #fff;
  content: '';
  height: 2px;
  left: 0;
  position: absolute;
  top: 17.5rem;
  width: 100%;
}

.sub_flow_step .inner {
  margin: 8rem auto 0;
  max-width: 120rem;
}

.sub_flow_step ol {
  display: flex;
  justify-content: space-between;
}

.sub_flow_step li {
  background-position: center top;
  background-repeat: no-repeat;
  background-size: auto 18.1rem;
  color: #fff;
  font-size: 2rem;
  font-weight: 700;
  letter-spacing: calc(100em/1000);
  line-height: calc(27/20);
  padding-top: 22.1rem;
  position: relative;
  text-align: center;
  width: 20rem;
}

.sub_flow_step li:nth-child(1) {
  background-image: url(/assets/img/top/icon_top_flow_step01.webp);
}

.sub_flow_step li:nth-child(2) {
  background-image: url(/assets/img/top/icon_top_flow_step02.webp);
}

.sub_flow_step li:nth-child(3) {
  background-image: url(/assets/img/top/icon_top_flow_step03.webp);
}

.sub_flow_step li:nth-child(4) {
  background-image: url(/assets/img/top/icon_top_flow_step04.webp);
}

.sub_flow_step .txt01 {
  align-items: center;
  display: flex;
  height: 8.1rem;
  white-space: nowrap;
}

.sub_flow_step li .txt02 {
  align-items: center;
  display: flex;
  flex-direction: column;
  height: 17.5rem;
  justify-content: center;
  margin-top: 1rem;
}

.sub_flow_step li:nth-child(1) .txt02 img {
  width: 12.2rem;
}

.sub_flow_step li:nth-child(1) .txt02 span {
  display: block;
  margin-top: 2rem;
}

.sub_flow_step li:nth-child(2) .txt02 img {
  width: 13.1rem;
}

.sub_flow_step li:nth-child(3) .txt02 {
  margin: 1rem auto 0;
  width: 16rem;
}

.sub_flow_step li:nth-child(3) .txt02 img {
  width: 3.2rem;
}

.sub_flow_step li:nth-child(3) .txt02 span {
  background-color: #fff;
  color: #ff6c00;
  display: block;
  margin-top: .5rem;
  padding: 1rem;
}

.sub_flow_step li:nth-child(4) .txt02 img {
  width: 12.4rem;
}

.sub_flow .link {
  align-items: center;
  background-color: #fff;
  border-radius: 6rem;
  color: #ff6c00;
  display: flex;
  font-size: 3.9rem;
  font-weight: 900;
  height: 11.5rem;
  justify-content: center;
  letter-spacing: calc(100em/1000);
  margin: 5.5rem auto 0;
  max-width: 120rem;
  position: relative;
}

.sub_flow .link .arrow {
  align-items: center;
  background-color: #ff6c00;
  border-radius: 3.7rem;
  content: '';
  display: flex;
  height: 7.3rem;
  justify-content: center;
  position: absolute;
  right: 2.3rem;
  top: 50%;
  transform: translateY(-50%);
  width: 7.3rem;
}

.sub_flow .link .arrow::before {
  background-color: #fff;
  clip-path: polygon(0 0, 0% 100%, 100% 50%);
  content: '';
  height: 2.6rem;
  transform: translateX(.3rem);
  width: 2.4rem;
}

.sub_flow_link_menu {
  display: flex;
  gap: 2.66rem;
  justify-content: center;
  margin-top: 5.5rem;
}

.sub_flow_link_menu li {
  width: 28rem;
}

.sub_flow_link_menu a {
  align-items: center;
  border: #fff 2px solid;
  border-radius: 1rem;
  color: #fff;
  display: flex;
  font-size: 2.2rem;
  font-weight: 700;
  height: 7.7rem;
  justify-content: center;
  letter-spacing: calc(100em/1000);
  padding-right: 4.7rem;
  position: relative;
}

.sub_flow_link_menu .arrow {
  align-items: center;
  background-color: #fff;
  border-radius: 3.7rem;
  content: '';
  display: flex;
  height: 3.2rem;
  justify-content: center;
  position: absolute;
  right: 1.5rem;
  top: 50%;
  transform: translateY(-50%);
  width: 3.2rem;
}

.sub_flow_link_menu .arrow::before {
  background-color: #ff6c00;
  clip-path: polygon(0 0, 0% 100%, 100% 50%);
  content: '';
  height: 1.2rem;
  transform: translateX(.1rem);
  width: 1.1rem;
}

.sub_flow_link_menu li:nth-child(2) a {
  letter-spacing: 0;
}

@media screen and (max-width:767px) {
  .sub_flow {
    padding-bottom: 2.5rem;
  }

  .sub_flow_content {
	margin: 10rem auto 0rem auto;
    padding: 4rem 0 2rem;
  }

  .sub_flow_ttl {
    font-size: 3rem;
  }

  .sub_flow_ttl::before {
    background-position: center 2rem;
    background-size: 6.3rem auto;
    height: 18.2rem;
    top: -11.5rem;
    width: 18.2rem;
  }

  .sub_flow_step::before {
    content: none;
  }

  .sub_flow_step .inner {
    margin-top: 2rem;
    padding: 0 1rem;
  }

  .sub_flow_step ol {
    display: block;
  }

  .sub_flow_step li {
    background-position: 4.5rem 2.5rem;
    background-size: 10.9rem auto;
    border-top: #fff 1px solid;
    padding: 13.3rem 0 2rem;
    width: auto;
  }

  .sub_flow_step li:nth-child(1) {
    background-image: url(/assets/img/top/icon_top_flow_step01_sp.webp);
  }

  .sub_flow_step li:nth-child(2) {
    background-image: url(/assets/img/top/icon_top_flow_step02_sp.webp);
  }

  .sub_flow_step li:nth-child(3) {
    background-image: url(/assets/img/top/icon_top_flow_step03_sp.webp);
  }

  .sub_flow_step li:nth-child(4) {
    background-image: url(/assets/img/top/icon_top_flow_step04_sp.webp);
    border-bottom: #fff 1px solid;
  }

  .sub_flow_step .txt01 {
    display: block;
    font-size: 1.7rem;
    height: auto;
    text-align: left;
    white-space: normal;
  }

  .sub_flow_step li .txt02 {
    display: block;
    margin: 0;
    position: absolute;
    right: 0;
    top: 0;
  }

  .sub_flow_step li:nth-child(1) .txt02 {
    margin: 1rem 4.5rem 0 0;
  }

  .sub_flow_step li:nth-child(1) .txt02 img {
    width: 8rem;
  }

  .sub_flow_step li:nth-child(1) .txt02 span {
    font-size: 1.3rem;
    margin-top: 1rem;
  }

  .sub_flow_step li:nth-child(2) .txt02 img {
    width: 7.6rem;
  }

  .sub_flow_step li:nth-child(2) .txt02 {
    margin: 3rem 4.5rem 0 0;
  }

  .sub_flow_step li:nth-child(3) .txt02 {
    margin: 1rem 3rem 0 0;
    width: 10.8rem;
  }

  .sub_flow_step li:nth-child(3) .txt02 img {
    width: 2.1rem;
  }

  .sub_flow_step li:nth-child(3) .txt02 span {
    font-size: 1.3rem;
    margin-top: .3rem;
    padding: .5rem;
    text-align: left;
  }

  .sub_flow_step li:nth-child(4) .txt02 {
    margin: 3rem 5rem 0 0;
  }

  .sub_flow_step li:nth-child(4) .txt02 img {
    width: 7.2rem;
  }

  .sub_flow .link {
    font-size: 1.7rem;
    height: 8rem;
    margin: 2rem 1rem 0;
  }

  .sub_flow .link .arrow {
    height: 3.3rem;
    width: 3.3rem;
  }

  .sub_flow .link .arrow::before {
    height: 1.3rem;
    transform: translateX(.1rem);
    width: 1.1rem;
  }

  .sub_flow_link_menu {
    flex-wrap: wrap;
    gap: 1rem;
    margin: 2rem 1rem 0;
  }

  .sub_flow_link_menu li {
    width: calc(50% - .5rem);
  }

  .sub_flow_link_menu a {
    font-size: 1.3rem;
    height: 4.7rem;
    padding-right: 2.5rem;
  }

  .sub_flow_link_menu .arrow {
    height: 2rem;
    right: 1rem;
    width: 2rem;
  }

  .sub_flow_link_menu .arrow::before {
    height: .7rem;
    width: .6rem;
  }
}

/*--------------------
  header
------------------- */
.header .nav li {
  border-left: #fff 1px solid;
  height: 5.1rem;
}

.header .nav a {
  align-items: center;
  color: #fff;
  display: flex;
  font-size: 1.6rem;
  font-weight: 500;
  height: 100%;
  letter-spacing: calc(50em/1000);
  line-height: calc(20/16);
  padding: 0 2.5rem;
  text-align: center;
}


.header {
  background-color: #343434;
  position: static;
}

/*--------------------
  title
------------------- */
.page_ttl {
  background-color: #343434;
}

.page_ttl .container {
  display: flex;
  justify-content: flex-end;
  padding: 6rem 3rem;
}

.page_ttl .txt {
  color: #fff;
  font-size: 2.7rem;
  font-weight: 700;
  letter-spacing: calc(200em/1000);
  text-align: right;
}

.page_ttl .txt .en {
  display: block;
  font-family: 'Oswald', sans-serif;
  font-size: 5.8rem;
  font-style: italic;
  font-weight: 700;
  letter-spacing: normal;
}

@media screen and (max-width:767px) {
  .page_ttl .container {
    padding: 3rem 1.5rem;
  }

  .page_ttl .txt {
    font-size: 1.8rem;
  }

  .page_ttl .txt .en {
    font-size: 4rem;
  }
}

/*--------------------
  breadcrumb
------------------- */
.breadcrumb {
  display: flex;
  margin: 2.5rem auto 0;
  max-width: 155rem;
}

.breadcrumb li {
  font-size: 2.2rem;
  font-weight: 500;
}

.breadcrumb li + li::before {
  content: '＞';
  margin: 0 1em;
}

@media screen and (max-width:767px) {
  .breadcrumb {
    margin: 1.5rem 1.5rem 0;
  }

  .breadcrumb li {
    font-size: 1.4rem;
  }
}

/*--------------------
  page content
------------------- */
.page_content {
  margin-top: 12rem;
}

.page_content .container {
  margin: 0 auto;
  max-width: 120rem;
}

.page_content .block {
  margin: 15rem 0;
}

@media screen and (max-width:767px) {
  .page_content {
    margin-top: 6rem;
  }

  .page_content .container {
    margin: 0 1.5rem;
  }

  .page_content .block {
    margin: 6rem 0;
  }
}

/* 目次 */
.page_content .index {
  margin-bottom: 10rem;
}

.page_content .index .container {
  align-items: flex-start;
  display: flex;
  justify-content: center;
  max-width: 100rem;
}

.page_content .index_ttl {
  align-items: flex-end;
  display: flex;
  font-size: 2.4rem;
  font-weight: 700;
  line-height: 1;
  letter-spacing: calc(200em/1000);
}

.page_content .index_ttl .en {
  color: #ff6c00;
  font-family: 'Oswald', sans-serif;
  font-size: 4.8rem;
  font-style: italic;
  margin-right: 3.5rem;
}

.page_content .index_list {
  margin-left: 12rem;
  min-width: 51.5rem;
}

.page_content .index_list li {
  border-bottom: #343434 1px solid;
}

.page_content .index_list a {
  display: block;
  font-size: 2.6rem;
  font-weight: 700;
  letter-spacing: calc(100em/1000);
  padding: 1rem 0;
}

@media screen and (max-width:767px) {
  .page_content .index {
    margin-bottom: 5rem;
  }

  .page_content .index .container {
    display: block;
  }

  .page_content .index_ttl {
    font-size: 1.8rem;
  }

  .page_content .index_ttl .en {
    font-size: 3rem;
    margin-right: 1.5rem;
  }

  .page_content .index_list {
    margin: 2rem 0 0;
    min-width: inherit;
  }

  .page_content .index_list a {
    font-size: 1.6rem;
  }
}

/* h2 */
.page_content .heading_lv_1 {
  background-color: #343434;
  margin: 28.7rem 0 6rem;
  padding: 4rem 0;
  position: relative;
}

.page_content .heading_lv_1::before {
  background-color: #343434;
  background-image: url(/assets/img/sub/icon_heading.webp);
  background-position: center 4rem;
  background-repeat: no-repeat;
  background-size: 17rem;
  border-radius: 18.3rem 18.3rem 0 0;
  content: '';
  height: 18.3rem;
  left: 50%;
  position: absolute;
  top: -15.7rem;
  transform: translateX(-50%);
  width: 36.5rem;
}

.page_content .heading_lv_1::after {
  content: '';
}

.page_content .heading_lv_1 .txt {
  color: #fff;
  font-size: 6rem;
  font-weight: 900;
  letter-spacing: calc(200em/1000);
  position: relative;
  text-align: center;
}

.page_content .heading_lv_1.b {
  background-color: #ff6c00;
}

.page_content .heading_lv_1.b::before {
  background-color: #ff6c00;
}

@media screen and (max-width:767px) {
  .page_content .heading_lv_1 {
    margin: 10.5rem 0 4rem;
    padding: 2rem 0;
  }

  .page_content .heading_lv_1::before {
    background-image: url(/assets/img/sub/icon_heading.webp);
    background-position: center 2rem;
    background-size: 6.3rem auto;
    border-radius: 9.1rem 9.1rem 0 0;
    height: 9.1rem;
    top: -6.5rem;
    width: 18.2rem;
  }

  .page_content .heading_lv_1 .txt {
    font-size: 3rem;
  }
}

/* h3 */
.page_content .heading_lv_2 {
  font-size: 6rem;
  font-weight: 900;
  letter-spacing: calc(200em/1000);
  margin: 6rem 0;
}

.page_content .heading_lv_2.b {
  color: #ff6c00;
}

@media screen and (max-width:767px) {
  .page_content .heading_lv_2 {
    font-size: 3rem;
    margin: 4rem 0;
  }
}

/* h4 */
.page_content .heading_lv_3 {
  border-left: #ff6c00 6px solid;
  font-size: 3.3rem;
  font-weight: 900;
  letter-spacing: calc(200em/1000);
  margin: 6rem 0;
  padding-left: 2rem;
}

.page_content .heading_lv_3.b {
  border-color: #343434;
  color: #ff6c00;
}

.page_content .heading_lv_3.c {
  border-color: #fff;
  color: #ff6c00;
}


@media screen and (max-width:767px) {
  .page_content .heading_lv_3 {
    border-width: 4px;
    font-size: 2rem;
    margin: 4rem 0;
    padding-left: 1rem;
  }
}

/* text */
.page_content .txt_normal {
  font-size: 2.2rem;
  line-height: calc(50/22);
}

@media screen and (max-width:767px) {
  .page_content .txt_normal {
    font-size: 1.4rem;
    line-height: 2;
  }
}

/* text */
.page_content .txt_normal_w {
  font-size: 2.2rem;
  line-height: calc(42/21);
  color: #fff
}

@media screen and (max-width:767px) {
  .page_content .txt_normal_w {
    font-size: 1.4rem;
    line-height: 2;
  }
}

/* 2col */
.page_content .col_2 {
  display: flex;
  justify-content: space-between;
}

.page_content .col_2 .col {
  width: 48%;
}

.page_content .col_2 .col *:first-child {
  margin-top: 0;
}

@media screen and (max-width:767px) {
  .page_content .col_2 {
    display: block;
  }

  .page_content .col_2 .col {
    width: auto;
  }

  .page_content .col_2 .col + .col {
    margin-top: 2rem;
  }

  .page_content .col_2 .col *:first-child {
    margin: 0;
  }

  .page_content .col_2 .col * + * {
    margin-top: 2rem;
  }
}

/* card */
.page_content .card {
  display: flex;
  gap: 8rem;
  justify-content: space-between;
}

.page_content .card .txt {
  background-color: #343434;
  color: #fff;
  padding: 5rem 2rem;
}

.page_content .card .heading {
  font-size: 3.2rem;
  font-weight: 900;
  letter-spacing: calc(100em/1000);
  line-height: calc(50/32);
  padding: 0 3rem;
  text-align: center;
}

.page_content .card .desc {
  font-size: 2.2rem;
  line-height: calc(36/22);
  margin-top: 5rem;
}

.page_content .card.col_3 {
  gap: 5rem;
}

.page_content .card.col_3 .txt {
  padding: 1.5rem;
}

.page_content .card.col_3 .heading {
  padding: 0;
}

.page_content .card.col_3 .desc {
  margin-top: 3rem;
}

.page_content .card.col_4 {
  gap: .6rem;
}

.page_content .card.col_4 .txt {
  padding: 1.5rem;
}

.page_content .card.col_4 .heading {
  font-size: 2.3rem;
  line-height: calc(33/23);
  padding: 0;
}

.page_content .card.col_4 .desc {
  margin-top: 3rem;
}

.page_content .card.b .img {
  background-color: #ff6c00;
  padding: 1.5rem 1.5rem 0;
}

.page_content .card.b .txt {
  background-color: #ff6c00;
}

@media screen and (max-width:767px) {
  .page_content .card.col_2 {
    display: block;
  }

  .page_content .card.col_2 .col .img + * {
    margin-top: 0;
  }

  .page_content .card .txt {
    padding: 2rem 1.5rem;
  }

  .page_content .card .heading {
    font-size: 2rem;
  }

  .page_content .card .desc {
    font-size: 1.4rem;
    margin-top: 2rem;
  }

  .page_content .card.col_3 {
    display: block;
  }

  .page_content .card.col_3 .col + .col {
    margin-top: 2rem;
  }

  .page_content .card.col_3 .desc {
    margin-top: 2rem;
  }

  .page_content .card.col_4 {
    flex-wrap: wrap;
  }

  .page_content .card.col_4 .col {
    width: calc(50% - .3rem);
  }

  .page_content .card.col_4 .heading {
    font-size: 1.8rem;
  }

  .page_content .card.col_4 .desc {
    margin-top: 2rem;
  }
}

/* Q&A */
.page_content .qa {
  background-color: #343434;
}

.page_content .qa .container {
  padding: 5rem 0 25rem;
}

.page_content .qa .heading {
  color: #fff;
  font-family: 'Oswald', sans-serif;
  font-size: 11rem;
  font-style: italic;
  margin-bottom: 11rem;
  text-align: center;
}
.page_content .qa .heading2 {
  color: #fff;
  font-family: 'Oswald', sans-serif;
  font-size: 6rem;
  font-style: italic;
  margin-bottom: 5rem;
  text-align: center;
	margin-top: 4rem;	
}

.page_content .qa .heading span {
  font-size: 6rem;
  margin: 0 .25em;
}

.page_content .qa .list {
  background-color: #fff;
  border-radius: 2rem;
}

.page_content .qa .list + .list {
  margin-top: 3rem;
}

.page_content .qa .question {
  align-items: center;
  background-image: url(/assets/img/sub/icon_question_off.webp);
  background-position: right 4.5rem center;
  background-repeat: no-repeat;
  background-size: 5.4rem auto;
  cursor: pointer;
  display: flex;
  font-size: 3rem;
  font-weight: 700;
  letter-spacing: calc(100em/1000);
  line-height: calc(36/30);
  padding: 1.7rem 15.5rem 1.7rem 0;
  transition: opacity .3s;
}

.page_content .qa .question::before {
  border-right: #ff6c00 2px solid;
  content: 'Q';
  display: block;
  flex-shrink: 0;
  font-family: 'Oswald', sans-serif;
  font-size: 10rem;
  font-style: italic;
  line-height: 1;
  margin-right: 3rem;
  padding-bottom: 2rem;
  text-align: center;
  width: 15.5rem;
}

.page_content .qa .question:hover {
  opacity: .7;
}

.page_content .qa .list.is-active .question {
  background-image: url(/assets/img/sub/icon_question_on.webp);
}

.page_content .qa .answer {
  background-color: #ededed;
  border-radius: 0 0 2rem 2rem;
  display: none;
  font-size: 3rem;
  font-weight: 700;
  letter-spacing: calc(100em/1000);
  line-height: calc(45/30);
  padding: 3rem 5rem 3rem 18.5rem;
  position: relative;
}

.page_content .qa .answer::before {
  color: #ff6c00;
  content: 'A';
  display: block;
  font-family: 'Oswald', sans-serif;
  font-size: 10rem;
  font-style: italic;
  left: 0;
  line-height: 1;
  position: absolute;
  text-align: center;
  top: 3rem;
  width: 15.5rem;
}

@media screen and (max-width:767px) {
.page_content .qa .heading2 {
  font-size: 3rem;
}

  .page_content .qa .container {
    padding: 1rem 0 5rem 0;
  }

  .page_content .qa .heading {
    font-size: 6rem;
    margin-bottom: 4rem;
  }

  .page_content .qa .heading span {
    font-size: 3rem;
  }

  .page_content .qa .list {
    border-radius: 1rem;
  }

  .page_content .qa .question {
    align-items: flex-start;
    background-position: right 1.5rem center;
    background-size: 2rem auto;
    font-size: 1.6rem;
    padding-right: 5rem;
  }

  .page_content .qa .question::before {
    font-size: 2rem;
    margin-right: 1rem;
    padding-bottom: 0;
    width: 3rem;
  }

  .page_content .qa .answer {
    font-size: 1.6rem;
    padding: 2rem 1.5rem 2rem 4rem;
  }

  .page_content .qa .answer::before {
    font-size: 2rem;
    top: 1.5rem;
    width: 3rem;
  }
}

/* table */
.page_content .table {
  border-collapse: separate;
  border-spacing: 6px;
  width: 100%;
}

.page_content .table th, .page_content .table td {
  font-size: 1.8rem;
  font-weight: 500;
  line-height: calc(28/18);
  padding: 3rem;
}

.page_content .table th {
  background-color: #343434;
  color: #fff;
	vertical-align: middle;
}

.page_content .table td {
  background-color: #eff1f5;
  vertical-align: middle;
}

.page_content .table td:nth-child(even) {
  background-color: #f5e3e0;
}

.page_content .table thead th {
  background-color: #ff6c00;
  color: #fff;
}

@media screen and (max-width:767px) {
  .page_content .table_scroll {
    overflow-x: scroll;
  }

  .page_content .table {
    white-space: nowrap;
  }

  .page_content .table th, .page_content .table td {
    font-size: 1.4rem;
    padding: 1rem;
  }
}

/* btn */
.page_content .btn {
  align-items: center;
  background-color: #ff6c00;
  border-radius: 6rem;
  color: #fff;
  display: flex;
  font-size: 3.9rem;
  font-weight: 900;
  height: 11.5rem;
  letter-spacing: calc(100em/1000);
  padding: 0 11.9rem 0 5rem;
  position: relative;
}

.page_content .btn .arrow {
  align-items: center;
  background-color: #fff;
  border-radius: 3.7rem;
  content: '';
  display: flex;
  height: 7.3rem;
  justify-content: center;
  position: absolute;
  right: 2.3rem;
  top: 50%;
  transform: translateY(-50%);
  width: 7.3rem;
}

.page_content .btn .arrow::before {
  background-color: #ff6c00;
  clip-path: polygon(0 0, 0% 100%, 100% 50%);
  content: '';
  height: 2.6rem;
  transform: translateX(.3rem);
  width: 2.4rem;
}

.page_content .btn.b {
  background-color: #06b455;
}

@media screen and (max-width:767px) {
  .page_content .btn {
    font-size: 2rem;
    height: 8.2rem;
    padding: 0 4.6rem 0 2rem;
  }

  .page_content .btn .arrow {
    height: 1.6rem;
    right: 1.5rem;
    width: 1.6rem;
  }

  .page_content .btn .arrow::before {
    height: .7rem;
    transform: translateX(.1rem);
    width: .6rem;
  }
}
