@charset "UTF-8";
html {
  scroll-behavior: smooth;
}

body {
  font-family: 'Noto Sans JP', "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
  color: #484848;
}

ul {
  list-style: none;
}

ul.ten {
  display: flex;
  flex-wrap: wrap;
  line-height: inherit;
}

ul.ten li {
  line-height: inherit;
}

ul.ten li:nth-last-of-type(n+2):after {
  content: "、";
}

a {
  color: #484848;
  text-decoration: none;
}

img {
  max-width: 100%;
  height: auto;
  display: inline;
  vertical-align: middle;
}

.mincho {
  font-family: 'Zen Old Mincho', '游明朝','Yu Mincho',YuMincho,'Hiragino Mincho Pro', serif;
}

header #header_contact {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  border: 1px solid #dddddd;
  border-radius: 50%;
  background: #FFFFFF;
}

header #header_menu_button {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  border: 1px solid #dddddd;
  border-radius: 50%;
  background: #FFFFFF;
  z-index: 15;
}

header #header_menu_area {
  display: none;
  background: #FFFFFF;
  z-index: 10;
}

header #header_nav_tel {
  background: #e8e7de;
}

header #header_nav_tel .tel_area h2 {
  color: #7d7a6c;
}

footer {
  background: #f8f8f5;
}

footer #footer_contact_area {
  background: #283342;
  color: #FFFFFF;
}

footer #footer_contact_area .car_contact h3 {
  color: #BFBAA1;
}

footer #footer_contact_area .car_contact a {
  color: #FFFFFF;
}

footer #footer_contact_area .car_contact #footer_contact_tel {
  display: flex;
  align-items: center;
}

footer #footer_contact_area .car_contact #footer_contact_form {
  display: block;
  border: 1px solid #848889;
  text-align: center;
}

footer #footer_contact_area .service_contact h3 {
  color: #BFBAA1;
}

footer #footer_contact_area .service_contact > ul {
  display: flex;
  flex-wrap: wrap;
  margin-top: 30px;
}

footer #footer_contact_area .service_contact > ul > li > dl > dt > a {
  display: block;
  background: #FFFFFF;
  color: #282828;
  text-align: center;
}

footer #footer_navi_area .logo_area > nav > ul > li.instagram a, footer #footer_navi_area .logo_area > nav > ul > li.facebook a {
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: #f8f8f5;
}

footer #footer_navi_area .logo_area > nav > ul > li.car_list a {
  display: flex;
  align-items: center;
  justify-content: center;
  background-image: linear-gradient(90deg, #deeef3 0%, #ecf5f8 100%);
}

footer #footer_navi_area .logo_area > nav > ul > li.kaitori a {
  display: flex;
  align-items: center;
  justify-content: center;
  background: #040b4b;
  color: #FFFFFF;
}

@media screen and (min-width: 768px) {
  html {
    font-size: 15px;
  }
  body {
    min-width: 1200px;
  }
  a[href^="tel:"] {
    pointer-events: none;
  }
  a:hover {
    opacity: 0.7;
    filter: alpha(opacity=70);
  }
  .sp {
    display: none;
  }
  :target {
    scroll-margin-top: 115px;
  }
  header {
    background: #FFFFFF;
    position: sticky;
    top: 0;
    z-index: 5;
  }
  header #header_wrapper {
    height: 115px;
    display: flex;
    width: 1200px;
    margin: 0 auto;
    align-items: center;
    justify-content: space-between;
  }
  header #header_wrapper .navi_area {
    display: flex;
    align-items: center;
    justify-content: flex-end;
  }
  header #header_logo {
    display: flex;
    align-items: center;
  }
  header #header_logo a {
    display: flex;
    flex-direction: column;
    justify-content: center;
  }
  header #header_logo a .txt {
    font-size: 13px;
  }
  header #header_gnavi {
    display: flex;
    align-items: center;
    margin-right: 30px;
    font-size: 14px;
  }
  header #header_gnavi > ul {
    display: flex;
    align-items: center;
    gap: 0 27px;
  }
  header #header_gnavi > ul > li {
    display: flex;
    align-items: center;
  }
  header #header_gnavi > ul > li a {
    display: flex;
    align-items: center;
  }
  header #header_tel {
    display: flex;
    font-size: 12px;
    margin-right: 30px;
  }
  header #header_tel .icon {
    margin: 4px 7px 0 0;
  }
  header #header_tel .icon img {
    vertical-align: top;
  }
  header #header_tel .tel_num {
    font-size: 26px;
    font-weight: 700;
    font-family: 'Roboto';
  }
  header #header_contact {
    width: 60px;
    height: 60px;
    margin-right: 10px;
  }
  header #header_menu_button {
    width: 60px;
    height: 60px;
  }
  header #header_menu_button > span {
    width: 14px;
    height: 10px;
    position: relative;
  }
  header #header_menu_button > span > span {
    width: 14px;
    height: 1px;
    display: block;
    background: #bfbaa1;
    position: absolute;
    left: 0;
  }
  header #header_menu_button > span > span.top {
    top: 0;
  }
  header #header_menu_button > span > span.middle {
    top: 5px;
  }
  header #header_menu_button > span > span.bottom {
    top: 10px;
  }
  header #header_menu_button.open {
    background: #f8f8f5;
  }
  header #header_menu_button.open > span > span {
    top: 5px;
  }
  header #header_menu_button.open > span > span.top {
    transform: rotate(-45deg) scale(1.3, 1);
  }
  header #header_menu_button.open > span > span.middle {
    display: none;
  }
  header #header_menu_button.open > span > span.bottom {
    transform: rotate(45deg) scale(1.3, 1);
  }
  header.active #header_menu_area {
    display: block;
    position: fixed;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    overflow: auto;
  }
  header.active #header_menu_area #header_menu_area_wapper {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    height: 100%;
    overflow: auto;
  }
  header.active #header_menu_area .link_area {
    width: 1000px;
    margin: 0 auto;
    padding: 55px 0;
    flex-grow: 1;
    display: flex;
    flex-direction: column;
    justify-content: center;
  }
  header.active #header_menu_area .link_area .top_link {
    color: #484848;
    font-size: 17px;
    font-weight: 600;
  }
  header.active #header_menu_area .link_area .service_link {
    margin-top: 60px;
    display: flex;
  }
  header.active #header_menu_area .link_area .service_link h2 {
    font-size: 14px;
    color: #BFBAA1;
    width: 165px;
  }
  header.active #header_menu_area .link_area .service_link .service_item h3 {
    color: #484848;
    font-size: 17px;
  }
  header.active #header_menu_area .link_area .service_link .service_item ul {
    margin-top: 11px;
  }
  header.active #header_menu_area .link_area .service_link .service_item ul li {
    margin-top: 5px;
  }
  header.active #header_menu_area .link_area .service_link .service_item ul li a {
    font-size: 13px;
    color: #484848;
  }
  header.active #header_menu_area .link_area .service_link .service_item ul li:nth-of-type(1) {
    margin-top: 0;
  }
  header.active #header_menu_area .link_area .service_link .service_item:nth-of-type(1) {
    width: 245px;
  }
  header.active #header_menu_area .link_area .service_link .service_item:nth-of-type(2) {
    width: 205px;
  }
  header.active #header_menu_area .link_area .service_link .service_item:nth-of-type(3) {
    width: 175px;
  }
  header.active #header_menu_area .link_area .sub_link_area {
    margin-top: 65px;
    display: flex;
    justify-content: space-between;
  }
  header.active #header_menu_area .link_area .sub_link_area > ul {
    display: flex;
  }
  header.active #header_menu_area .link_area .sub_link_area > ul.shop_link {
    gap: 0 65px;
  }
  header.active #header_menu_area .link_area .sub_link_area > ul.shop_link a {
    font-size: 17px;
    font-weight: 600;
    color: #484848;
  }
  header.active #header_menu_area .link_area .sub_link_area > ul.other_link {
    gap: 0 35px;
  }
  header.active #header_menu_area .link_area .sub_link_area > ul.other_link a {
    font-size: 13px;
    color: #484848;
  }
  header.active #header_menu_area #header_nav_tel {
    padding: 50px 0;
    min-width: 1000px;
  }
  header.active #header_menu_area #header_nav_tel #header_nav_tel_wrapper {
    width: 1000px;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
  }
  header.active #header_menu_area #header_nav_tel #header_nav_tel_wrapper .tel_area h2 {
    font-size: 18px;
  }
  header.active #header_menu_area #header_nav_tel #header_nav_tel_wrapper .tel_area #header_menu_tel {
    display: flex;
    align-items: center;
    margin-top: 10px;
    font-size: 36px;
    font-weight: 700;
    font-family: 'Roboto';
    letter-spacing: 0.02em;
  }
  header.active #header_menu_area #header_nav_tel #header_nav_tel_wrapper .tel_area #header_menu_tel .icon {
    margin-right: 10px;
    height: 36px;
  }
  header.active #header_menu_area #header_nav_tel #header_nav_tel_wrapper .tel_area #header_menu_tel .icon img {
    vertical-align: top;
  }
  header.active #header_menu_area #header_nav_tel #header_nav_tel_wrapper .tel_area #header_menu_mail {
    display: flex;
    width: 300px;
    padding: 20px 0;
    margin-top: 10px;
    background: #FFFFFF;
    align-items: center;
    justify-content: center;
    border-radius: 45px;
    font-weight: 600;
  }
  header.active #header_menu_area #header_nav_tel #header_nav_tel_wrapper .tel_area #header_menu_mail .icon {
    margin-right: 7px;
  }
  header.active #header_menu_area #header_nav_tel #header_nav_tel_wrapper .tel_area .data_area {
    display: flex;
    align-items: flex-end;
  }
  header.active #header_menu_area #header_nav_tel #header_nav_tel_wrapper .tel_area .data_area .date {
    margin-left: 17px;
  }
  header.active #header_menu_area #header_nav_tel #header_nav_tel_wrapper .tel_area .data_area .date dl {
    margin-top: 7px;
  }
  header.active #header_menu_area #header_nav_tel #header_nav_tel_wrapper .tel_area .data_area .date dl dt {
    font-size: 13px;
    font-weight: 600;
    color: #7d7a6c;
    line-height: 1;
  }
  header.active #header_menu_area #header_nav_tel #header_nav_tel_wrapper .tel_area .data_area .date dl dd {
    margin-top: 2px;
    font-size: 12px;
    color: #7d7a6c;
  }
  header.active #header_menu_area #header_nav_tel #header_nav_tel_wrapper .contact_area {
    width: 510px;
  }
  header.active #header_menu_area #header_nav_tel #header_nav_tel_wrapper .contact_area h3 {
    color: #7d7a6c;
    font-size: 13px;
    font-weight: 600;
  }
  header.active #header_menu_area #header_nav_tel #header_nav_tel_wrapper .contact_area > ul {
    margin-top: 15px;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
  }
  header.active #header_menu_area #header_nav_tel #header_nav_tel_wrapper .contact_area > ul li {
    display: flex;
  }
  header.active #header_menu_area #header_nav_tel #header_nav_tel_wrapper .contact_area > ul li a {
    display: flex;
    width: 250px;
    background: #FFFFFF;
    font-weight: 500;
    border-radius: 45px;
    padding: 15px 0;
    justify-content: center;
    position: relative;
  }
  header.active #header_menu_area #header_nav_tel #header_nav_tel_wrapper .contact_area > ul li a::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 30px;
    width: 14px;
    height: 10px;
    background: url(/common/images/base/vanguard-arrow-gd.svg) no-repeat;
    transform: translateY(-50%);
  }
  footer {
    padding-bottom: 20px;
  }
  footer #footer_contact_area {
    display: flex;
    justify-content: center;
    padding: 100px 0;
  }
  footer #footer_contact_area .car_contact {
    width: 500px;
    padding: 16px 0 8px 130px;
    border-right: 1px solid #4d555e;
  }
  footer #footer_contact_area .car_contact h2 {
    font-size: 30px;
    font-weight: 400;
    line-height: 1.5;
  }
  footer #footer_contact_area .car_contact h3 {
    font-size: 17px;
    font-weight: 500;
  }
  footer #footer_contact_area .car_contact .tel_area {
    margin-top: 65px;
  }
  footer #footer_contact_area .car_contact #footer_contact_tel {
    margin-top: 13px;
    font-size: 36px;
    font-weight: 700;
    font-family: 'Roboto';
    letter-spacing: 0.04em;
  }
  footer #footer_contact_area .car_contact #footer_contact_tel .icon {
    margin-right: 10px;
    height: 36px;
  }
  footer #footer_contact_area .car_contact #footer_contact_tel .icon img {
    vertical-align: top;
  }
  footer #footer_contact_area .car_contact .mail_area {
    margin-top: 40px;
  }
  footer #footer_contact_area .car_contact #footer_contact_form {
    width: 300px;
    margin-top: 15px;
    padding: 20px 0;
    font-size: 15px;
    border-radius: 45px;
    position: relative;
  }
  footer #footer_contact_area .car_contact #footer_contact_form::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 30px;
    width: 14px;
    height: 10px;
    background: url(/common/images/base/vanguard-arrow-gd.svg) no-repeat;
    transform: translateY(-50%);
  }
  footer #footer_contact_area .service_contact {
    width: 699px;
    padding: 20px 0 10px 70px;
  }
  footer #footer_contact_area .service_contact > ul {
    gap: 33px 50px;
  }
  footer #footer_contact_area .service_contact > ul li {
    width: 250px;
  }
  footer #footer_contact_area .service_contact > ul li dt > a {
    font-size: 15px;
    font-weight: 700;
    padding: 21px 0;
    border-radius: 45px;
    position: relative;
  }
  footer #footer_contact_area .service_contact > ul li dt > a::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 30px;
    width: 14px;
    height: 10px;
    background: url(/common/images/base/vanguard-arrow-gd.svg) no-repeat;
    transform: translateY(-50%);
  }
  footer #footer_contact_area .service_contact > ul li dd {
    margin-top: 14px;
    font-size: 12px;
    line-height: 1.67;
  }
  footer #footer_navi_area {
    background: #ffffff;
  }
  footer #footer_navi_area .footer_navi_wrapper {
    width: 1200px;
    margin: 0 auto;
    padding: 50px 0 80px;
    display: flex;
    justify-content: space-between;
  }
  footer #footer_navi_area .logo_area {
    padding-left: 40px;
    width: 600px;
  }
  footer #footer_navi_area .logo_area nav {
    margin-top: 35px;
  }
  footer #footer_navi_area .logo_area nav > ul {
    display: flex;
    align-items: center;
  }
  footer #footer_navi_area .logo_area nav > ul > li {
    display: flex;
    align-items: center;
  }
  footer #footer_navi_area .logo_area nav > ul > li.facebook a, footer #footer_navi_area .logo_area nav > ul > li.instagram a {
    width: 50px;
    height: 50px;
  }
  footer #footer_navi_area .logo_area nav > ul > li.instagram {
    margin-right: 10px;
  }
  footer #footer_navi_area .logo_area nav > ul > li.facebook {
    margin-right: 10px;
  }
  footer #footer_navi_area .logo_area nav > ul > li.car_list {
    margin-right: 7px;
  }
  footer #footer_navi_area .logo_area nav > ul > li.car_list a {
    font-weight: 700;
    width: 190px;
    height: 50px;
    position: relative;
    border-radius: 45px;
    color: #040b4b;
  }
  footer #footer_navi_area .logo_area nav > ul > li.car_list a::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 20px;
    width: 14px;
    height: 10px;
    background: url(/common/images/base/vanguard-arrow.svg) no-repeat;
    transform: translateY(-50%);
  }
  footer #footer_navi_area .logo_area nav > ul > li.kaitori a {
    width: 230px;
    height: 50px;
    position: relative;
    border-radius: 45px;
  }
  footer #footer_navi_area .logo_area nav > ul > li.kaitori a::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 20px;
    width: 14px;
    height: 10px;
    background: url(/common/images/base/vanguard-arrow-gd.svg) no-repeat;
    transform: translateY(-50%);
  }
  footer #footer_navi_area .service_area {
    margin-right: 100px;
    display: flex;
    flex-wrap: wrap;
    gap: 20px 0;
    width: 310px;
    position: relative;
  }
  footer #footer_navi_area .service_area::before {
    content: "";
    width: 2px;
    background: #edece4;
    position: absolute;
    left: 0;
    top: 45px;
    bottom: 0;
  }
  footer #footer_navi_area .service_area h3 {
    color: #BFBAA1;
    font-size: 14px;
    font-weight: 600;
    width: 180px;
  }
  footer #footer_navi_area .service_area a {
    font-size: 14px;
    color: #484848;
    font-weight: 600;
  }
  footer #footer_navi_area .service_area > ul {
    display: contents;
  }
  footer #footer_navi_area .service_area > ul li:nth-of-type(2n) {
    width: 180px;
    padding-left: 15px;
  }
  footer #footer_navi_area .service_area > ul li:nth-of-type(2n + 1) {
    width: 130px;
  }
  footer #footer_navi_area #footer_logo .footer_copy {
    font-size: 13px;
    font-weight: 600;
  }
  footer #footer_navi_area #footer_logo .image {
    margin-top: 20px;
  }
  footer #footer_navi_area #footer_logo .footer_company {
    margin-top: 7px;
    font-size: 12px;
  }
  footer #footer_copyright {
    width: 1040px;
    margin: 0 auto;
    padding-top: 20px;
    text-align: right;
    font-size: 12px;
  }
  .car_result_list li.car_item {
    width: 300px;
  }
  .car_result_list li.car_item .image img {
    width: 300px;
    height: auto;
  }
  .car_result_list li.car_item h3 {
    font-size: 14px;
    line-height: 1.61;
    font-weight: 600;
    margin-top: 13px;
    text-decoration: underline;
  }
  .car_result_list li.car_item .price {
    font-size: 16px;
    margin-top: 17px;
  }
  .car_result_list li.car_item dl {
    display: flex;
    font-size: 12px;
    font-weight: normal;
    margin-top: 4px;
  }
  .car_result_list li.car_item dl.year {
    margin-top: 18px;
  }
  .car_result_list li.car_item dl dt {
    width: 5em;
    position: relative;
  }
  .car_result_list li.car_item dl dt::after {
    content: "：";
    position: absolute;
    right: 0;
    top: 0;
  }
  .special_area > dl {
    width: 800px;
    margin: 40px auto 0;
    border: 4px solid #ededd3;
    position: relative;
  }
  .special_area > dl dt {
    position: absolute;
    top: -17px;
    left: -14px;
  }
  .special_area > dl dt span {
    display: inline-flex;
    align-items: center;
    position: relative;
    height: 44px;
    padding: 0 45px 0 35px;
    color: #FFFFFF;
    background: #c73c3c;
    font-size: 18px;
    font-weight: 600;
    line-height: 1;
  }
  .special_area > dl dt span::before {
    content: "";
    position: absolute;
    left: 0;
    bottom: -11px;
    width: 11px;
    height: 11px;
    background: url(/common/images/buy/obi-ura.png);
    background-size: cover;
  }
  .special_area > dl dt span::after {
    content: "";
    position: absolute;
    right: -21px;
    top: 0;
    width: 21px;
    height: 44px;
    background: url(/common/images/buy/obi-right.png);
    background-size: cover;
  }
  .special_area > dl dd {
    padding: 60px 55px 40px 60px;
    background: #fbf8ed;
    line-height: 2.3;
  }
}
