@charset "UTF-8";
/*-----------------------
mixin
-------------------------*/
/*-----------------------
colors
-------------------------*/
/*-----------------------
common
-------------------------*/
@media screen and (max-width: 767px) {
  .is-pc {
    display: none;
  }
}
@media screen and (min-width: 768px) {
  .is-sp {
    display: none;
  }
}
body {
  font-size: 16px;
  color: #3E3E3E;
  line-height: 1.5;
  font-family: "Lato", sans-serif;
  font-family: "Montserrat", sans-serif;
}

img {
  width: 100%;
}

.inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 40px;
  box-sizing: content-box;
}
@media screen and (max-width: 767px) {
  .inner {
    padding: 0 16px;
  }
}

/*-----------------------
header
-------------------------*/
.header {
  background: rgba(255, 255, 255, 0.1019607843);
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  height: 83px;
  z-index: 100;
  opacity: 1;
}
@media screen and (max-width: 767px) {
  .header {
    background: #F3F3F3;
    opacity: 1;
    height: 68px;
  }
}

.header-inner {
  display: flex;
  align-items: center;
}

.header-logo {
  color: #3E3E3E;
  font-size: 23px;
  font-weight: 700;
  padding: 17px 16px;
  font-family: "Montserrat", sans-serif;
}

.header-nav {
  margin: 0 auto;
}

@media screen and (min-width: 768px) {
  .header-nav-list {
    display: flex;
  }
}

@media screen and (min-width: 768px) {
  .header-nav-item + .header-nav-item {
    margin-left: 34px;
  }
}

.header-nav-item-link {
  display: block;
  color: #3E3E3E;
  height: 70px;
  line-height: 82px;
  letter-spacing: 0.025em;
  position: relative;
  cursor: pointer;
}
.header-nav-item-link::after {
  content: "";
  position: absolute;
  bottom: 10px;
  left: 0;
  width: 100%;
  height: 1px;
  background: transparent;
  transition: all 0.3s ease 0s;
}
.header-nav-item-link:hover::after, .header-nav-item-link.is-active::after {
  background: #3E3E3E;
}

.drawer-hamburger-icon {
  width: 26px;
  height: 4px;
  border-radius: 2px;
}
.drawer-hamburger-icon::before, .drawer-hamburger-icon::after {
  height: 4px;
  border-radius: 2px;
}

/*-----------------------
drawer
-------------------------*/
.drawer-icon {
  position: fixed;
  top: 24px;
  right: 18px;
  z-index: 300;
  display: none;
  transition: transform 0.5s ease 0s;
}
@media screen and (max-width: 767px) {
  .drawer-icon {
    display: block;
  }
}
.drawer-icon.is-active {
  right: 316px;
}
.drawer-icon.is-active .drawer-icon_bar1 {
  transform: rotate(-45deg);
  top: 11px;
  background: #fff;
}
.drawer-icon.is-active .drawer-icon_bar2 {
  display: none;
}
.drawer-icon.is-active .drawer-icon_bar3 {
  transform: rotate(45deg);
  top: 11px;
  background: #fff;
}

.drawer-icon_bars {
  width: 27px;
  height: 20px;
  display: block;
  position: relative;
}

.drawer-icon_bar1,
.drawer-icon_bar2,
.drawer-icon_bar3 {
  position: absolute;
  width: 27px;
  height: 4px;
  background: #3E3E3E;
  top: 0;
  left: 1;
  border-radius: 4px;
}

.drawer-icon_bar2 {
  top: 8px;
}

.drawer-icon_bar3 {
  top: 16px;
}

.drawer-content {
  width: 80%;
  max-width: 300px;
  height: 100%;
  position: fixed;
  right: 0;
  top: 0;
  background: #fff;
  z-index: 299;
  transform: translateX(105%);
  transition: transform 0.5s ease 0s;
}
.drawer-content.is-active {
  transform: translateX(0);
}

.drawer-content_items {
  padding-top: 157px;
}

.drawer-content_item a {
  text-align: center;
  font-size: 18px;
  width: 100%;
  height: 22px;
  display: block;
  color: #3E3E3E;
  font-family: "Montserrat", sans-serif;
}
.drawer-content_item a span {
  display: inline;
  position: relative;
}
.drawer-content_item a span::after {
  content: "";
  position: absolute;
  bottom: -19px;
  left: 0;
  width: 100%;
  height: 1px;
  background: transparent;
  transition: all 0.3s ease 0s;
}
.drawer-content_item a span:hover::after, .drawer-content_item a span.is-active::after {
  background: #3E3E3E;
}
.drawer-content_item:nth-child(n+2) {
  padding-top: 32px;
}

.drawer-background {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #3E3E3E;
  opacity: 0.7;
  z-index: 298;
  display: none;
}
.drawer-background.is-active {
  display: block;
}

/*-----------------------
top
-------------------------*/
.top {
  width: 100%;
  height: 648px;
  position: relative;
  background: url(../img/mv@2x.png) no-repeat center center/cover;
}
@media screen and (max-width: 767px) {
  .top {
    padding-top: 177%;
    background: url(../img/mv@2x.png) no-repeat 22% center/cover;
  }
}

.top-content {
  position: absolute;
  top: 35%;
  width: 100%;
  max-width: 600px;
}
@media screen and (min-width: 768px) {
  .top-content {
    right: 40px;
  }
}
@media screen and (max-width: 767px) {
  .top-content {
    top: 33%;
  }
}

.top-message {
  top: 36%;
  right: 0;
}
@media screen and (max-width: 767px) {
  .top-message {
    margin: 0 16px;
  }
}

.top-message-title {
  font-family: "游ゴシック体", serif;
  font-size: 32px;
  font-weight: 700;
  padding-bottom: 30px;
  line-height: 1.5;
}
@media screen and (max-width: 767px) {
  .top-message-title {
    font-size: 24px;
    line-height: 1.6666666667;
    padding-bottom: 24px;
  }
}

.top-message-text {
  font-family: "游ゴシック体", serif;
  font-size: 18px;
  font-weight: 700;
  letter-spacing: 0.45px;
}
@media screen and (max-width: 767px) {
  .top-message-text {
    font-size: 14px;
    line-height: 1.4285714286;
    letter-spacing: 0;
  }
}

@media screen and (min-width: 768px) {
  .top-contact {
    width: 282px;
    height: 50px;
    margin-top: 51px;
  }
}
@media screen and (max-width: 767px) {
  .top-contact {
    width: 219px;
    height: 32px;
    margin: 0 auto;
    margin-top: 36px;
  }
}

.top-contact-link a {
  font-family: "游ゴシック体", serif;
  font-size: 18px;
  font-weight: 700;
  padding: 16px 50px;
  background: #FFAA3B;
  box-shadow: 0px 3px 5px rgba(62, 62, 62, 0.2);
  border-radius: 10px;
  color: #fff;
  transition: all 0.3s ease 0s;
}
@media screen and (max-width: 767px) {
  .top-contact-link a {
    font-size: 16px;
    padding: 17px 30px;
  }
}
.top-contact-link a:hover {
  background: #F18900;
}
.top-contact-link a:disabled {
  background: #B2B2B2;
}

/*-----------------------
main
-------------------------*/
.main {
  background: #F3F3F3;
}

/*-----------------------
common
-------------------------*/
.util-title {
  font-size: 36px;
  font-weight: 600;
  line-height: 1;
  text-align: center;
  padding-top: 66px;
  padding-bottom: 61px;
}
@media screen and (max-width: 767px) {
  .util-title {
    padding-top: 45px;
    padding-bottom: 43px;
    font-size: 30px;
  }
}

/*-----------------------
news
-------------------------*/
.news {
  margin: 120px auto;
}
@media screen and (max-width: 767px) {
  .news {
    margin: -37px auto 60px;
    height: 554px;
  }
}

@media screen and (max-width: 767px) {
  .news-inner {
    display: flex;
    justify-content: center;
  }
}

.news-contain {
  background: #fff;
  box-shadow: 0px 5px 12px rgba(62, 62, 62, 0.2);
}
@media screen and (min-width: 768px) {
  .news-contain {
    padding: 0 60px 0;
  }
}
@media screen and (max-width: 767px) {
  .news-contain {
    position: absolute;
    max-width: 91.4%;
    z-index: 2;
  }
}

.news-items {
  text-align: center;
  border-top: 1px solid #CECDCD;
}

.news-item {
  border-bottom: 1px solid #CECDCD;
  padding: 34px 52px 43px 0px;
}
@media screen and (max-width: 767px) {
  .news-item {
    padding: 10px 5px 9px 16px;
  }
}
.news-item:hover {
  background: rgba(73, 115, 255, 0.1019607843);
}

.news-meta {
  display: flex;
  align-items: center;
}
@media screen and (max-width: 767px) {
  .news-meta {
    flex-wrap: wrap;
  }
}

@media screen and (min-width: 768px) {
  .news_date {
    width: 98px;
    font-size: 18px;
  }
}
@media screen and (max-width: 767px) {
  .news_date {
    font-size: 14px;
  }
}

.news_label {
  width: 121px;
  height: 30px;
  line-height: 26px;
  text-align: center;
  font-size: 14px;
  border: 2px solid #3B69FF;
  border-radius: 50px;
  margin-left: 39px;
}
@media screen and (max-width: 767px) {
  .news_label {
    width: 81px;
    height: 20px;
    line-height: 17px;
    font-size: 12px;
    margin-left: 24px;
  }
}

.news_title {
  text-align: left;
  position: relative;
  font-family: "游ゴシック体", serif;
  line-height: 1.6;
}
@media screen and (min-width: 768px) {
  .news_title {
    letter-spacing: 0.45px;
    font-size: 18px;
    width: calc(100% - 299px - 43px);
    margin-left: 40px;
  }
}
@media screen and (max-width: 767px) {
  .news_title {
    font-size: 14px;
    padding-top: 7px;
    width: calc(100% - 43px);
  }
}
.news_title a {
  line-height: 1.4444444444;
}
.news_title::after {
  content: "";
  position: absolute;
  right: -112px;
  top: 50%;
  transform: translateY(-50%);
  width: 43px;
  height: 27px;
  background: url(../img/news-arrow.png) no-repeat, center center/contain;
}
@media screen and (max-width: 767px) {
  .news_title::after {
    top: 30%;
    right: -63px;
  }
}

.news_more a {
  display: inline-block;
  border: 1px solid #707070;
  padding: 16px 79px;
  margin: 40px auto;
  font-size: 20px;
  letter-spacing: 4px;
  color: #3E3E3E;
  font-weight: 600;
  transition: all 0.3s ease 0s;
}
.news_more a:hover {
  background: #3E3E3E;
  color: #FFF;
}
@media screen and (max-width: 767px) {
  .news_more a {
    font-size: 18px;
    width: 78.4%;
    padding: 12px 0;
    margin: 40px auto;
    letter-spacing: 3.6px;
  }
}

/*-----------------------
service
-------------------------*/
.service {
  width: 100%;
  height: 400px;
  background: #3E3E3E;
}
@media screen and (max-width: 767px) {
  .service {
    height: 480px;
  }
}

.service-inner {
  padding: 0 40px;
  max-width: 960px;
}
@media screen and (max-width: 767px) {
  .service-inner {
    padding: 0 16px;
  }
}

.accent {
  color: #fff;
}

.service-contain {
  background: #fff;
  margin: 0 auto;
  box-shadow: 0px 5px 12px rgba(62, 62, 62, 0.2);
}
@media screen and (min-width: 768px) {
  .service-contain {
    display: flex;
    align-items: center;
  }
}
@media screen and (max-width: 767px) {
  .service-contain {
    padding: 40px 0 34px;
  }
}

.service-item {
  padding: 58px 45px 58px;
}
@media screen and (max-width: 767px) {
  .service-item {
    padding: 0 16px;
  }
  .service-item + .service-item {
    margin-top: 33px;
  }
}

.service-item-img {
  width: 53px;
  height: 64px;
  margin: 0 auto;
  padding-bottom: 8px;
  padding-top: 14px;
  margin-bottom: 5px;
}
@media screen and (max-width: 767px) {
  .service-item-img {
    margin-bottom: 9px;
  }
}

.service-title {
  text-align: center;
  font-size: 20px;
  font-weight: 600;
  letter-spacing: 4px;
  padding-bottom: 12px;
  font-family: "Montserrat", sans-serif;
}
@media screen and (max-width: 767px) {
  .service-title {
    padding-bottom: 16px;
    line-height: 1.2;
  }
}

.service-text {
  font-size: 14px;
  line-height: 1.7142857143;
}

/*-----------------------
results
-------------------------*/
.results {
  margin-top: 215px;
}
@media screen and (max-width: 767px) {
  .results {
    margin-top: 391px;
  }
}

.utiltitle-results {
  text-align: left;
  font-size: 36px;
  font-weight: 600;
  padding: 55px 0 53px;
}
@media screen and (max-width: 767px) {
  .utiltitle-results {
    text-align: center;
    font-size: 30px;
    padding: 35px 0 34px;
    padding-right: 16px;
  }
}

@media screen and (min-width: 768px) {
  .results-inner {
    padding-left: 40px;
  }
}

.results-content {
  background: #3E3E3E;
}
.results-content-inner {
  padding-left: 60px;
}
@media screen and (max-width: 767px) {
  .results-content-inner {
    padding-left: 16px;
  }
}

.swiper-slide {
  width: 400px;
  height: 366px;
}
@media screen and (max-width: 767px) {
  .swiper-slide {
    width: none;
  }
}

.results-item-body {
  background: #fff;
  padding: 16px;
}
@media screen and (max-width: 767px) {
  .results-item-body {
    text-align: left;
    padding: 12px;
  }
}

.results-item-title {
  font-weight: 700;
  font-size: 20px;
  font-family: "游ゴシック体", serif;
  color: #3E3E3E;
}
@media screen and (max-width: 767px) {
  .results-item-title {
    font-size: 14px;
  }
}

.results-item-text {
  padding-top: 4px;
  font-family: "游ゴシック体", serif;
  color: #3E3E3E;
}
@media screen and (max-width: 767px) {
  .results-item-text {
    padding-top: 6px;
    font-size: 12px;
  }
}

@media screen and (min-width: 768px) {
  .swiper-wrapper {
    height: 383px;
  }
}
@media screen and (max-width: 767px) {
  .swiper-wrapper {
    height: 273px;
  }
}

.swiper-slide {
  margin-right: initial;
}

.swiper-slide swiper-slide-prev {
  margin-right: 0;
}

.swiper-pagination {
  position: relative;
  text-align: left;
  padding-top: 31px;
  padding-left: 1px;
}
@media screen and (max-width: 767px) {
  .swiper-pagination {
    padding-top: 14px;
    text-align: center;
  }
}

.swiper-pagination-bullet {
  background: #fff;
  width: 12px;
  height: 12px;
  opacity: 1;
}

.swiper-pagination-bullet-active {
  position: relative;
  background: #fff;
  width: 12px;
  height: 12px;
  opacity: 1;
}
.swiper-pagination-bullet-active::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 20px;
  height: 20px;
  border-radius: 50%;
  border: 1px solid #fff;
}

.swiper-horizontal > .swiper-pagination-bullets .swiper-pagination-bullet, .swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet {
  margin-right: 16px;
  background: #fff;
}

.results-button a {
  font-size: 20px;
  letter-spacing: 4px;
  color: #fff;
  font-weight: 600;
  display: inline-block;
  text-align: center;
  border: 1px solid #fff;
  width: 289px;
  height: 64px;
  line-height: 64px;
  margin: 30px 0 60px;
  transition: all 0.3s ease 0s;
  font-family: "Montserrat", sans-serif;
}
@media screen and (max-width: 767px) {
  .results-button a {
    font-size: 18px;
    text-align: center;
    margin: 13px 0 40px;
    width: 88.2%;
    height: 54px;
    line-height: 54px;
    margin-left: 13px;
    letter-spacing: 3.6px;
  }
}
.results-button a:hover {
  background: #fff;
  color: #3E3E3E;
  border: 1px solid #3E3E3E;
}

/*-----------------------
price
-------------------------*/
.util-title-price {
  font-size: 36px;
  font-weight: 600;
  line-height: 1;
  text-align: center;
  padding-top: 125px;
  padding-bottom: 61px;
}
@media screen and (max-width: 767px) {
  .util-title-price {
    font-size: 30px;
    padding-top: 42px;
    padding-bottom: 45px;
  }
}

@media screen and (min-width: 768px) {
  .price-inner {
    padding: 0 160px;
  }
}
@media screen and (max-width: 767px) {
  .price-inner {
    padding: 0 16px;
  }
}

.price-table-wrapper {
  margin: 0 auto;
  max-width: 960px;
  margin-bottom: 65px;
}
@media screen and (max-width: 767px) {
  .price-table-wrapper {
    margin-bottom: 0px;
  }
}

.price-table {
  border-collapse: collapse;
  width: 100%;
  table-layout: fixed;
  margin-bottom: 4px;
  font-family: "Montserrat", sans-serif;
}
.price-table tr {
  height: 56px;
}
@media screen and (max-width: 767px) {
  .price-table tr {
    height: 55px;
  }
}
.price-table th, .price-table td {
  border: solid 1px black;
}
@media screen and (min-width: 768px) {
  .price-table th, .price-table td {
    height: 61px;
  }
}
.price-table th {
  background: #3E3E3E;
  color: #fff;
  font-size: 24px;
  font-weight: 600;
}
@media screen and (min-width: 768px) {
  .price-table th:nth-child(1) {
    width: 27.2%;
  }
}
@media screen and (max-width: 767px) {
  .price-table th:nth-child(1) {
    font-size: 18px;
    width: 100px;
  }
}
.price-table td {
  font-size: 24px;
  font-weight: 600;
  background: #fff;
  padding: 11px 0;
  padding-left: 37px;
}
@media screen and (max-width: 767px) {
  .price-table td {
    font-size: 20px;
    padding-left: 20px;
  }
}

.price-attention {
  font-family: "游ゴシック体", serif;
  font-size: 12px;
  padding-bottom: 60px;
}

/*-----------------------
comments
-------------------------*/
.comments-inner {
  padding: 0 40px;
}
@media screen and (max-width: 767px) {
  .comments-inner {
    padding: 0 16px;
  }
}

.comments-wrapper {
  display: flex;
  justify-content: center;
  margin-top: 34px;
}
@media screen and (max-width: 767px) {
  .comments-wrapper {
    margin-top: 0px;
  }
}

.comments-container {
  max-width: 666px;
  background: #fff;
}

.comments-picture {
  display: flex;
  align-items: center;
}
.comments-picture img {
  width: 100%;
}
@media screen and (max-width: 767px) {
  .comments-picture img {
    display: none;
  }
}

.comments-items-wrapper {
  padding: 111px 60px 123px;
  box-shadow: 0px 0px 10px rgba(0, 0, 0, 0.1607843137);
}
@media screen and (max-width: 767px) {
  .comments-items-wrapper {
    padding: 31px 20px 32px;
  }
}

.comments-title {
  font-size: 36px;
  padding-bottom: 50px;
  font-family: "Montserrat", sans-serif;
}
@media screen and (max-width: 767px) {
  .comments-title {
    font-size: 30px;
    padding-bottom: 34px;
  }
}

@media screen and (max-width: 767px) {
  .comments-item-text {
    font-size: 14px;
  }
}

.comments-item {
  display: flex;
}
.comments-item:nth-child(2) {
  padding-bottom: 60px;
}
@media screen and (max-width: 767px) {
  .comments-item:nth-child(2) {
    padding-bottom: 29px;
  }
}

.comments-item-picture {
  padding-right: 32px;
}
@media screen and (max-width: 767px) {
  .comments-item-picture {
    padding-right: 20px;
  }
}
.comments-item-picture img {
  width: 100px;
  height: 100px;
}
@media screen and (max-width: 767px) {
  .comments-item-picture img {
    width: 60px;
    height: 60px;
  }
}

.comments {
  width: 76.5%;
  background: #3E3E3E;
  height: 576px;
  margin-top: -453px;
}
@media screen and (max-width: 767px) {
  .comments {
    width: 100%;
    margin-top: -365px;
    height: 424px;
  }
}

/*-----------------------
qa
-------------------------*/
.qa {
  width: 100%;
  height: 821px;
  background: url(../img/qa-bg@.png) no-repeat center center/cover;
}
@media screen and (min-width: 768px) {
  .qa {
    height: 946px;
  }
}

.util-title-qa {
  font-size: 36px;
  font-weight: 600;
  line-height: 1;
  text-align: center;
  padding-top: 61px;
  padding-bottom: 68px;
  font-family: "Montserrat", sans-serif;
}
@media screen and (max-width: 767px) {
  .util-title-qa {
    padding-top: 48px;
    padding-bottom: 42px;
    font-size: 30px;
  }
}

.qa-list {
  padding-bottom: 120px;
}
@media screen and (min-width: 768px) {
  .qa-list {
    margin-left: 49%;
  }
}
@media screen and (max-width: 767px) {
  .qa-list {
    padding-bottom: 60px;
  }
}

.qa-item {
  font-family: "游ゴシック体", serif;
  background: #fff;
  border-radius: 4px;
  padding: 14px 14px;
}
.qa-item:not(:nth-child(6)) {
  margin-bottom: 34px;
}
@media screen and (max-width: 767px) {
  .qa-item:not(:nth-child(6)) {
    margin-bottom: 26px;
  }
}

.question {
  display: inline-block;
  background: #3B69FF;
  text-align: center;
  color: #fff;
  width: 24px;
  height: 24px;
  line-height: 24px;
  border-radius: 50%;
  margin-right: 21px;
}

.qa-content {
  background: rgba(59, 105, 255, 0.2);
  border-radius: 4px;
  padding: 15px;
  margin: 11px 0 0;
  line-height: 1.5;
}
@media screen and (max-width: 767px) {
  .qa-content {
    font-size: 14px;
    padding: 12px;
  }
}

.qa-box-q {
  position: relative;
}

.qa-title {
  display: flex;
  align-items: center;
}

.question-text {
  font-weight: 700;
  letter-spacing: 0.4px;
}

.qa-box-icon {
  position: absolute;
  width: 17px;
  height: 17px;
  right: 1px;
  top: 50%;
  transform: translateY(-50%);
  cursor: pointer;
}
.qa-box-icon.is-open .qa-box_bar2 {
  transform: rotate(90deg);
}

.qa-box_bar1 {
  width: 17px;
  height: 4px;
  background: #3B69FF;
  border-radius: 20px;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: 0;
}

.qa-box_bar2 {
  width: 4px;
  height: 17px;
  background: #3B69FF;
  border-radius: 20px;
  position: absolute;
  top: 0;
  transform: translateX(-50%);
  left: 50%;
  transition: all 0.3s ease 0s;
}

.qa-box-a {
  display: none;
}

/*-----------------------
access
-------------------------*/
.access {
  position: relative;
  padding-top: 123px;
  padding-left: 100px;
  padding-right: 40px;
  padding-bottom: 120px;
}
@media screen and (max-width: 767px) {
  .access {
    padding-top: 40px;
    padding: 0 16px;
  }
}
.access::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 980px;
  height: 504px;
  max-width: 100%;
  background: #3E3E3E;
}
@media screen and (max-width: 767px) {
  .access::before {
    height: 100%;
  }
}

@media screen and (min-width: 768px) {
  .access-content {
    display: flex;
    max-width: 1200px;
  }
}

.access-address {
  position: relative;
  padding-right: 71px;
  z-index: 1;
}

.access-title {
  color: #fff;
  font-size: 36px;
  padding: 0 0 50px 0;
  font-family: "Montserrat", sans-serif;
}
@media screen and (max-width: 767px) {
  .access-title {
    font-size: 30px;
    padding: 37px 0 33px;
  }
}

.access-info {
  font-family: "游ゴシック体", serif;
  color: #fff;
}
@media screen and (max-width: 767px) {
  .access-info {
    font-size: 14px;
  }
}

@media screen and (min-width: 768px) {
  .access-map {
    width: 726px;
    max-width: 100%;
  }
}
@media screen and (max-width: 767px) {
  .access-map {
    margin-top: 16px;
  }
}

.iframe-wrap {
  width: 100%;
  padding-top: 71.6253443526%;
  position: relative;
}
.iframe-wrap iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.access-button {
  font-family: "Montserrat", sans-serif;
}
.access-button a {
  display: inline-block;
  border: 1px solid #fff;
  width: 100%;
  height: 63px;
  line-height: 58px;
  margin-top: 24px;
  margin-bottom: 60px;
  text-align: center;
  letter-spacing: 2px;
  font-size: 20px;
  color: #fff;
  transition: all 0.3s ease 0s;
}
.access-button a:hover {
  background: #FFF;
  color: #3E3E3E;
  border: 1px solid #3E3E3E;
}
@media screen and (max-width: 767px) {
  .access-button a {
    font-size: 18px;
    height: 55px;
    margin-top: 21px;
  }
}
@media screen and (min-width: 768px) {
  .access-button a {
    max-width: 314px;
    width: 25vw;
    margin-top: 27px;
    margin-right: 30px;
    margin-bottom: 123px;
  }
}

/*-----------------------
contact
-------------------------*/
.contact {
  padding-top: 60px;
  padding-bottom: 60px;
  background: url(../img/contact-bg.png) no-repeat center center/cover;
}
@media screen and (max-width: 767px) {
  .contact {
    padding-top: 38px;
    padding-bottom: 40px;
  }
}

.contact_form {
  margin: 0 auto;
  width: 960px;
  max-width: 100%;
  background: #fff;
  border-radius: 12px;
}

.contact_form_picture {
  border-radius: 12px 12px 0px 0px;
  background: url(../img/contact1.png) no-repeat center center/cover;
}

.contact_form_content {
  border-radius: 12px;
}
@media screen and (min-width: 768px) {
  .contact_form_content {
    padding: 56px 0 60px;
    text-align: center;
  }
}
@media screen and (max-width: 767px) {
  .contact_form_content {
    padding: 38px 16px;
  }
}

.contact-title {
  color: #fff;
  font-size: 36px;
  text-align: center;
  font-family: "Montserrat", sans-serif;
}
@media screen and (max-width: 767px) {
  .contact-title {
    font-size: 30px;
  }
}

.contact-text {
  color: #fff;
}
@media screen and (min-width: 768px) {
  .contact-text {
    padding-top: 7px;
  }
}
@media screen and (max-width: 767px) {
  .contact-text {
    font-size: 14px;
  }
}

.contact_form_wrapper {
  padding: 59px 120px;
}
@media screen and (max-width: 767px) {
  .contact_form_wrapper {
    padding: 25px 12px 39px;
  }
}

@media screen and (min-width: 768px) {
  .contact_form_row {
    display: flex;
  }
}
.contact_form_row:not(:first-child) {
  padding-top: 19px;
}
@media screen and (max-width: 767px) {
  .contact_form_row:not(:first-child) {
    padding-top: 20px;
  }
}

.contact_form_label {
  padding-top: 9px;
  width: 188px;
}
@media screen and (max-width: 767px) {
  .contact_form_label {
    padding-bottom: 2px;
  }
}
.contact_form_label label {
  font-weight: 700;
  font-family: "游ゴシック体", serif;
}
.contact_form_label label.is-require {
  display: inline-block;
  position: relative;
}
.contact_form_label label.is-require::after {
  content: "必須";
  position: absolute;
  top: 0;
  width: 40px;
  font-weight: 700;
  color: #fff;
  background: #e81919;
  margin-left: 12px;
  text-align: center;
  font-size: 13px;
  border-radius: 2px;
}
@media screen and (max-width: 767px) {
  .contact_form_label label.is-require::after {
    font-size: 2px;
    top: 6px;
    margin-left: 20px;
  }
}

.contact_form_input_select {
  position: relative;
}
.contact_form_input_select::after {
  content: "";
  position: absolute;
  right: 17px;
  top: 16px;
  width: 7px;
  height: 7px;
  border-top: 2px solid #3E3E3E;
  border-left: 2px solid #3E3E3E;
  pointer-events: none;
  transform: translateY(-50%) rotate(-135deg);
}
@media screen and (max-width: 767px) {
  .contact_form_input_select::after {
    top: 26px;
  }
}
@media screen and (max-width: 767px) {
  .contact_form_input_select {
    width: 100%;
  }
}
.contact_form_input_select select {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  box-shadow: none;
  border: 1px solid #707070;
  background: #fff;
  padding: 10px 35px 10px 12px;
  font-size: inherit;
  cursor: pointer;
}
@media screen and (max-width: 767px) {
  .contact_form_input_select select {
    width: 100%;
    margin-top: 13px;
    font-size: 14px;
  }
}
.contact_form_input_select select:hover {
  box-shadow: 0px 0px 5px rgba(73, 115, 255, 0.5019607843);
}

.contact_form_input {
  overflow: hidden;
  padding-bottom: 5px;
}
@media screen and (min-width: 768px) {
  .contact_form_input {
    width: calc(100% - 188px);
  }
}
.contact_form_input [type=text] {
  box-shadow: none;
  border: none;
  border-bottom: 1px solid #707070;
  background: #fff;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  width: 100%;
  font-size: inherit;
  position: relative;
  transition: all 0.3s ease 0s;
  font-family: "游ゴシック体", serif;
}
.contact_form_input [type=text]:hover {
  border-bottom: 1px solid rgba(73, 115, 255, 0.5019607843);
  box-shadow: 0px 0px 8px rgba(73, 115, 255, 0.5019607843);
}
@media screen and (min-width: 768px) {
  .contact_form_input [type=text] {
    padding: 12px 11px 5px;
  }
}
@media screen and (max-width: 767px) {
  .contact_form_input [type=text] {
    font-size: 14px;
    padding-bottom: 1px;
  }
}
.contact_form_input [type=email] {
  box-shadow: none;
  border: none;
  border-bottom: 1px solid #707070;
  background: #fff;
  padding: 10px 16px;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  width: 100%;
  font-size: inherit;
}
.contact_form_input select {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  box-shadow: none;
  border: 1px solid #707070;
  background: #fff;
  padding: 9px 17px 10px 12px;
  font-size: inherit;
}
@media screen and (max-width: 767px) {
  .contact_form_input select {
    width: 100%;
  }
}

@media screen and (min-width: 768px) {
  .contact_form_radio {
    display: flex;
    padding-top: 19px;
  }
}
@media screen and (max-width: 767px) {
  .contact_form_radio {
    padding-top: 19px;
  }
}
.contact_form_radio span {
  margin-right: 40px;
}
@media screen and (max-width: 767px) {
  .contact_form_radio span {
    margin-right: 29px;
  }
}
.contact_form_radio label {
  cursor: pointer;
}
.contact_form_radio label:hover span::before {
  border-color: #4973ff;
  box-shadow: 0 0 4px #4973ff;
}
.contact_form_radio label:active span::before {
  background: rgba(73, 115, 255, 0.2);
}
.contact_form_radio [type=radio] {
  display: none;
}
.contact_form_radio span {
  display: inline-block;
  padding-left: 22px;
  position: relative;
  margin-right: 36px;
}
@media screen and (max-width: 767px) {
  .contact_form_radio span {
    padding-left: 21px;
  }
}
.contact_form_radio span::before {
  content: "";
  width: 12px;
  height: 12px;
  border: 1px solid #707070;
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  background: #fff;
  border-radius: 50%;
}
.contact_form_radio span::after {
  content: "";
  width: 6px;
  height: 6px;
  background: #4973FF;
  position: absolute;
  left: 4px;
  top: 50%;
  transform: translateY(-50%);
  border-radius: 50%;
  display: none;
}
.contact_form_radio [type=radio]:checked + span::after {
  display: block;
}

.contact_form_radio_label {
  width: 188px;
  font-weight: 700;
  font-family: "游ゴシック体", serif;
}
@media screen and (max-width: 767px) {
  .contact_form_radio_label {
    padding-bottom: 12px;
  }
}

.contact_form_message {
  padding-top: 16px;
}

.contact_form_input_message {
  margin-top: 3px;
}
@media screen and (max-width: 767px) {
  .contact_form_input_message {
    margin-top: 9px;
  }
}
.contact_form_input_message textarea {
  box-shadow: none;
  border: 1px solid #707070;
  background: #fff;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  width: 100%;
  height: 200px;
  font-size: inherit;
  transition: all 0.3s ease 0s;
}
.contact_form_input_message textarea:hover {
  box-shadow: 0px 0px 8px rgba(73, 115, 255, 0.5019607843);
  border: 1px solid rgba(73, 115, 255, 0.5019607843);
}
@media screen and (max-width: 767px) {
  .contact_form_input_message textarea {
    height: 160px;
  }
}

.contact_form_check {
  font-family: "游ゴシック体", serif;
  font-weight: 700;
}
@media screen and (min-width: 768px) {
  .contact_form_check {
    margin-top: 32px;
    font-size: 18px;
  }
}
@media screen and (max-width: 767px) {
  .contact_form_check {
    margin-top: 24px;
  }
}
.contact_form_check [type=checkbox] {
  display: none;
}
.contact_form_check label {
  cursor: pointer;
}
.contact_form_check label:hover span::before {
  border-color: #4973ff;
  box-shadow: 0 0 4px #4973ff;
}
.contact_form_check label:active span::before {
  background: rgba(73, 115, 255, 0.2);
}
.contact_form_check span {
  display: inline-block;
  padding-left: 40px;
  position: relative;
}
.contact_form_check span::before {
  content: "";
  width: 17px;
  height: 16px;
  background: #fff;
  border: 1px solid #3E3E3E;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: 0;
  transition: all 0.3s ease 0s;
}
.contact_form_check span::after {
  content: "";
  border-right: 2px solid #4973FF;
  border-bottom: 2px solid #4973FF;
  width: 7px;
  height: 13px;
  margin-top: -10px;
  position: absolute;
  top: 50%;
  transform: rotate(45deg);
  left: 5px;
  display: none;
}
.contact_form_check [type=checkbox]:checked + span::after {
  display: block;
}

.checkbox {
  margin-right: 21px;
}

@media screen and (max-width: 767px) {
  .contact_form_button {
    text-align: center;
  }
}
.contact_form_button [type=submit] {
  font-size: 18px;
  color: #fff;
  font-weight: 700;
  width: 173px;
  height: 50px;
  margin-top: 38px;
  background: #FFAA3B;
  border: none;
  border-radius: 10px;
  box-shadow: 0px 3px 5px rgba(0, 0, 0, 0.2);
  opacity: 1;
  transition: all 0.3s ease 0s;
}
.contact_form_button [type=submit]:hover {
  cursor: pointer;
  background: #F18900;
}
.contact_form_button [type=submit]:disabled {
  background: #B2B2B2;
}
@media screen and (max-width: 767px) {
  .contact_form_button [type=submit] {
    width: 165px;
    height: 48px;
    font-size: 16px;
    margin-top: 31px;
  }
}

/*-----------------------
footer
-------------------------*/
footer {
  background: #3E3E3E;
}
@media screen and (min-width: 768px) {
  footer {
    padding: 52px 40px;
  }
}
@media screen and (max-width: 767px) {
  footer {
    padding: 49px 0px;
  }
}

@media screen and (min-width: 768px) {
  .footer-container {
    display: flex;
    margin: 0 auto;
    max-width: 960px;
  }
}
@media screen and (max-width: 767px) {
  .footer-container {
    text-align: center;
  }
}

@media screen and (min-width: 768px) {
  .footer-left {
    width: 50%;
  }
}

@media screen and (min-width: 768px) {
  .footer-right {
    width: 50%;
    height: 49px;
  }
}

.footer-sns-list {
  display: flex;
  color: #E3E3E3;
  margin-bottom: 27px;
}
@media screen and (max-width: 767px) {
  .footer-sns-list {
    justify-content: center;
    margin-bottom: 22px;
  }
}

.footer-sns-item {
  font-size: 36px;
  color: #E3E3E3;
  transition: all 0.3s ease 0s;
}
.footer-sns-item a:hover {
  opacity: 0.7;
}
.footer-sns-item + .footer-sns-item {
  margin-left: 32px;
}
@media screen and (max-width: 767px) {
  .footer-sns-item + .footer-sns-item {
    margin-left: 49px;
  }
}
@media screen and (max-width: 767px) {
  .footer-sns-item {
    font-size: 40px;
  }
}

.footer-sns-item-list {
  color: #E3E3E3;
}

.footer-nav-list {
  color: #fff;
}
@media screen and (max-width: 767px) {
  .footer-nav-list {
    margin-bottom: 33px;
  }
}

.footer-nav-item {
  display: block;
  font-family: "游ゴシック体";
  color: #fff;
}
.footer-nav-item:not(:nth-child(3n)) {
  margin-bottom: 15px;
}
@media screen and (max-width: 767px) {
  .footer-nav-item:not(:nth-child(3n)) {
    margin-bottom: 20px;
  }
}

.footer-nav-item-list {
  display: block;
  color: #fff;
  transition: all 0.3s ease 0s;
}
@media screen and (max-width: 767px) {
  .footer-nav-item-list {
    font-size: 14px;
  }
}
.footer-nav-item-list:hover {
  opacity: 0.7;
}

.footer-logo {
  font-size: 40px;
  font-weight: 700;
  text-align: right;
  height: 49px;
  color: #E3E3E3;
  margin-bottom: 19px;
  font-family: "Montserrat", sans-serif;
}
@media screen and (max-width: 767px) {
  .footer-logo {
    font-size: 32px;
    text-align: center;
    margin-bottom: 5px;
  }
}

.footer-copyright {
  font-size: 12px;
  text-align: right;
  color: #fff;
  letter-spacing: 0.3px;
}
@media screen and (max-width: 767px) {
  .footer-copyright {
    text-align: center;
  }
}

.to-top {
  position: fixed;
  right: 39px;
  bottom: 39px;
  transition: all 0.3s ease 0s;
  opacity: 0;
  visibility: hidden;
}
.to-top.is-show {
  opacity: 1;
  visibility: visible;
}
.to-top:hover {
  opacity: 0.7;
}
@media screen and (max-width: 767px) {
  .to-top {
    right: 15px;
    bottom: 12px;
  }
}
.to-top a {
  text-decoration: none;
}
.to-top a img {
  width: 52px;
  height: 52px;
}