@charset "UTF-8";
/* =======================================
 base style
======================================= */
html {
  -webkit-text-size-adjust: 100%;
  overflow-x: hidden;
}

h1,
h2,
h3,
h4,
h5,
dl,
dt,
dd,
ul,
ol,
li {
  font-size: 100%;
  line-height: 1;
  margin: 0;
  padding: 0;
}

p {
  margin: 0;
  padding: 0;
}

ul,
ol,
li {
  list-style: none;
}

body {
  background: #fff;
  line-height: 1;
  margin: auto;
  width: 100%;
  font-family: "Noto Sans JP", sans-serif;
}

@media only screen and (min-width: 769px) {
  body {
    font-size: 1.333vw;
  }
}

@media only screen and (min-width: 1200px) {
  body {
    font-size: 16px;
    min-width: 1200px;
  }
}

@media only screen and (max-width: 768px) {
  body {
    font-size: 3.467vw;
    overflow-x: hidden;
  }
}

img {
  width: 100%;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}

a {
  text-decoration: none;
  -webkit-animation: all 1s ease-in-out;
          animation: all 1s ease-in-out;
}

a:hover {
  opacity: 0.9;
  -webkit-animation: all 1s ease-in-out;
          animation: all 1s ease-in-out;
}

.main_ctx {
  position: relative;
}

@media only screen and (min-width: 769px) {
  .main_ctx {
    margin-top: 4.375em;
  }
}

@media only screen and (max-width: 768px) {
  .main_ctx {
    margin-top: 13.333%;
  }
}

.inner_ctx {
  margin: auto;
  position: relative;
}

@media only screen and (min-width: 769px) {
  .inner_ctx {
    width: 100vw;
    max-width: 1200px;
  }
}

@media only screen and (max-width: 768px) {
  .inner_ctx {
    padding: 0 4.667%;
  }
}

@media only screen and (max-width: 768px) {
  .pc {
    display: none !important;
  }
}

@media only screen and (min-width: 769px) {
  .sp {
    display: none !important;
  }
}

@media only screen and (min-width: 769px) {
  .header_pc {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 1000;
    display: block;
    background-color: #000;
    height: 4.375em;
  }
  .header_pc .inner_ctx {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .header_pc .header_logo img {
    width: 12.5em;
  }
  .header_pc .header_nav {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .header_pc .header_nav ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    gap: 1.875em;
  }
  .header_pc .header_nav ul li {
    position: relative;
  }
  .header_pc .header_nav ul li a {
    color: #fff;
    font-size: 0.813em;
  }
  .header_pc .header_nav ul li:after {
    content: "";
    display: block;
    position: absolute;
    top: 0.25em;
    right: -0.938em;
    height: 0.75em;
    background-color: #fff;
    width: 1px;
  }
  .header_pc .header_nav ul li:last-child:after {
    display: none;
  }
  .header_pc .header_btn {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .header_pc .header_btn .tel a img {
    width: 12.5em;
  }
  .header_pc .header_btn .contact a img {
    width: 10.625em;
  }
}

@media only screen and (max-width: 768px) {
  .header_sp {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 1000;
    display: block;
  }
  .header_sp_bar {
    background-color: #1a1a1a;
    -webkit-box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
            box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
    z-index: 1000;
  }
  .header_sp_bar .inner_ctx {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    padding: 0 6vw;
    height: 13.333vw;
  }
  .header_sp_bar .header_logo img {
    width: 33.333vw;
  }
  .header_sp .hamburger_btn {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    cursor: pointer;
    width: 5.333vw;
    height: 4vw;
    gap: 1.6vw;
    -webkit-tap-highlight-color: transparent;
    -webkit-user-select: none;
       -moz-user-select: none;
        -ms-user-select: none;
            user-select: none;
    -ms-touch-action: manipulation;
        touch-action: manipulation;
    position: relative;
    z-index: 1000;
  }
  .header_sp .hamburger_btn span {
    background-color: #ffffff;
    -webkit-transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    width: 100%;
    height: 0.533vw;
    border-radius: 0.267vw;
    -webkit-transform-origin: center;
            transform-origin: center;
    will-change: transform, opacity;
  }
  .header_sp .hamburger_btn.active span:nth-child(1) {
    -webkit-transform: rotate(45deg) translate(1vw, 2vw);
            transform: rotate(45deg) translate(1vw, 2vw);
  }
  .header_sp .hamburger_btn.active span:nth-child(2) {
    opacity: 0;
  }
  .header_sp .hamburger_btn.active span:nth-child(3) {
    -webkit-transform: rotate(-45deg) translate(1vw, -2vw);
            transform: rotate(-45deg) translate(1vw, -2vw);
  }
}

.header_sp_menu {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  visibility: hidden;
  opacity: 0;
  -webkit-transition: visibility 0s linear 0.3s, opacity 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  transition: visibility 0s linear 0.3s, opacity 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  z-index: 999;
  will-change: opacity, visibility;
}

.header_sp_menu.active {
  visibility: visible;
  opacity: 1;
  -webkit-transition: visibility 0s linear 0s, opacity 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  transition: visibility 0s linear 0s, opacity 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.header_sp_overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.7);
  top: 13.333vw;
}

.header_sp_content {
  position: absolute;
  z-index: 1000;
  margin-top: 13.333vw;
  right: 0;
  width: 80vw;
  background-color: #1a1a1a;
  -webkit-transform: translateX(100%);
          transform: translateX(100%);
  -webkit-transition: -webkit-transform 0.3s ease;
  transition: -webkit-transform 0.3s ease;
  transition: transform 0.3s ease;
  transition: transform 0.3s ease, -webkit-transform 0.3s ease;
  overflow-y: auto;
  padding: 6.667vw 6.667vw 12vw;
}

.header_sp_menu.active .header_sp_content {
  -webkit-transform: translateX(0);
          transform: translateX(0);
}

.header_sp_nav {
  margin-bottom: 10.667vw;
}

.header_sp_nav ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.header_sp_nav ul li {
  border-bottom: 1px solid #ffffff;
  padding: 4.667vw 2.667vw;
}

.header_sp_nav ul li a {
  color: #ffffff;
  text-decoration: none;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  font-weight: 400;
  font-size: 3.867vw;
  gap: 3.2vw;
}

.header_sp_nav ul li a::before {
  content: "";
  font-size: 3.733vw;
  color: #999999;
  background-image: url(../img/header/h_arrow_sp.png);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  width: 1.333vw;
  height: 2.667vw;
}

.header_sp_btn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: 4vw;
}

.header_sp_btn a {
  display: block;
  width: 66.667vw;
}

@media only screen and (min-width: 769px) {
  .hero {
    margin-top: 4.375em;
  }
}

@media only screen and (max-width: 768px) {
  .hero {
    margin-top: 13.333vw;
  }
}

@media only screen and (min-width: 769px) {
  .hero .archive_hero {
    width: 4.625em;
  }
}

@media only screen and (max-width: 768px) {
  .hero .archive_hero {
    width: 14.667vw;
  }
}

@media only screen and (min-width: 769px) {
  .hero .download_hero {
    width: 5.188em;
  }
}

@media only screen and (max-width: 768px) {
  .hero .download_hero {
    width: 16.667vw;
  }
}

.hero {
  background-color: #0068b6;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  text-align: center;
}

@media only screen and (min-width: 769px) {
  .hero {
    height: 12.5em;
  }
}

@media only screen and (max-width: 768px) {
  .hero {
    height: 34.667vw;
  }
}

.hero .hero_inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

@media only screen and (min-width: 769px) {
  .hero .hero_inner {
    gap: 1.25em;
  }
}

@media only screen and (max-width: 768px) {
  .hero .hero_inner {
    gap: 4vw;
  }
}

.hero_title {
  color: #ffffff;
  font-weight: 500;
  margin: 0;
}

@media only screen and (min-width: 769px) {
  .hero_title {
    font-size: 2.5em;
  }
}

@media only screen and (max-width: 768px) {
  .hero_title {
    font-size: 6.667vw;
  }
}

@media only screen and (min-width: 769px) {
  .breadcrumbs {
    padding: 1.25em 0;
  }
}

@media only screen and (max-width: 768px) {
  .breadcrumbs {
    padding: 2.667vw 0;
  }
}

.breadcrumbs_list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  list-style: none;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}

@media only screen and (min-width: 769px) {
  .breadcrumbs_list {
    margin: 0 6.25em;
  }
}

.breadcrumbs_item {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  color: #333333;
}

.breadcrumbs_item:not(:last-child)::after {
  content: "";
  display: inline-block;
  vertical-align: middle;
}

@media only screen and (min-width: 769px) {
  .breadcrumbs_item:not(:last-child)::after {
    width: 0.25em;
    height: 0.5em;
    margin: 0 0.5em;
    background: url("../img/common/breadcrumb_arrow.png") no-repeat center;
    background-size: contain;
  }
}

@media only screen and (max-width: 768px) {
  .breadcrumbs_item:not(:last-child)::after {
    width: 0.667vw;
    height: 2vw;
    margin: 0 2vw;
    background: url("../img/common/breadcrumb_arrow.png") no-repeat center;
    background-size: contain;
  }
}

.breadcrumbs_link {
  color: #666666;
  text-decoration: none;
  font-weight: 400;
  -webkit-transition: color 0.3s ease;
  transition: color 0.3s ease;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  text-decoration: underline;
}

@media only screen and (min-width: 769px) {
  .breadcrumbs_link {
    font-size: 0.875em;
    gap: 0.25em;
  }
}

@media only screen and (max-width: 768px) {
  .breadcrumbs_link {
    font-size: 3.2vw;
    line-height: 5.333vw;
    gap: 1.333vw;
  }
}

@media only screen and (min-width: 769px) {
  .breadcrumbs_home_icon {
    width: 1em;
    height: 0.813em;
  }
}

@media only screen and (max-width: 768px) {
  .breadcrumbs_home_icon {
    width: 3.2vw;
    height: 2.667vw;
  }
}

.breadcrumbs_current {
  color: #333333;
  font-weight: 400;
}

@media only screen and (min-width: 769px) {
  .breadcrumbs_current {
    font-size: 0.875em;
    line-height: 2;
  }
}

@media only screen and (max-width: 768px) {
  .breadcrumbs_current {
    font-size: 3.2vw;
    line-height: 5.333vw;
  }
}

@media only screen and (min-width: 769px) {
  .top .fv {
    background: url("../img/top/fv_bg.jpg") no-repeat 50% 0%;
    background-size: 125em auto;
    height: 37.5em;
  }
}

@media only screen and (max-width: 768px) {
  .top .fv {
    background: url("../img/top/fv_bg_sp.jpg") no-repeat 50% 0;
    background-size: 100vw auto;
    height: 149.333vw;
  }
}

.top .fv_txt {
  position: absolute;
}

@media only screen and (min-width: 769px) {
  .top .fv_txt {
    width: 46.875em;
    top: 4.625em;
    left: 5.625em;
  }
}

@media only screen and (max-width: 768px) {
  .top .fv_txt {
    width: 81.6vw;
    top: 10.267vw;
    left: 5.333vw;
  }
}

.top .fv_sub {
  position: absolute;
  width: 100%;
  font-weight: 500;
}

@media only screen and (min-width: 769px) {
  .top .fv_sub {
    top: 28em;
    left: 7.063em;
  }
}

@media only screen and (max-width: 768px) {
  .top .fv_sub {
    top: 112.267vw;
    left: 6vw;
  }
}

.top .fv_sub p:first-child {
  position: absolute;
  color: #fff;
}

@media only screen and (min-width: 769px) {
  .top .fv_sub p:first-child {
    font-size: 1.875em;
    letter-spacing: 0.2em;
  }
}

@media only screen and (max-width: 768px) {
  .top .fv_sub p:first-child {
    font-size: 4.533vw;
    letter-spacing: 0.1em;
  }
}

.top .fv_sub p:nth-child(2) {
  color: #0068b6;
  position: relative;
}

@media only screen and (min-width: 769px) {
  .top .fv_sub p:nth-child(2) {
    font-size: 1.563em;
    left: 5.28em;
    top: 0.6em;
  }
}

@media only screen and (max-width: 768px) {
  .top .fv_sub p:nth-child(2) {
    font-size: 3.733vw;
    left: 20vw;
    top: 2.4vw;
  }
}

.top .fv_sub p:last-child {
  color: #fff;
}

@media only screen and (min-width: 769px) {
  .top .fv_sub p:last-child {
    font-size: 1.375em;
    margin-top: 2.273em;
    letter-spacing: 0.05em;
  }
}

@media only screen and (max-width: 768px) {
  .top .fv_sub p:last-child {
    font-size: 3.6vw;
    margin-top: 10.667vw;
    letter-spacing: 0.02em;
  }
}

.top .fv_cost {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  position: absolute;
}

@media only screen and (min-width: 769px) {
  .top .fv_cost {
    top: 21.625em;
    left: 53.563em;
  }
}

@media only screen and (max-width: 768px) {
  .top .fv_cost {
    top: 82.667vw;
    left: 63.467vw;
  }
}

.top .fv_cost p:first-child {
  color: #0068b6;
}

@media only screen and (min-width: 769px) {
  .top .fv_cost p:first-child {
    font-size: 1.25em;
    margin-bottom: 0.2em;
  }
}

@media only screen and (max-width: 768px) {
  .top .fv_cost p:first-child {
    font-size: 3.2vw;
    margin-bottom: 1.333vw;
  }
}

.top .fv_cost p:nth-child(2) {
  color: #0068b6;
}

@media only screen and (min-width: 769px) {
  .top .fv_cost p:nth-child(2) {
    font-size: 1.875em;
    margin-bottom: 0.5em;
  }
}

@media only screen and (max-width: 768px) {
  .top .fv_cost p:nth-child(2) {
    font-size: 4.267vw;
    margin-bottom: 1.6vw;
  }
}

@media only screen and (min-width: 769px) {
  .top .fv_cost img {
    width: 11.813em;
  }
}

@media only screen and (max-width: 768px) {
  .top .fv_cost img {
    width: 25.6vw;
  }
}

@media only screen and (min-width: 769px) {
  .top .achievement {
    background: url("../img/top/achievement_bg.jpg") no-repeat 50% 0%;
    background-size: 125em auto;
    height: 26.25em;
  }
}

@media only screen and (max-width: 768px) {
  .top .achievement {
    background: url("../img/top/achievement_bg_sp.jpg") no-repeat 50% 0;
    background-size: 100vw auto;
    height: 120vw;
  }
}

.top .achievement .inner_ctx {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  flex-direction: column;
}

.top .achievement_title {
  color: #333333;
  font-weight: 500;
}

@media only screen and (min-width: 769px) {
  .top .achievement_title {
    font-size: 1.563em;
    padding-top: 2.4em;
    margin-bottom: 1em;
    letter-spacing: 0.05em;
  }
}

@media only screen and (max-width: 768px) {
  .top .achievement_title {
    text-align: center;
    font-size: 4.4vw;
    padding-top: 16vw;
    margin-bottom: 5.067vw;
    letter-spacing: 0.1em;
  }
}

@media only screen and (min-width: 769px) {
  .top .achievement_example {
    width: 59.375em;
    margin-bottom: 6.875em;
  }
}

@media only screen and (max-width: 768px) {
  .top .achievement_example {
    width: 85.333vw;
    margin-bottom: 13.333vw;
  }
}

.top .achievement_note {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

.top .achievement_note .bg {
  position: absolute;
}

@media only screen and (min-width: 769px) {
  .top .achievement_note .bg {
    width: 62.5em;
  }
}

@media only screen and (max-width: 768px) {
  .top .achievement_note .bg {
    width: 89.333vw;
  }
}

.top .achievement_note p {
  color: #fff;
}

@media only screen and (min-width: 769px) {
  .top .achievement_note p {
    font-size: 1.5em;
    letter-spacing: 0.05em;
  }
}

@media only screen and (max-width: 768px) {
  .top .achievement_note p {
    text-align: center;
    font-size: 4vw;
    line-height: 8vw;
  }
}

.top .support {
  background-color: #f2f2f2;
}

@media only screen and (min-width: 769px) {
  .top .support {
    padding: 3.125em 0;
  }
}

@media only screen and (max-width: 768px) {
  .top .support {
    padding: 13.333vw 0;
  }
}

@media only screen and (min-width: 769px) {
  .top .support .inner_ctx {
    padding: 0 6.25em;
  }
}

@media only screen and (max-width: 768px) {
  .top .support .inner_ctx {
    width: 85.333vw;
    padding: 0;
  }
}

.top .support_title {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}

@media only screen and (min-width: 769px) {
  .top .support_title {
    gap: 1.75em;
    margin-bottom: 2.5em;
  }
}

@media only screen and (max-width: 768px) {
  .top .support_title {
    gap: 6vw;
    margin-bottom: 8vw;
  }
}

.top .support_title .en {
  position: relative;
}

@media only screen and (min-width: 769px) {
  .top .support_title .en img {
    width: 6em;
  }
}

@media only screen and (max-width: 768px) {
  .top .support_title .en img {
    width: 21.333vw;
  }
}

.top .support_title .en:after {
  position: absolute;
  content: "";
  display: block;
  height: 1px;
  background-color: #0068b6;
}

@media only screen and (min-width: 769px) {
  .top .support_title .en:after {
    width: 2.5em;
    bottom: -0.563em;
  }
}

@media only screen and (max-width: 768px) {
  .top .support_title .en:after {
    width: 8vw;
    bottom: -2vw;
  }
}

.top .support_title .ja {
  color: #333333;
  font-weight: 600;
}

@media only screen and (min-width: 769px) {
  .top .support_title .ja {
    font-size: 2.063em;
    letter-spacing: 0.1em;
  }
}

@media only screen and (max-width: 768px) {
  .top .support_title .ja {
    font-size: 6.667vw;
  }
}

.top .support .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}

@media only screen and (min-width: 769px) {
  .top .support .list {
    gap: 1.875em;
  }
}

@media only screen and (max-width: 768px) {
  .top .support .list {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    gap: 4vw;
    margin-bottom: 10.667vw;
    gap: 9.333vw;
  }
}

@media only screen and (min-width: 769px) {
  .top .support .list .item {
    width: 20em;
  }
}

@media only screen and (max-width: 768px) {
  .top .support .list .item {
    width: 85.333vw;
  }
}

@media only screen and (min-width: 769px) {
  .top .support .list .item_img {
    width: 20em;
    height: 11.25em;
    margin-bottom: 1.25em;
  }
}

@media only screen and (max-width: 768px) {
  .top .support .list .item_img {
    width: 85.333vw;
    height: 48vw;
    margin-bottom: 4vw;
  }
}

.top .support .list .item_img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.top .support .list .item_txt p {
  color: #333333;
  text-decoration: underline;
}

@media only screen and (min-width: 769px) {
  .top .support .list .item_txt p {
    font-size: 1.063em;
    line-height: 1.941em;
  }
}

@media only screen and (max-width: 768px) {
  .top .support .list .item_txt p {
    font-size: 3.6vw;
    line-height: 7.2vw;
  }
}

@media only screen and (min-width: 769px) {
  .top .support .btn {
    text-align: center;
    margin-top: 3.125em;
  }
}

@media only screen and (max-width: 768px) {
  .top .support .btn {
    text-align: right;
    margin-top: 12vw;
  }
}

@media only screen and (min-width: 769px) {
  .top .support .btn img {
    width: 33.5em;
  }
}

@media only screen and (max-width: 768px) {
  .top .support .btn img {
    width: 86.667vw;
  }
}

@media only screen and (min-width: 769px) {
  .top .trouble {
    background: url("../img/top/trouble_bg.jpg") no-repeat 50% 0%;
    background-size: 125em auto;
    height: 55em;
    padding-top: 3.375em;
  }
}

@media only screen and (max-width: 768px) {
  .top .trouble {
    background-color: #ffffff;
    padding-top: 14vw;
  }
}

.top .trouble_title {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

@media only screen and (min-width: 769px) {
  .top .trouble_title {
    margin-bottom: 3.5em;
  }
}

@media only screen and (max-width: 768px) {
  .top .trouble_title {
    margin-bottom: 9.333vw;
  }
}

.top .trouble_title .bg {
  position: absolute;
}

@media only screen and (min-width: 769px) {
  .top .trouble_title .bg {
    width: 55.375em;
  }
}

@media only screen and (max-width: 768px) {
  .top .trouble_title .bg {
    width: 86.133vw;
  }
}

.top .trouble_title p {
  color: #333333;
  text-align: center;
  font-weight: 700;
}

@media only screen and (min-width: 769px) {
  .top .trouble_title p {
    font-size: 2.25em;
    line-height: 1.667em;
    letter-spacing: 0.1em;
  }
}

@media only screen and (max-width: 768px) {
  .top .trouble_title p {
    font-size: 5.333vw;
    line-height: 8vw;
    letter-spacing: 0.05em;
  }
}

@media only screen and (max-width: 768px) {
  .top .trouble_bg {
    margin: auto;
    width: 50.667vw;
  }
}

@media only screen and (min-width: 769px) {
  .top .trouble_list {
    margin-left: 7.813em;
  }
}

@media only screen and (max-width: 768px) {
  .top .trouble_list {
    margin-top: 4vw;
    margin-bottom: 8.933vw;
  }
}

.top .trouble_list .title {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  font-weight: 700;
}

@media only screen and (min-width: 769px) {
  .top .trouble_list .title {
    height: 3.75em;
  }
}

@media only screen and (max-width: 768px) {
  .top .trouble_list .title {
    background-color: #cdd5dd;
    height: 10.667vw;
  }
}

.top .trouble_list .title p {
  color: #062b54;
}

@media only screen and (min-width: 769px) {
  .top .trouble_list .title p {
    font-size: 1.438em;
  }
}

@media only screen and (max-width: 768px) {
  .top .trouble_list .title p {
    font-size: 4.267vw;
    padding-left: 4vw;
  }
}

.top .trouble_list ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}

@media only screen and (min-width: 769px) {
  .top .trouble_list ul {
    margin-top: 1.25em;
    gap: 0.125em;
  }
}

@media only screen and (max-width: 768px) {
  .top .trouble_list ul {
    margin-top: 6.133vw;
    gap: 2.667vw;
  }
}

.top .trouble_list ul li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  position: relative;
}

@media only screen and (min-width: 769px) {
  .top .trouble_list ul li {
    gap: 0.625em;
  }
}

@media only screen and (max-width: 768px) {
  .top .trouble_list ul li {
    gap: 2.667vw;
  }
}

.top .trouble_list ul li p {
  line-height: 1.6;
  color: #333333;
  font-weight: 500;
}

@media only screen and (min-width: 769px) {
  .top .trouble_list ul li p {
    font-size: 1.125em;
    letter-spacing: 0.05em;
  }
}

@media only screen and (max-width: 768px) {
  .top .trouble_list ul li p {
    font-size: 3.6vw;
    line-height: 5.333vw;
    letter-spacing: 0.05vw;
  }
}

.top .trouble_list ul li::before {
  content: "";
  display: inline-block;
  background-image: url("../img/top/trouble_check.png");
  background-size: contain;
  background-repeat: no-repeat;
  position: relative;
}

@media only screen and (min-width: 769px) {
  .top .trouble_list ul li::before {
    width: 1.25em;
    height: 0.938em;
    top: 0.375em;
  }
}

@media only screen and (max-width: 768px) {
  .top .trouble_list ul li::before {
    width: 4vw;
    height: 2.933vw;
    top: 1.333vw;
  }
}

@media only screen and (min-width: 769px) {
  .top .trouble_list.first {
    margin-bottom: 3.625em;
  }
}

@media only screen and (min-width: 769px) {
  .top .trouble_list.second {
    margin-bottom: 2em;
  }
}

@media only screen and (min-width: 769px) {
  .top .why_change {
    background: url("../img/top/why_change_bg.jpg") no-repeat 50% 0%;
    background-size: 125em auto;
    height: 88.75em;
    padding-top: 4.375em;
  }
}

@media only screen and (max-width: 768px) {
  .top .why_change {
    background: url("../img/top/why_change_bg_sp.jpg") no-repeat 50% 0;
    background-size: 100vw auto;
    height: 447.067vw;
    padding-top: 15.333vw;
  }
}

.top .why_change_title {
  width: 100%;
}

@media only screen and (min-width: 769px) {
  .top .why_change_title {
    padding: 0 6.25em;
  }
}

.top .why_change_title h2 {
  font-weight: 500;
  color: #fff;
  text-align: center;
  border-bottom: 1px solid #fff;
}

@media only screen and (min-width: 769px) {
  .top .why_change_title h2 {
    font-size: 2.25em;
    padding-bottom: 0.417em;
    letter-spacing: 0.04em;
  }
}

@media only screen and (max-width: 768px) {
  .top .why_change_title h2 {
    font-size: 5.2vw;
    line-height: 8vw;
    padding-bottom: 6.4vw;
    letter-spacing: 0.3vw;
  }
}

.top .why_change_sub {
  text-align: center;
  width: 100%;
  color: #fff;
}

@media only screen and (min-width: 769px) {
  .top .why_change_sub {
    padding-top: 2.5em;
  }
}

@media only screen and (max-width: 768px) {
  .top .why_change_sub {
    padding-top: 5.6vw;
  }
}

@media only screen and (min-width: 769px) {
  .top .why_change_sub p {
    font-size: 1.375em;
    line-height: 1.727em;
  }
}

@media only screen and (max-width: 768px) {
  .top .why_change_sub p {
    font-size: 3.6vw;
    line-height: 7.2vw;
  }
}

@media only screen and (min-width: 769px) {
  .top .why_change_content {
    background: url("../img/top/why_change_content_bg.png") no-repeat 50% 0%;
    background-size: 62.5em 36.25em;
    height: 36.25em;
    margin-top: 3.125em;
    padding: 0 6.25em;
  }
}

@media only screen and (max-width: 768px) {
  .top .why_change_content {
    background: url("../img/top/why_change_content_bg_sp.png") no-repeat 50% 0;
    background-size: 90.667vw 213.333vw;
    height: 213.333vw;
    margin-top: 8vw;
  }
}

.top .why_change_content ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}

@media only screen and (min-width: 769px) {
  .top .why_change_content ul {
    padding: 0 3.125em;
    gap: 5.313em 6.25em;
  }
}

@media only screen and (max-width: 768px) {
  .top .why_change_content ul {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    padding: 0 5.333vw;
  }
}

@media only screen and (min-width: 769px) {
  .top .why_change_content ul li {
    width: 25em;
  }
}

@media only screen and (max-width: 768px) {
  .top .why_change_content ul li {
    padding: 6.667vw 0;
    width: 80vw;
  }
}

@media only screen and (min-width: 769px) {
  .top .why_change_content_title {
    height: 3.75em;
    margin-bottom: 3.125em;
  }
}

@media only screen and (max-width: 768px) {
  .top .why_change_content_title {
    height: 22.667vw;
  }
}

.top .why_change_content_title p {
  color: #fff;
  text-align: left;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -ms-flex-line-pack: center;
      align-content: center;
}

@media only screen and (min-width: 769px) {
  .top .why_change_content_title p {
    font-size: 1.625em;
    height: 2.308em;
    padding-left: 1.923em;
  }
}

@media only screen and (max-width: 768px) {
  .top .why_change_content_title p {
    font-size: 4.8vw;
    height: 22.667vw;
    line-height: 7.2vw;
    padding-left: 8vw;
  }
}

.top .why_change_content_item .title {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

@media only screen and (min-width: 769px) {
  .top .why_change_content_item .title {
    margin-bottom: 1.563em;
  }
}

@media only screen and (max-width: 768px) {
  .top .why_change_content_item .title {
    margin-bottom: 2.133vw;
  }
}

@media only screen and (min-width: 769px) {
  .top .why_change_content_item .title img {
    width: 5em;
    height: 5em;
    margin-right: 1.25em;
  }
}

@media only screen and (max-width: 768px) {
  .top .why_change_content_item .title img {
    width: 16vw;
    height: 16vw;
    margin-right: 4vw;
  }
}

.top .why_change_content_item .title p {
  color: #0068b6;
  font-weight: 700;
}

@media only screen and (min-width: 769px) {
  .top .why_change_content_item .title p {
    font-size: 1.438em;
    line-height: 1.478em;
  }
}

@media only screen and (max-width: 768px) {
  .top .why_change_content_item .title p {
    font-size: 4.267vw;
    line-height: 6vw;
    letter-spacing: 0.1vw;
  }
}

.top .why_change_content_item .txt p {
  color: #333;
}

@media only screen and (min-width: 769px) {
  .top .why_change_content_item .txt p {
    font-size: 1.125em;
    line-height: 1.667em;
  }
}

@media only screen and (max-width: 768px) {
  .top .why_change_content_item .txt p {
    font-size: 3.6vw;
    line-height: 7.2vw;
  }
}

.top .why_change_point {
  margin: 0 auto;
}

@media only screen and (min-width: 769px) {
  .top .why_change_point {
    background: url("../img/top/why_change_point_bg.png") no-repeat 50% 0%;
    background-size: 63em 26.938em;
    width: 63em;
    height: 26.938em;
    margin-top: 3.563em;
  }
}

@media only screen and (max-width: 768px) {
  .top .why_change_point {
    background: url("../img/top/why_change_point_bg_sp.png") no-repeat 50% 0;
    background-size: 90.667vw 129.333vw;
    width: 90.667vw;
    height: 129.333vw;
    margin-top: 11.333vw;
  }
}

@media only screen and (min-width: 769px) {
  .top .why_change_point_title {
    padding-top: 6.063em;
  }
}

@media only screen and (max-width: 768px) {
  .top .why_change_point_title {
    padding-top: 16vw;
  }
}

.top .why_change_point_title h2 {
  color: #0068b6;
  text-align: center;
}

@media only screen and (min-width: 769px) {
  .top .why_change_point_title h2 {
    font-size: 2.188em;
    letter-spacing: 0.04em;
  }
}

@media only screen and (max-width: 768px) {
  .top .why_change_point_title h2 {
    font-size: 5.467vw;
    line-height: 7.333vw;
    letter-spacing: 0.4vw;
  }
}

@media only screen and (min-width: 769px) {
  .top .why_change_point_content {
    padding-top: 3.438em;
    padding-left: 4.875em;
  }
}

@media only screen and (max-width: 768px) {
  .top .why_change_point_content {
    margin: 0 auto;
    width: 77.333vw;
    padding-top: 48vw;
  }
}

.top .why_change_point_content p {
  color: #333333;
}

@media only screen and (min-width: 769px) {
  .top .why_change_point_content p {
    font-size: 1.375em;
    line-height: 2em;
  }
}

@media only screen and (max-width: 768px) {
  .top .why_change_point_content p {
    font-size: 3.6vw;
    line-height: 7.2vw;
    letter-spacing: 0.4vw;
  }
}

.top .why_change_point_content p span {
  color: #0068b6;
}

.top .quality {
  position: relative;
}

@media only screen and (min-width: 769px) {
  .top .quality {
    background: url("../img/top/quality_bg.jpg") no-repeat 50% 0%;
    background-size: 125em auto;
    height: 67.5em;
    padding-bottom: 3.75em;
  }
}

@media only screen and (max-width: 768px) {
  .top .quality {
    background: url("../img/top/quality_bg_sp.jpg") no-repeat 50% 0;
    background-size: 100vw auto;
    height: 282.667vw;
  }
}

.top .quality_content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin: auto;
}

@media only screen and (min-width: 769px) {
  .top .quality_content {
    height: 31.25em;
    gap: 4.125em;
  }
}

@media only screen and (max-width: 768px) {
  .top .quality_content {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    height: 169.333vw;
    gap: 20vw;
  }
}

@media only screen and (max-width: 768px) {
  .top .quality_title {
    margin-left: 8vw;
  }
}

.top .quality_title p:first-child {
  color: #0068b6;
  display: inline-block;
  font-weight: 700;
}

@media only screen and (min-width: 769px) {
  .top .quality_title p:first-child {
    font-size: 1.313em;
    margin-bottom: 1.667em;
    padding-left: 0.81em;
    letter-spacing: 0.2em;
  }
}

@media only screen and (max-width: 768px) {
  .top .quality_title p:first-child {
    font-size: 4.8vw;
    margin-bottom: 6.667vw;
    padding-left: 4vw;
  }
}

.top .quality_title p:nth-child(2) {
  color: #fff;
  font-weight: 700;
}

@media only screen and (min-width: 769px) {
  .top .quality_title p:nth-child(2) {
    font-size: 3.75em;
    margin-bottom: 0.667em;
    line-height: 1.183em;
  }
}

@media only screen and (max-width: 768px) {
  .top .quality_title p:nth-child(2) {
    font-size: 10vw;
    line-height: 11.6vw;
    margin-bottom: 6.667vw;
    letter-spacing: 0.4vw;
  }
}

.top .quality_title p:last-child {
  color: #fff;
  font-weight: 400;
  line-height: 1.6;
}

@media only screen and (min-width: 769px) {
  .top .quality_title p:last-child {
    font-size: 1.125em;
    line-height: 1.667em;
  }
}

@media only screen and (max-width: 768px) {
  .top .quality_title p:last-child {
    font-size: 3.6vw;
    line-height: 7.2vw;
    letter-spacing: 0.4vw;
  }
}

.top .quality_list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}

@media only screen and (min-width: 769px) {
  .top .quality_list {
    gap: 1.25em;
  }
}

@media only screen and (max-width: 768px) {
  .top .quality_list {
    -ms-flex-item-align: end;
        align-self: flex-end;
    gap: 5.333vw;
  }
}

.top .quality_list li {
  color: #333333;
  background: #fff;
  position: relative;
  -webkit-box-shadow: rgba(99, 99, 99, 0.2) 0px 2px 8px 0px;
          box-shadow: rgba(99, 99, 99, 0.2) 0px 2px 8px 0px;
}

@media only screen and (min-width: 769px) {
  .top .quality_list li {
    padding: 1.25em 2.5em;
    border-radius: 0.625em;
  }
}

@media only screen and (max-width: 768px) {
  .top .quality_list li {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    min-height: 17.333vw;
    width: 86.667vw;
    padding: 2.667vw 5.333vw 2.667vw 6.667vw;
    border-radius: 1.333vw;
  }
}

.top .quality_list li p {
  font-weight: 500;
}

@media only screen and (min-width: 769px) {
  .top .quality_list li p {
    font-size: 1.313em;
    line-height: 1.619em;
  }
}

@media only screen and (max-width: 768px) {
  .top .quality_list li p {
    font-size: 3.6vw;
    line-height: 5.867vw;
    letter-spacing: 0.2vw;
  }
}

.top .quality_list li p span {
  color: #0068b6;
}

.top .quality_list li p:before {
  content: "";
  background: url("../img/top/quality_check.png") no-repeat 50% 50%;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  position: absolute;
}

@media only screen and (min-width: 769px) {
  .top .quality_list li p:before {
    width: 2.381em;
    height: 2.381em;
    top: -0.476em;
    left: -1.19em;
  }
}

@media only screen and (max-width: 768px) {
  .top .quality_list li p:before {
    top: -1.333vw;
    left: -4vw;
    width: 8vw;
    height: 8vw;
  }
}

.top .quality_cost {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  margin: auto;
  position: relative;
}

@media only screen and (min-width: 769px) {
  .top .quality_cost {
    margin-top: 4.5em;
  }
}

.top .quality_cost_title {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  position: absolute;
  top: 0;
  width: 100%;
}

.top .quality_cost_title p:first-child {
  color: #333333;
  font-weight: 500;
  position: absolute;
}

@media only screen and (min-width: 769px) {
  .top .quality_cost_title p:first-child {
    font-size: 2.375em;
    letter-spacing: 0.05em;
  }
}

@media only screen and (max-width: 768px) {
  .top .quality_cost_title p:first-child {
    text-align: center;
    font-size: 5.6vw;
    line-height: 8vw;
    letter-spacing: 0.4vw;
    top: 4vw;
  }
}

.top .quality_cost_title p:last-child {
  color: #ffffff;
  font-weight: 500;
  position: absolute;
}

@media only screen and (min-width: 769px) {
  .top .quality_cost_title p:last-child {
    font-size: 2.938em;
    top: 1.702em;
  }
}

@media only screen and (max-width: 768px) {
  .top .quality_cost_title p:last-child {
    font-size: 6.267vw;
    letter-spacing: 0.4vw;
    top: 30.667vw;
  }
}

.top .quality_cost_content {
  color: #333333;
  text-align: center;
  font-weight: 500;
  position: absolute;
}

@media only screen and (min-width: 769px) {
  .top .quality_cost_content {
    top: 15.625em;
  }
}

@media only screen and (max-width: 768px) {
  .top .quality_cost_content {
    top: 50.667vw;
  }
}

@media only screen and (min-width: 769px) {
  .top .quality_cost_content p {
    font-size: 1.375em;
    line-height: 1.864em;
    letter-spacing: 0.2em;
  }
}

@media only screen and (max-width: 768px) {
  .top .quality_cost_content p {
    font-size: 3.6vw;
    line-height: 7.2vw;
    letter-spacing: 0.4vw;
  }
}

.top .quality_cost_content span {
  color: #0068b6;
}

.top .cv {
  background-color: #cb141d;
}

@media only screen and (min-width: 769px) {
  .top .cv {
    padding: 2.5em 0;
  }
}

@media only screen and (max-width: 768px) {
  .top .cv {
    padding: 13.333vw 0;
  }
}

.top .cv .inner_ctx {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

@media only screen and (min-width: 769px) {
  .top .cv .inner_ctx {
    gap: 2.188em;
  }
}

@media only screen and (max-width: 768px) {
  .top .cv .inner_ctx {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 5.067vw;
  }
}

@media only screen and (min-width: 769px) {
  .top .cv_number img {
    width: 20.625em;
  }
}

@media only screen and (max-width: 768px) {
  .top .cv_number img {
    width: 66.667vw;
  }
}

.top .cv_btn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

@media only screen and (min-width: 769px) {
  .top .cv_btn {
    gap: 1.25em;
  }
}

@media only screen and (max-width: 768px) {
  .top .cv_btn {
    -ms-flex-item-align: end;
        align-self: flex-end;
    gap: 4vw;
  }
}

@media only screen and (min-width: 769px) {
  .top .cv_btn a {
    width: 39.75em;
  }
}

@media only screen and (max-width: 768px) {
  .top .cv_btn a {
    width: 86.533vw;
  }
}

@media only screen and (min-width: 769px) {
  .top .features {
    background: url("../img/top/features_bg.jpg") no-repeat 50% 0%;
    background-size: 125em auto;
    height: 153.125em;
    padding-top: 3.75em;
  }
}

@media only screen and (max-width: 768px) {
  .top .features {
    background: url("../img/top/features_bg_sp.jpg") no-repeat 50% 0;
    background-size: 100vw auto;
    height: 740vw;
    padding-top: 14.667vw;
  }
}

@media only screen and (min-width: 769px) {
  .top .features .inner_ctx {
    padding: 0 6.25em;
  }
}

.top .features_title {
  text-align: center;
}

@media only screen and (min-width: 769px) {
  .top .features_title img {
    width: 34em;
  }
}

@media only screen and (max-width: 768px) {
  .top .features_title img {
    width: 84.533vw;
  }
}

@media only screen and (min-width: 769px) {
  .top .features_content {
    margin-top: 9.5em;
  }
}

@media only screen and (max-width: 768px) {
  .top .features_content {
    padding-left: 3.333vw;
    margin-top: 28.667vw;
  }
}

.top .features_content_item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}

@media only screen and (min-width: 769px) {
  .top .features_content_item:nth-child(even) {
    margin-left: 32.5em;
  }
}

@media only screen and (max-width: 768px) {
  .top .features_content_item:nth-child(even) {
    margin-left: 4vw;
  }
}

@media only screen and (min-width: 769px) {
  .top .features_content_item:first-child {
    margin-bottom: 10em;
  }
}

@media only screen and (max-width: 768px) {
  .top .features_content_item:first-child {
    margin-bottom: 92vw;
  }
}

@media only screen and (min-width: 769px) {
  .top .features_content_item:nth-child(2) {
    margin-bottom: 13.75em;
  }
}

@media only screen and (max-width: 768px) {
  .top .features_content_item:nth-child(2) {
    margin-bottom: 96vw;
  }
}

@media only screen and (min-width: 769px) {
  .top .features_content_item:nth-child(3) {
    margin-bottom: 12.25em;
  }
}

@media only screen and (max-width: 768px) {
  .top .features_content_item:nth-child(3) {
    margin-bottom: 93.333vw;
  }
}

.top .features_content_item_title p {
  color: #fff;
  display: inline-block;
  font-weight: 700;
}

@media only screen and (min-width: 769px) {
  .top .features_content_item_title p {
    font-size: 1.875em;
    line-height: 1.667em;
    letter-spacing: 0.033em;
  }
}

@media only screen and (max-width: 768px) {
  .top .features_content_item_title p {
    font-size: 4.8vw;
    line-height: 8vw;
    letter-spacing: 0.1vw;
  }
}

.top .features_content_item_title p .red {
  background-color: #cb141d;
}

@media only screen and (min-width: 769px) {
  .top .features_content_item_title p .red {
    padding: 0 0.1em;
  }
}

@media only screen and (max-width: 768px) {
  .top .features_content_item_title p .red {
    padding: 0 0.4vw;
  }
}

.top .features_content_item_title p .blue {
  background-color: #0068b6;
}

@media only screen and (min-width: 769px) {
  .top .features_content_item_title p .blue {
    padding: 0 0.1em;
  }
}

@media only screen and (max-width: 768px) {
  .top .features_content_item_title p .blue {
    padding: 0 0.4vw;
  }
}

@media only screen and (min-width: 769px) {
  .top .features_content_item_content {
    width: 30em;
    margin-top: 1.25em;
  }
}

@media only screen and (max-width: 768px) {
  .top .features_content_item_content {
    width: 77.333vw;
    margin-top: 4vw;
  }
}

.top .features_content_item_content p {
  color: #333333;
}

@media only screen and (min-width: 769px) {
  .top .features_content_item_content p {
    font-size: 1.125em;
    line-height: 1.778em;
    letter-spacing: 0.028em;
  }
}

@media only screen and (max-width: 768px) {
  .top .features_content_item_content p {
    font-size: 3.6vw;
    line-height: 7.2vw;
    letter-spacing: 0.2vw;
  }
}

.top .voice_contact {
  background-color: #cb141d;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

@media only screen and (min-width: 769px) {
  .top .voice_contact {
    padding: 2em 0;
    gap: 1em;
    border-radius: 1.25em;
  }
}

@media only screen and (max-width: 768px) {
  .top .voice_contact {
    margin: 0 auto;
    width: 93.333vw;
    padding: 10.667vw 0 12vw;
    gap: 8vw;
    border-radius: 2.667vw;
  }
}

.top .voice_contact_title {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

@media only screen and (min-width: 769px) {
  .top .voice_contact_title {
    gap: 1.125em;
  }
}

@media only screen and (max-width: 768px) {
  .top .voice_contact_title {
    gap: 1.867vw;
  }
}

.top .voice_contact_title p {
  color: #ffffff;
}

@media only screen and (min-width: 769px) {
  .top .voice_contact_title p {
    font-size: 1.563em;
    letter-spacing: 0.1em;
  }
}

@media only screen and (max-width: 768px) {
  .top .voice_contact_title p {
    text-align: center;
    font-size: 4.8vw;
    line-height: 7.467vw;
  }
}

.top .voice_contact_title::before, .top .voice_contact_title::after {
  content: "";
  display: block;
  background-size: 100% 100%;
  background-position: center;
  background-repeat: no-repeat;
}

@media only screen and (min-width: 769px) {
  .top .voice_contact_title::before, .top .voice_contact_title::after {
    background-image: url("../img/top/voice_el.png");
    width: 0.688em;
    height: 1.875em;
  }
}

@media only screen and (max-width: 768px) {
  .top .voice_contact_title::before, .top .voice_contact_title::after {
    background-image: url("../img/top/voice_el_sp.png");
    width: 4.133vw;
    height: 10.667vw;
  }
}

.top .voice_contact_title::after {
  -webkit-transform: scaleX(-1);
          transform: scaleX(-1);
}

.top .voice_contact_btn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}

@media only screen and (min-width: 769px) {
  .top .voice_contact_btn {
    gap: 1.25em;
  }
}

@media only screen and (max-width: 768px) {
  .top .voice_contact_btn {
    padding: 0 2.667vw 0 4vw;
    gap: 7.2vw;
  }
}

@media only screen and (min-width: 769px) {
  .top .voice_contact_btn a img {
    width: 39.688em;
  }
}

@media only screen and (max-width: 768px) {
  .top .voice_contact_btn a img {
    width: 86.533vw;
  }
}

@media only screen and (min-width: 769px) {
  .top .voice01 {
    background: url("../img/top/voice01_bg.jpg") no-repeat 50% 0%;
    background-size: 125em 48.125em;
    padding-bottom: 3.75em;
  }
}

@media only screen and (max-width: 768px) {
  .top .voice01 {
    background: url("../img/top/voice01_bg_sp.jpg") no-repeat 50% 0%;
    background-size: 100vw auto;
    height: 198.8vw;
  }
}

@media only screen and (min-width: 769px) {
  .top .voice01 .inner_ctx {
    padding: 23.75em 6.25em 0;
  }
}

@media only screen and (max-width: 768px) {
  .top .voice01 .inner_ctx {
    padding: 96vw 0 0;
  }
}

.top .voice01_title {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  color: #ffffff;
  position: absolute;
}

@media only screen and (min-width: 769px) {
  .top .voice01_title {
    gap: 5em;
    top: 4.5em;
    left: 10.188em;
  }
}

@media only screen and (max-width: 768px) {
  .top .voice01_title {
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    gap: 12.533vw;
    top: 20vw;
    left: 8.667vw;
  }
}

.top .voice01_title p:nth-child(1) {
  font-weight: 700;
}

@media only screen and (min-width: 769px) {
  .top .voice01_title p:nth-child(1) {
    font-size: 2.375em;
    line-height: 1.053em;
  }
}

@media only screen and (max-width: 768px) {
  .top .voice01_title p:nth-child(1) {
    font-size: 5.467vw;
    line-height: 5.867vw;
    letter-spacing: 0.4vw;
  }
}

.top .voice01_title p:nth-child(2) {
  font-weight: 600;
}

@media only screen and (min-width: 769px) {
  .top .voice01_title p:nth-child(2) {
    font-size: 2.375em;
    line-height: 2.263em;
    letter-spacing: 0.08em;
  }
}

@media only screen and (max-width: 768px) {
  .top .voice01_title p:nth-child(2) {
    font-size: 5.067vw;
    line-height: 8vw;
  }
}

.top .voice01_txt01, .top .voice01_txt02 {
  position: absolute;
}

.top .voice01_txt01 p, .top .voice01_txt02 p {
  color: #333333;
}

@media only screen and (min-width: 769px) {
  .top .voice01_txt01 p, .top .voice01_txt02 p {
    font-size: 1.313em;
  }
}

@media only screen and (max-width: 768px) {
  .top .voice01_txt01 p, .top .voice01_txt02 p {
    font-size: 3.733vw;
    letter-spacing: 0.1vw;
  }
}

.top .voice01_txt01 p b, .top .voice01_txt02 p b {
  color: #0068b6;
}

@media only screen and (min-width: 769px) {
  .top .voice01_txt01 {
    top: 15.125em;
    left: 12.5em;
  }
}

@media only screen and (max-width: 768px) {
  .top .voice01_txt01 {
    top: 50.933vw;
    left: 20.933vw;
  }
}

@media only screen and (min-width: 769px) {
  .top .voice01_txt02 {
    top: 13.25em;
    left: 41.75em;
  }
}

@media only screen and (max-width: 768px) {
  .top .voice01_txt02 {
    top: 69.6vw;
    left: 21.333vw;
  }
}

.top .voice01_txt03 {
  position: absolute;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  color: #ffffff;
}

@media only screen and (min-width: 769px) {
  .top .voice01_txt03 {
    top: 19.125em;
  }
}

@media only screen and (max-width: 768px) {
  .top .voice01_txt03 {
    top: 84.533vw;
  }
}

@media only screen and (min-width: 769px) {
  .top .voice01_txt03 p {
    font-size: 1.25em;
    letter-spacing: 0.1em;
  }
}

@media only screen and (max-width: 768px) {
  .top .voice01_txt03 p {
    text-align: center;
    width: 100vw;
    font-size: 4vw;
    letter-spacing: 0.1vw;
  }
}

@media only screen and (min-width: 769px) {
  .top .voice02 {
    background: url("../img/top/voice02_bg.jpg") no-repeat 50% 0%;
    background-size: 125em 45em;
    padding-bottom: 3.75em;
  }
}

@media only screen and (max-width: 768px) {
  .top .voice02 {
    background: url("../img/top/voice02_bg_sp.jpg") no-repeat 50% 0%;
    background-size: 100vw auto;
    height: 178.4vw;
  }
}

@media only screen and (min-width: 769px) {
  .top .voice02 .inner_ctx {
    padding: 23.75em 6.25em 0;
  }
}

@media only screen and (max-width: 768px) {
  .top .voice02 .inner_ctx {
    padding: 74.667vw 0 0;
  }
}

.top .voice02_title {
  color: #ffffff;
  position: absolute;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  text-align: center;
  width: 100%;
}

@media only screen and (min-width: 769px) {
  .top .voice02_title {
    top: 4.75em;
  }
}

@media only screen and (max-width: 768px) {
  .top .voice02_title {
    top: 16.4vw;
  }
}

.top .voice02_title p:nth-child(1) {
  font-weight: 700;
}

@media only screen and (min-width: 769px) {
  .top .voice02_title p:nth-child(1) {
    font-size: 2.375em;
    line-height: 1.395em;
    letter-spacing: 0.05em;
  }
}

@media only screen and (max-width: 768px) {
  .top .voice02_title p:nth-child(1) {
    font-size: 5.067vw;
    line-height: 7.067vw;
    letter-spacing: 0.1em;
  }
}

@media only screen and (min-width: 769px) {
  .top .voice02_title p:nth-child(2) {
    font-size: 1.25em;
    margin-top: 2.75em;
    letter-spacing: 0.1em;
  }
}

@media only screen and (max-width: 768px) {
  .top .voice02_title p:nth-child(2) {
    margin-top: 9.333vw;
    font-size: 4vw;
    line-height: 6.667vw;
    letter-spacing: 0.3vw;
  }
}

@media only screen and (min-width: 769px) {
  .top .voice02_contact_btn {
    gap: 1.25em;
  }
}

@media only screen and (max-width: 768px) {
  .top .voice02_contact_btn {
    gap: 3.333vw;
  }
}

.top .voice02_txt {
  text-align: center;
  color: #ffffff;
}

@media only screen and (min-width: 769px) {
  .top .voice02_txt {
    position: relative;
    top: -0.625em;
    font-size: 0.938em;
    letter-spacing: 0.2em;
  }
}

@media only screen and (max-width: 768px) {
  .top .voice02_txt {
    font-size: 2.933vw;
    letter-spacing: 0.3vw;
  }
}

@media only screen and (min-width: 769px) {
  .top .voice03 {
    background: url("../img/top/voice03_bg.jpg") no-repeat 50% 0%;
    background-size: 125em 40em;
    padding-bottom: 3.75em;
  }
}

@media only screen and (max-width: 768px) {
  .top .voice03 {
    background: url("../img/top/voice03_bg_sp.jpg") no-repeat 50% 0%;
    background-size: 100vw auto;
    height: 204.933vw;
  }
}

@media only screen and (min-width: 769px) {
  .top .voice03 .inner_ctx {
    padding: 18.75em 6.25em 0;
  }
}

@media only screen and (max-width: 768px) {
  .top .voice03 .inner_ctx {
    padding: 130.667vw 0 0;
  }
}

.top .voice03_title {
  color: #ffffff;
  position: absolute;
  width: 100%;
}

@media only screen and (min-width: 769px) {
  .top .voice03_title {
    top: 5.25em;
    left: 27.5em;
  }
}

@media only screen and (max-width: 768px) {
  .top .voice03_title {
    text-align: center;
    left: 50%;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
    top: 70.667vw;
  }
}

.top .voice03_title p:nth-child(1) {
  font-weight: 700;
}

@media only screen and (min-width: 769px) {
  .top .voice03_title p:nth-child(1) {
    font-size: 1.938em;
    letter-spacing: 0.05em;
  }
}

@media only screen and (max-width: 768px) {
  .top .voice03_title p:nth-child(1) {
    font-size: 5.333vw;
    line-height: 8vw;
    letter-spacing: 0.3 vw;
  }
}

@media only screen and (min-width: 769px) {
  .top .voice03_title p:nth-child(2) {
    font-size: 1.125em;
    line-height: 1.778em;
    margin-top: 2.667em;
    letter-spacing: 0.1em;
  }
}

@media only screen and (max-width: 768px) {
  .top .voice03_title p:nth-child(2) {
    font-size: 3.467vw;
    line-height: 6.4vw;
    margin-top: 8vw;
    letter-spacing: 0.1vw;
  }
}

.top .voice03_cost {
  position: absolute;
}

@media only screen and (min-width: 769px) {
  .top .voice03_cost {
    top: 1.875em;
    left: 6.25em;
  }
}

@media only screen and (max-width: 768px) {
  .top .voice03_cost {
    left: 50%;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
    top: 13.333vw;
  }
}

@media only screen and (min-width: 769px) {
  .top .voice03_cost img {
    width: 17.5em;
  }
}

@media only screen and (max-width: 768px) {
  .top .voice03_cost img {
    width: 53.333vw;
  }
}

@media only screen and (max-width: 768px) {
  .top .voice03_contact {
    padding: 9.333vw 0 10.133vw;
  }
}

.top .faq {
  background-color: #0068b6;
}

@media only screen and (min-width: 769px) {
  .top .faq {
    padding: 3.625em 0 3.125em;
  }
}

@media only screen and (max-width: 768px) {
  .top .faq {
    padding: 13.333vw 0;
  }
}

.top .faq.faq_01 {
  background-color: #0068b6;
}

.top .faq.faq_02 {
  background-color: #f2f2f2;
}

@media only screen and (min-width: 769px) {
  .top .faq .inner_ctx {
    padding: 0 6.25em;
  }
}

.top .faq_title {
  text-align: center;
}

@media only screen and (min-width: 769px) {
  .top .faq_title {
    margin-bottom: 3.75em;
  }
}

@media only screen and (max-width: 768px) {
  .top .faq_title {
    margin-bottom: 10.667vw;
  }
}

.top .faq_title.faq_title_01 p {
  color: #ffffff;
}

.top .faq_title.faq_title_02 p {
  color: #333333;
}

@media only screen and (min-width: 769px) {
  .top .faq_title img {
    width: 2.5em;
    margin-bottom: 1.875em;
  }
}

@media only screen and (max-width: 768px) {
  .top .faq_title img {
    width: 13.333vw;
    margin-bottom: 2.667vw;
  }
}

.top .faq_title p {
  font-weight: 700;
}

@media only screen and (min-width: 769px) {
  .top .faq_title p {
    font-size: 2.5em;
    letter-spacing: 0.1em;
  }
}

@media only screen and (max-width: 768px) {
  .top .faq_title p {
    font-size: 6.667vw;
    line-height: 10.667vw;
    letter-spacing: 0.05em;
  }
}

.top .faq_list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  margin: 0 auto;
}

@media only screen and (min-width: 769px) {
  .top .faq_list {
    width: 62.5em;
    gap: 0.625em;
  }
}

@media only screen and (max-width: 768px) {
  .top .faq_list {
    width: 90.667vw;
    gap: 6.667vw;
  }
}

.top .faq_item {
  background-color: #fff;
  overflow: hidden;
  opacity: 1;
  -webkit-transform: translateY(0);
          transform: translateY(0);
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}

@media only screen and (min-width: 769px) {
  .top .faq_item {
    width: 62.5em;
    border-radius: 0.875em;
  }
}

@media only screen and (max-width: 768px) {
  .top .faq_item {
    border-radius: 1.333vw;
  }
}

.top .faq_question {
  position: relative;
  cursor: pointer;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}

@media only screen and (min-width: 769px) {
  .top .faq_question {
    padding: 1.25em 3.125em;
    gap: 1.75em;
  }
}

@media only screen and (max-width: 768px) {
  .top .faq_question {
    padding: 6.667vw 4vw;
    gap: 5.067vw;
  }
}

.top .faq_question > img,
.top .faq_question .faq_q_icon img {
  -ms-flex-negative: 0;
      flex-shrink: 0;
}

@media only screen and (min-width: 769px) {
  .top .faq_question > img,
  .top .faq_question .faq_q_icon img {
    width: 3.125em;
    height: 3.125em;
  }
}

@media only screen and (max-width: 768px) {
  .top .faq_question > img,
  .top .faq_question .faq_q_icon img {
    width: 9.333vw;
    height: 9.333vw;
  }
}

.top .faq_question .faq_q_icon {
  -ms-flex-negative: 0;
      flex-shrink: 0;
}

.top .faq_question::after {
  content: "";
  position: absolute;
  background-color: #333333;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}

@media only screen and (min-width: 769px) {
  .top .faq_question::after {
    right: 1.75em;
    top: 50%;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    width: 1.875em;
    height: 0.125em;
  }
}

@media only screen and (max-width: 768px) {
  .top .faq_question::after {
    right: 6vw;
    top: 50%;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    width: 6.667vw;
    height: 0.4vw;
  }
}

.top .faq_question::before {
  content: "";
  position: absolute;
  background-color: #333333;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}

@media only screen and (min-width: 769px) {
  .top .faq_question::before {
    right: 2.6em;
    top: calc(50% - round-decimal((30 / $font_size_pc * 1em), 3));
    width: 0.125em;
    height: 1.875em;
    z-index: 2;
  }
}

@media only screen and (max-width: 768px) {
  .top .faq_question::before {
    right: 9.333vw;
    top: calc(50% - round-decimal((30 / $sp_width * 100vw), 3));
    width: 0.4vw;
    height: 6.667vw;
    z-index: 2;
  }
}

.top .faq_question.active::before {
  opacity: 0;
  -webkit-transform: rotate(90deg);
          transform: rotate(90deg);
}

.top .faq_question p {
  color: #333;
  font-weight: 500;
  line-height: 1.6;
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  margin: 0;
}

@media only screen and (min-width: 769px) {
  .top .faq_question p {
    font-size: 1.375em;
  }
}

@media only screen and (max-width: 768px) {
  .top .faq_question p {
    font-size: 4.267vw;
    line-height: 6.133vw;
  }
}

.top .faq_answer {
  background-color: #fff;
  display: none;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
}

@media only screen and (min-width: 769px) {
  .top .faq_answer {
    padding: 0 3.125em 1.25em;
    gap: 1.75em;
  }
}

@media only screen and (max-width: 768px) {
  .top .faq_answer {
    padding: 0 4vw 6.667vw 4vw;
    gap: 5.067vw;
  }
}

.top .faq_answer img {
  -ms-flex-negative: 0;
      flex-shrink: 0;
}

@media only screen and (min-width: 769px) {
  .top .faq_answer img {
    width: 3.125em;
    height: 3.125em;
  }
}

@media only screen and (max-width: 768px) {
  .top .faq_answer img {
    width: 9.333vw;
    height: 9.333vw;
  }
}

.top .faq_answer p {
  color: #333333;
  margin: 0;
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  font-weight: 500;
}

@media only screen and (min-width: 769px) {
  .top .faq_answer p {
    font-size: 1em;
    line-height: 1.875em;
  }
}

@media only screen and (max-width: 768px) {
  .top .faq_answer p {
    font-size: 3.467vw;
    line-height: 6.4vw;
    letter-spacing: 0.05em;
  }
}

.top .flow {
  background-color: #cce1f0;
}

@media only screen and (min-width: 769px) {
  .top .flow {
    padding: 3.75em 0;
  }
}

@media only screen and (max-width: 768px) {
  .top .flow {
    padding: 10vw 0 15.2vw;
  }
}

@media only screen and (min-width: 769px) {
  .top .flow .inner_ctx {
    padding: 0 6.25em;
  }
}

.top .flow_title {
  text-align: center;
}

@media only screen and (min-width: 769px) {
  .top .flow_title {
    margin-bottom: 3.625em;
  }
}

@media only screen and (max-width: 768px) {
  .top .flow_title {
    margin-bottom: 10.667vw;
  }
}

@media only screen and (min-width: 769px) {
  .top .flow_title img {
    width: 2.5em;
    margin-bottom: 1.875em;
  }
}

@media only screen and (max-width: 768px) {
  .top .flow_title img {
    width: 13.333vw;
    margin-bottom: 2.667vw;
  }
}

.top .flow_title p {
  font-weight: 700;
  color: #333333;
}

@media only screen and (min-width: 769px) {
  .top .flow_title p {
    font-size: 2.5em;
    letter-spacing: 0.1em;
  }
}

@media only screen and (max-width: 768px) {
  .top .flow_title p {
    font-size: 6.667vw;
    line-height: 10.667vw;
    letter-spacing: 0.05em;
  }
}

.top .flow_list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  position: relative;
}

@media only screen and (min-width: 769px) {
  .top .flow_list {
    gap: 2.5em 2.313em;
    max-width: 60.938em;
  }
}

@media only screen and (max-width: 768px) {
  .top .flow_list {
    gap: 7.333vw;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
}

.top .flow_item {
  position: relative;
  background: #ffffff;
  -webkit-box-shadow: 0 3px 15px rgba(0, 0, 0, 0.1);
          box-shadow: 0 3px 15px rgba(0, 0, 0, 0.1);
}

@media only screen and (min-width: 769px) {
  .top .flow_item {
    width: 18.75em;
    min-height: 16.875em;
    padding: 7.188em 1.563em 1.25em;
  }
}

@media only screen and (max-width: 768px) {
  .top .flow_item {
    width: 90.667vw;
    padding: 4vw 3.333vw 5.333vw;
  }
}

.top .flow_item::before {
  content: "";
  position: absolute;
  background-size: contain;
  z-index: 1;
}

@media only screen and (min-width: 769px) {
  .top .flow_item::before {
    top: -0.375em;
    left: -0.063em;
    width: 20.375em;
    height: 5.688em;
  }
}

@media only screen and (max-width: 768px) {
  .top .flow_item::before {
    top: -0.8vw;
    left: -0.133vw;
    width: 32vw;
    height: 12.133vw;
  }
}

@media only screen and (min-width: 769px) {
  .top .flow_item:nth-child(1)::before {
    background: url("../img/top/flow_step01.png") no-repeat center center;
    background-size: contain;
  }
}

@media only screen and (max-width: 768px) {
  .top .flow_item:nth-child(1)::before {
    background: url("../img/top/flow_step01_sp.png") no-repeat center center;
    background-size: contain;
  }
}

@media only screen and (min-width: 769px) {
  .top .flow_item:nth-child(2)::before {
    background: url("../img/top/flow_step02.png") no-repeat center center;
    background-size: contain;
  }
}

@media only screen and (max-width: 768px) {
  .top .flow_item:nth-child(2)::before {
    background: url("../img/top/flow_step02_sp.png") no-repeat center center;
    background-size: contain;
  }
}

@media only screen and (min-width: 769px) {
  .top .flow_item:nth-child(3)::before {
    background: url("../img/top/flow_step03.png") no-repeat center center;
    background-size: contain;
  }
}

@media only screen and (max-width: 768px) {
  .top .flow_item:nth-child(3)::before {
    background: url("../img/top/flow_step03_sp.png") no-repeat center center;
    background-size: contain;
  }
}

@media only screen and (min-width: 769px) {
  .top .flow_item:nth-child(4)::before {
    background: url("../img/top/flow_step04.png") no-repeat center center;
    background-size: contain;
  }
}

@media only screen and (max-width: 768px) {
  .top .flow_item:nth-child(4)::before {
    background: url("../img/top/flow_step04_sp.png") no-repeat center center;
    background-size: contain;
  }
}

@media only screen and (min-width: 769px) {
  .top .flow_item:nth-child(5)::before {
    background: url("../img/top/flow_step05.png") no-repeat center center;
    background-size: contain;
  }
}

@media only screen and (max-width: 768px) {
  .top .flow_item:nth-child(5)::before {
    background: url("../img/top/flow_step05_sp.png") no-repeat center center;
    background-size: contain;
  }
}

@media only screen and (min-width: 769px) {
  .top .flow_item:nth-child(6)::before {
    background: url("../img/top/flow_step06.png") no-repeat center center;
    width: 15.063em;
    background-size: contain;
  }
}

@media only screen and (max-width: 768px) {
  .top .flow_item:nth-child(6)::before {
    background: url("../img/top/flow_step06_sp.png") no-repeat center center;
    background-size: contain;
  }
}

@media only screen and (max-width: 768px) {
  .top .flow_item::after {
    content: "";
    position: absolute;
    background-size: contain;
    z-index: 1;
    background-image: url("../img/top/flow_arrow.png");
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center center;
    width: 1.6vw;
    height: 6.933vw;
    bottom: -7vw;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
  }
}

@media only screen and (max-width: 768px) {
  .top .flow_item:last-child::after {
    display: none;
  }
}

@media only screen and (min-width: 769px) {
  .top .flow_item_title {
    margin-bottom: 0.875em;
  }
}

@media only screen and (max-width: 768px) {
  .top .flow_item_title {
    margin-bottom: 6.933vw;
  }
}

.top .flow_item_title p {
  font-weight: 500;
  color: #0068b6;
}

@media only screen and (min-width: 769px) {
  .top .flow_item_title p {
    font-size: 1.438em;
  }
}

@media only screen and (max-width: 768px) {
  .top .flow_item_title p {
    font-size: 4.267vw;
    padding-left: 30.667vw;
  }
}

.top .flow_item_content p {
  color: #333333;
}

@media only screen and (min-width: 769px) {
  .top .flow_item_content p {
    font-size: 1em;
    line-height: 1.688em;
    letter-spacing: 0.05em;
  }
}

@media only screen and (max-width: 768px) {
  .top .flow_item_content p {
    font-size: 3.2vw;
    line-height: 5.333vw;
  }
}

.top .flow_item_content span {
  color: #666666;
  display: block;
}

@media only screen and (min-width: 769px) {
  .top .flow_item_content span {
    font-size: 0.75em;
    line-height: 1.417em;
    margin-top: 0.333em;
  }
}

@media only screen and (max-width: 768px) {
  .top .flow_item_content span {
    font-size: 2.667vw;
    line-height: 4.533vw;
    margin-top: 1.333vw;
  }
}

@media only screen and (max-width: 768px) {
  .fixed_btn {
    -webkit-box-shadow: rgba(27, 27, 27, 0.8) 0px 2px 8px 0px;
            box-shadow: rgba(27, 27, 27, 0.8) 0px 2px 8px 0px;
    position: fixed;
    bottom: 0;
    left: 0;
    width: 100%;
    z-index: 1000;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
}

.fixed_btn a {
  display: block;
  width: 100%;
  width: 66.667vw;
}

#single_page {
  font-family: "M PLUS 1", sans-serif !important;
  font-weight: 400;
  font-style: normal;
  margin-top: unset;
}

@media only screen and (min-width: 769px) {
  #single_page {
    margin: 3.75em 0 10em;
  }
}

@media only screen and (max-width: 768px) {
  #single_page {
    margin: 9.333vw 0 18.667vw;
  }
}

#single_page .single_title_wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

@media only screen and (min-width: 769px) {
  #single_page .single_title_wrap {
    margin-bottom: 3.125em;
  }
}

@media only screen and (max-width: 768px) {
  #single_page .single_title_wrap {
    margin-bottom: 6.667vw;
  }
}

#single_page .single_title_txt {
  position: relative;
}

@media only screen and (min-width: 769px) {
  #single_page .single_title_txt {
    width: 55em;
    margin-bottom: 3.125em;
  }
}

@media only screen and (max-width: 768px) {
  #single_page .single_title_txt {
    width: 85.333vw;
    margin-bottom: 8vw;
  }
}

#single_page .single_title_txt:before, #single_page .single_title_txt:after {
  content: "";
  position: absolute;
  background-repeat: no-repeat;
  background-position: center;
}

@media only screen and (min-width: 769px) {
  #single_page .single_title_txt:before, #single_page .single_title_txt:after {
    background-image: url(../img/single/title_el.png);
    background-size: 55.375em 1.438em;
    width: 55.375em;
    height: 1.438em;
  }
}

@media only screen and (max-width: 768px) {
  #single_page .single_title_txt:before, #single_page .single_title_txt:after {
    background-image: url(../img/single/title_el_sp.png);
    background-size: 86.133vw 3.867vw;
    width: 86.133vw;
    height: 3.867vw;
  }
}

#single_page .single_title_txt:before {
  top: 0;
}

@media only screen and (min-width: 769px) {
  #single_page .single_title_txt:before {
    left: -0.188em;
  }
}

@media only screen and (max-width: 768px) {
  #single_page .single_title_txt:before {
    left: -0.4vw;
  }
}

#single_page .single_title_txt:after {
  bottom: 0;
  -webkit-transform: scaleX(-1) scaleY(-1);
          transform: scaleX(-1) scaleY(-1);
}

@media only screen and (min-width: 769px) {
  #single_page .single_title_txt:after {
    right: -0.188em;
  }
}

@media only screen and (max-width: 768px) {
  #single_page .single_title_txt:after {
    right: -0.4vw;
  }
}

#single_page .single_title_txt h1 {
  background-color: #e5f0f8;
  color: #333333;
  text-align: left;
}

@media only screen and (min-width: 769px) {
  #single_page .single_title_txt h1 {
    font-size: 1.875em;
    line-height: 1.6em;
    padding: 1.167em 4em;
  }
}

@media only screen and (max-width: 768px) {
  #single_page .single_title_txt h1 {
    font-size: 5.067vw;
    line-height: 1.867;
    padding: 8vw 9.333vw;
  }
}

#single_page .single_title_img {
  margin: auto;
}

@media only screen and (min-width: 769px) {
  #single_page .single_title_img {
    max-width: 40em;
  }
}

@media only screen and (max-width: 768px) {
  #single_page .single_title_img {
    max-width: 85.333vw;
  }
}

#single_page .single_title_img img {
  width: 100%;
  height: auto;
}

#single_page ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin: auto;
}

@media only screen and (min-width: 769px) {
  #single_page ul {
    max-width: 50em;
    margin-bottom: 1.875em;
  }
}

@media only screen and (max-width: 768px) {
  #single_page ul {
    margin-bottom: 4vw;
  }
}

#single_page ul li {
  position: relative;
  font-weight: 600;
}

@media only screen and (min-width: 769px) {
  #single_page ul li {
    font-size: 1.125em;
    padding-left: 0.556em;
    line-height: 2.278em;
  }
}

@media only screen and (max-width: 768px) {
  #single_page ul li {
    font-size: 3.733vw;
    line-height: 8vw;
  }
}

#single_page ul li::before {
  content: "●";
  color: #062b54;
  position: relative;
}

@media only screen and (min-width: 769px) {
  #single_page ul li::before {
    font-size: 0.875em;
  }
}

@media only screen and (max-width: 768px) {
  #single_page ul li::before {
    font-size: 2.4vw;
    margin-right: 1.333vw;
    top: -0.5vw;
  }
}

#single_page .aligncenter {
  margin: 1rem auto !important;
}

#single_page .aligncenter {
  clear: both;
}

#single_page .single_content {
  color: #333333;
}

#single_page .single_content .inner_ctx {
  margin-left: auto;
  margin-right: auto;
}

@media only screen and (min-width: 769px) {
  #single_page .single_content .inner_ctx {
    max-width: 55em;
  }
}

@media only screen and (max-width: 768px) {
  #single_page .single_content .inner_ctx {
    padding: unset;
    max-width: 85.333vw;
  }
}

#single_page .single_content a {
  color: #0068b6;
  text-decoration: underline;
}

#single_page .single_content img {
  display: block;
  height: auto;
  margin: 1rem 0;
  max-width: 100%;
  width: unset !important;
  border: none;
  height: auto;
}

#single_page .single_content strong {
  font-weight: 700;
}

#single_page .single_content h2 {
  background-color: #e5f0f8;
  color: #0068b6;
  position: relative;
  display: block;
}

@media only screen and (min-width: 769px) {
  #single_page .single_content h2 {
    font-size: 2.25em;
    width: 24.444em;
    line-height: 1.389em;
    padding: 0.556em 1.111em;
    margin: 2.778em 0 1.389em;
    border-left: 0.417em solid #0068b6;
  }
}

@media only screen and (max-width: 768px) {
  #single_page .single_content h2 {
    font-size: 5.067vw;
    width: 85.333vw;
    line-height: 1.389;
    padding: 4vw;
    margin: 13.333vw 0 6.667vw;
    border-left: 2vw solid #0068b6;
  }
}

#single_page .single_content h3 {
  color: #333333;
  margin: auto;
}

@media only screen and (min-width: 769px) {
  #single_page .single_content h3 {
    font-size: 1.75em;
    width: 28.571em;
    line-height: 1.786em;
    margin: 1.429em auto 1.071em;
    border-bottom: 0.107em solid #0068b6;
  }
}

@media only screen and (max-width: 768px) {
  #single_page .single_content h3 {
    font-size: 4.267vw;
    width: 85.333vw;
    padding: 0 2.667vw;
    line-height: 1.786;
    margin: 5.333vw auto 4vw;
    border-bottom: 0.4vw solid #0068b6;
  }
}

#single_page .single_content h3 * {
  color: #333333 !important;
}

#single_page .single_content h4 {
  margin: auto;
}

@media only screen and (min-width: 769px) {
  #single_page .single_content h4 {
    font-size: 1.75em;
    width: 28.571em;
    line-height: 1.786em;
    margin: 1.071em auto 0;
  }
}

@media only screen and (max-width: 768px) {
  #single_page .single_content h4 {
    padding: 0 4vw;
    font-size: 3.733vw;
    width: 85.333vw;
    line-height: 1.786;
    margin: 4vw auto 0;
  }
}

#single_page .single_content h4 span {
  color: #333333 !important;
}

@media only screen and (min-width: 769px) {
  #single_page .single_content table {
    padding: 0.625em;
  }
}

@media only screen and (max-width: 768px) {
  #single_page .single_content table {
    padding: 1.333vw;
  }
}

#single_page .single_content table h4 {
  font-size: unset;
  width: unset;
  margin: unset;
}

@media only screen and (min-width: 769px) {
  #single_page .single_content p {
    font-size: 1.125em;
    line-height: 1.778em;
    margin: 0.833em auto;
    padding: 0 2.222em;
  }
}

@media only screen and (max-width: 768px) {
  #single_page .single_content p {
    font-size: 4.2vw;
    line-height: 6.4vw;
    margin: 2vw auto;
  }
}

#single_page .single_content table {
  border-collapse: collapse;
  margin-left: auto;
  margin-right: auto;
}

@media only screen and (min-width: 769px) {
  #single_page .single_content table {
    max-width: 50em;
  }
}

@media only screen and (max-width: 768px) {
  #single_page .single_content table {
    max-width: 85.333vw;
  }
}

#single_page .single_content table li {
  font-size: 100% !important;
}

#single_page .single_content table th,
#single_page .single_content table td {
  border: 1px solid #ddd;
  text-align: left;
}

@media only screen and (min-width: 769px) {
  #single_page .single_content table th,
  #single_page .single_content table td {
    padding: 0.75rem;
  }
}

@media only screen and (max-width: 768px) {
  #single_page .single_content table th,
  #single_page .single_content table td {
    padding: 2.5vw 2vw;
  }
}

#single_page .single_content table th {
  background-color: #f4f4f4;
  font-weight: bold;
}

@media only screen and (max-width: 768px) {
  #single_float {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    width: 100%;
    z-index: 999;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-pack: distribute;
        justify-content: space-around;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    margin: 0;
    padding: 0;
    padding: 4vw 3.333vw;
    gap: 2.667vw;
    background-color: #0000008f;
  }
  #single_float .single_float_close {
    position: absolute;
    background-image: url(../img/single/single_close_sp.png);
    background-repeat: no-repeat;
    background-size: contain;
    background-position: center;
    cursor: pointer;
    z-index: 1000;
    width: 8vw;
    height: 8vw;
    top: -5.333vw;
    right: 3.333vw;
  }
  #single_float li {
    text-align: center;
    list-style: none;
    -webkit-box-shadow: 0 -2px 10px rgba(0, 0, 0, 0.1);
            box-shadow: 0 -2px 10px rgba(0, 0, 0, 0.1);
    width: 29.333vw;
    position: relative;
  }
  #single_float li::before {
    display: none;
  }
  #single_float li:first-child::after {
    content: "";
    position: absolute;
    background-image: url(../img/single/single_btnel_sp.png);
    background-repeat: no-repeat;
    background-size: contain;
    background-position: center;
    width: 12vw;
    height: 12vw;
    top: -1.333vw;
    right: -1.333vw;
  }
  #single_float li a {
    display: block;
  }
  #single_float li a img {
    width: 100%;
    height: auto;
    margin: 0 auto;
  }
}

#single_page #toc_container {
  font-family: "M PLUS 1", sans-serif !important;
  all: initial;
  display: block;
  background-color: #f2f2f2;
  border: none;
  border-radius: 0;
  position: relative;
  font-weight: bold;
}

#single_page #toc_container::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 0;
  height: 0;
  border-style: solid;
  border-color: #ffffff transparent transparent transparent;
}

@media only screen and (min-width: 769px) {
  #single_page #toc_container::before {
    border-width: 2.5em 2.5em 0 0;
  }
}

@media only screen and (max-width: 768px) {
  #single_page #toc_container::before {
    border-width: 8vw 8vw 0 0;
  }
}

#single_page #toc_container::after {
  content: "";
  position: absolute;
  bottom: 0;
  right: 0;
  width: 0;
  height: 0;
  border-style: solid;
  border-color: transparent transparent #ffffff transparent;
}

@media only screen and (min-width: 769px) {
  #single_page #toc_container::after {
    border-width: 0 0 2.5em 2.5em;
  }
}

@media only screen and (max-width: 768px) {
  #single_page #toc_container::after {
    border-width: 0 0 8vw 8vw;
  }
}

@media only screen and (min-width: 769px) {
  #single_page #toc_container {
    margin: 3.125em auto;
  }
}

@media only screen and (max-width: 768px) {
  #single_page #toc_container {
    padding: 12vw 5.333vw;
    margin: 6.667vw auto;
  }
}

#single_page #toc_container .toc_title {
  color: #333333;
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

@media only screen and (min-width: 769px) {
  #single_page #toc_container .toc_title {
    gap: 0.8em;
    font-size: 1em;
    padding: 3em 3em 1em 3em;
    margin: unset;
  }
}

@media only screen and (max-width: 768px) {
  #single_page #toc_container .toc_title {
    padding: 0;
    font-size: 3.467vw;
    gap: 2.4vw;
  }
}

#single_page #toc_container .toc_title .toc_toggle {
  display: none;
}

#single_page #toc_container .toc_title::before {
  all: unset;
  content: "";
  display: block;
  background-color: #0068b6;
}

@media only screen and (min-width: 769px) {
  #single_page #toc_container .toc_title::before {
    font-size: 1em;
    width: 1.3em;
    height: 0.3em;
  }
}

@media only screen and (max-width: 768px) {
  #single_page #toc_container .toc_title::before {
    font-size: 2.667vw;
    width: 4vw;
    height: 0.667vw;
  }
}

#single_page #toc_container .toc_list {
  all: unset;
  display: block;
  list-style: none;
  padding: 0;
  margin: 0;
  counter-reset: toc-counter;
}

@media only screen and (min-width: 769px) {
  #single_page #toc_container .toc_list {
    padding: 0em 3em 3em 3em;
    font-size: 1em;
  }
}

#single_page #toc_container .toc_list li {
  all: unset;
  display: list-item;
  position: relative;
  list-style: none;
  border-bottom: 1px solid #e0e0e0;
  counter-increment: toc-counter;
  text-wrap: wrap;
}

@media only screen and (min-width: 769px) {
  #single_page #toc_container .toc_list li {
    font-size: 1em;
    padding: 1.1em 0 1.1em 2.5em;
  }
}

@media only screen and (max-width: 768px) {
  #single_page #toc_container .toc_list li {
    font-size: 4vw;
    line-height: 5.333vw;
    padding: 3vw 0 3vw 5vw;
  }
}

#single_page #toc_container .toc_list li::before {
  all: unset;
  content: counter(toc-counter) ".";
  position: absolute;
  color: #333333;
  left: 2%;
}

@media only screen and (min-width: 769px) {
  #single_page #toc_container .toc_list li::before {
    top: 1.35em;
  }
}

@media only screen and (max-width: 768px) {
  #single_page #toc_container .toc_list li::before {
    font-size: 3.467vw;
  }
}

#single_page #toc_container .toc_list li a {
  all: unset;
  display: block;
  color: #333333;
  text-decoration: none;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
  cursor: pointer;
}

@media only screen and (min-width: 769px) {
  #single_page #toc_container .toc_list li a {
    font-size: 1em;
    line-height: 2em;
  }
}

@media only screen and (max-width: 768px) {
  #single_page #toc_container .toc_list li a {
    max-width: 66.667vw;
  }
}

#single_page #toc_container .toc_list li a .toc_number {
  display: none;
}

#single_page .no_bullets .toc_list {
  list-style: none !important;
}

#single_page .no_bullets .toc_list li {
  list-style: none !important;
}

#fixed_page {
  margin-top: unset;
}

@media only screen and (min-width: 769px) {
  #fixed_page {
    margin-bottom: 6.25em;
  }
}

@media only screen and (max-width: 768px) {
  #fixed_page {
    margin-bottom: 13.333vw;
  }
}

#fixed_page .aligncenter {
  margin: 1rem auto !important;
}

#fixed_page .aligncenter {
  clear: both;
}

#fixed_page .inner_ctx {
  margin-left: auto;
  margin-right: auto;
}

@media only screen and (min-width: 769px) {
  #fixed_page .inner_ctx {
    max-width: 55em;
  }
}

@media only screen and (max-width: 768px) {
  #fixed_page .inner_ctx {
    padding: unset;
    max-width: 85.333vw;
  }
}

#fixed_page a {
  color: #333333;
  text-decoration: underline;
}

#fixed_page img {
  display: block;
  height: auto;
  margin: 1rem 0;
  max-width: 100%;
  width: unset !important;
  border: none;
  height: auto;
}

#fixed_page h2 {
  background-color: #e5f0f8;
  color: #0068b6;
  position: relative;
  text-align: center;
  display: block;
}

@media only screen and (min-width: 769px) {
  #fixed_page h2 {
    font-size: 2.25em;
    width: 24.444em;
    line-height: 1.389em;
    padding: 0.556em;
    margin: 2.778em 0 1.389em;
    border-left: 0.417em solid #0068b6;
  }
}

@media only screen and (max-width: 768px) {
  #fixed_page h2 {
    font-size: 4.8vw;
    width: 85.333vw;
    line-height: 1.389;
    padding: 4vw;
    margin: 13.333vw 0 6.667vw;
    border-left: 2vw solid #0068b6;
  }
}

#fixed_page h3 {
  color: #333333;
  margin: auto;
}

@media only screen and (min-width: 769px) {
  #fixed_page h3 {
    font-size: 1.75em;
    width: 28.571em;
    line-height: 1.786em;
    margin: 1.429em auto 1.071em;
    border-bottom: 0.107em solid #0068b6;
  }
}

@media only screen and (max-width: 768px) {
  #fixed_page h3 {
    font-size: 3.733vw;
    width: 85.333vw;
    padding: 0 2.667vw;
    line-height: 1.786;
    margin: 5.333vw auto 4vw;
    border-bottom: 0.4vw solid #0068b6;
  }
}

#fixed_page h3 * {
  color: #333333 !important;
}

#fixed_page h4 {
  margin: auto;
}

@media only screen and (min-width: 769px) {
  #fixed_page h4 {
    font-size: 1.75em;
    width: 28.571em;
    line-height: 1.786em;
    margin: 1.071em auto 0;
  }
}

@media only screen and (max-width: 768px) {
  #fixed_page h4 {
    padding: 0 4vw;
    font-size: 3.733vw;
    width: 85.333vw;
    line-height: 1.786;
    margin: 4vw auto 0;
  }
}

#fixed_page h4 span {
  color: #333333 !important;
}

@media only screen and (min-width: 769px) {
  #fixed_page p {
    font-size: 1.125em;
    line-height: 1.778em;
    margin: 0.833em auto;
    padding: 0 2.222em;
  }
}

@media only screen and (max-width: 768px) {
  #fixed_page p {
    font-size: 4.2vw;
    line-height: 6.4vw;
    margin: 2vw auto;
    padding: 0 4vw;
  }
}

#fixed_page p strong {
  color: #333333 !important;
}

#fixed_page table {
  border-collapse: collapse;
  margin-left: auto;
  margin-right: auto;
}

@media only screen and (min-width: 769px) {
  #fixed_page table {
    max-width: 50em;
  }
}

@media only screen and (max-width: 768px) {
  #fixed_page table {
    max-width: 85.333vw;
  }
}

#fixed_page table li {
  font-size: 100% !important;
}

#fixed_page table th,
#fixed_page table td {
  border: 1px solid #ddd;
  text-align: left;
}

@media only screen and (min-width: 769px) {
  #fixed_page table th,
  #fixed_page table td {
    padding: 0.75rem;
  }
}

@media only screen and (max-width: 768px) {
  #fixed_page table th,
  #fixed_page table td {
    padding: 2.5vw 2vw;
  }
}

#fixed_page table th {
  background-color: #f4f4f4;
  font-weight: bold;
}

#fixed_page ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin: auto;
}

@media only screen and (min-width: 769px) {
  #fixed_page ul {
    max-width: 50em;
    margin-bottom: 1.875em;
  }
}

@media only screen and (max-width: 768px) {
  #fixed_page ul {
    max-width: 71.333vw;
    margin-bottom: 4vw;
  }
}

#fixed_page ul li {
  position: relative;
  font-weight: 600;
}

@media only screen and (min-width: 769px) {
  #fixed_page ul li {
    font-size: 1.125em;
    padding-left: 0.556em;
    line-height: 2.278em;
  }
}

@media only screen and (max-width: 768px) {
  #fixed_page ul li {
    font-size: 3.733vw;
    line-height: 8vw;
  }
}

#fixed_page ul li::before {
  content: "●";
  color: #062b54;
}

@media only screen and (min-width: 769px) {
  #fixed_page ul li::before {
    font-size: 0.875em;
  }
}

@media only screen and (max-width: 768px) {
  #fixed_page ul li::before {
    font-size: 2.4vw;
    margin-right: 1.333vw;
    top: -0.5vw;
  }
}

#fixed_page .file_form {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin: 0 auto;
}

@media only screen and (min-width: 769px) {
  #fixed_page .file_form {
    width: 48.125em;
    gap: 1.25em;
  }
}

@media only screen and (max-width: 768px) {
  #fixed_page .file_form {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    width: 85.333vw;
    gap: 6.667vw;
  }
}

#fixed_page .file_form .form_group {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}

@media only screen and (max-width: 768px) {
  #fixed_page .file_form .form_group {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}

#fixed_page .file_form .form_group label {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -ms-flex-item-align: start;
      align-self: start;
  color: #333333;
}

@media only screen and (min-width: 769px) {
  #fixed_page .file_form .form_group label {
    font-size: 1.125em;
    width: 11.111em;
    margin-top: 0.667em;
  }
}

@media only screen and (max-width: 768px) {
  #fixed_page .file_form .form_group label {
    font-size: 3.733vw;
    width: 85.333vw;
    margin-bottom: 2.667vw;
  }
}

#fixed_page .file_form .form_group label .required {
  background: #0068b6;
  color: #fff;
  display: inline-block;
}

@media only screen and (min-width: 769px) {
  #fixed_page .file_form .form_group label .required {
    font-size: 0.813em;
    padding: 0.231em 0.615em;
  }
}

@media only screen and (max-width: 768px) {
  #fixed_page .file_form .form_group label .required {
    font-size: 2.667vw;
    padding: 0.933vw 1.333vw;
  }
}

#fixed_page .file_form .form_group .input_wrapper {
  display: table-cell;
  vertical-align: middle;
}

@media only screen and (min-width: 769px) {
  #fixed_page .file_form .form_group .input_wrapper {
    width: 34.375em;
  }
}

@media only screen and (max-width: 768px) {
  #fixed_page .file_form .form_group .input_wrapper {
    width: 85.333vw;
  }
}

#fixed_page .file_form .form_group input[type="text"],
#fixed_page .file_form .form_group input[type="tel"],
#fixed_page .file_form .form_group input[type="email"],
#fixed_page .file_form .form_group select,
#fixed_page .file_form .form_group textarea {
  width: 100%;
  background: #f2f2f2;
  font-family: inherit;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  border: none;
  outline: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  border-radius: 0;
}

@media only screen and (min-width: 769px) {
  #fixed_page .file_form .form_group input[type="text"],
  #fixed_page .file_form .form_group input[type="tel"],
  #fixed_page .file_form .form_group input[type="email"],
  #fixed_page .file_form .form_group select,
  #fixed_page .file_form .form_group textarea {
    font-size: 1.063em;
    padding: 0.706em 0.941em;
  }
}

@media only screen and (max-width: 768px) {
  #fixed_page .file_form .form_group input[type="text"],
  #fixed_page .file_form .form_group input[type="tel"],
  #fixed_page .file_form .form_group input[type="email"],
  #fixed_page .file_form .form_group select,
  #fixed_page .file_form .form_group textarea {
    padding: 4vw 3.6vw;
    font-size: 3.467vw;
  }
}

#fixed_page .file_form .form_group select {
  cursor: pointer;
  background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23666' d='M6 8L0 0h12z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
}

@media only screen and (min-width: 769px) {
  #fixed_page .file_form .form_group select {
    background-position: right 0.75em center;
  }
}

@media only screen and (max-width: 768px) {
  #fixed_page .file_form .form_group select {
    background-position: right 2.667vw center;
  }
}

#fixed_page .file_form .form_group textarea {
  resize: vertical;
  line-height: 1.5;
  font-family: inherit;
}

@media only screen and (min-width: 769px) {
  #fixed_page .file_form .form_group textarea {
    min-height: 8.125em;
  }
}

@media only screen and (max-width: 768px) {
  #fixed_page .file_form .form_group textarea {
    min-height: 40vw;
  }
}

#fixed_page .file_form .form_submit {
  text-align: center;
}

@media only screen and (min-width: 769px) {
  #fixed_page .file_form .form_submit {
    margin-top: 1.625em;
  }
}

@media only screen and (max-width: 768px) {
  #fixed_page .file_form .form_submit {
    margin-top: 1.333vw;
  }
}

#fixed_page .file_form .form_submit .submit_btn {
  border: none;
  border-radius: 0;
  cursor: pointer;
  background: url("../img/download/form_submit.png") no-repeat center;
  background-size: contain;
  color: transparent;
}

@media only screen and (min-width: 769px) {
  #fixed_page .file_form .form_submit .submit_btn {
    width: 17.5em;
    height: 4.375em;
  }
}

@media only screen and (max-width: 768px) {
  #fixed_page .file_form .form_submit .submit_btn {
    width: 61.2vw;
    height: 15.333vw;
  }
}

#fixed_page .contact_form .form_group.error input,
#fixed_page .contact_form .form_group.error select,
#fixed_page .contact_form .form_group.error textarea {
  background-color: #fdf2f2;
}

#fixed_page .contact_form .form_group.success input,
#fixed_page .contact_form .form_group.success select,
#fixed_page .contact_form .form_group.success textarea {
  background-color: #f2fdf5;
}

#fixed_page .contact_form .error_message {
  color: #e74c3c;
  font-size: 0.875em;
  margin-top: 0.313em;
  display: none;
}

@media only screen and (max-width: 768px) {
  #fixed_page .contact_form .error_message {
    font-size: 1.6vw;
  }
}

#fixed_page .contact_form .error_message.show {
  display: block;
}

.download {
  margin-top: unset !important;
}

@media only screen and (min-width: 769px) {
  .download .service {
    background: url("../img/download/service_bg.jpg") no-repeat 50% 0%;
    background-size: 125em auto;
    height: 44.375em;
  }
}

@media only screen and (max-width: 768px) {
  .download .service {
    background: url("../img/download/service_bg_sp.jpg") no-repeat 50% 0;
    background-size: 100vw auto;
    height: 192vw;
  }
}

.download .service .inner_ctx {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

.download .service_title_txt {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  background-color: rgba(255, 255, 255, 0.5);
}

@media only screen and (min-width: 769px) {
  .download .service_title_txt {
    width: 55em;
    padding: 2.5em 0;
    gap: 0.938em;
    margin-bottom: 2.5em;
    margin-top: 3.125em;
  }
}

@media only screen and (max-width: 768px) {
  .download .service_title_txt {
    text-align: center;
    width: 85.333vw;
    padding: 5.333vw 0;
    gap: 0.667vw;
    margin-bottom: 8vw;
    margin-top: 9.333vw;
  }
}

.download .service_title_txt:before, .download .service_title_txt:after {
  content: "";
  position: absolute;
  background-repeat: no-repeat;
  background-position: center;
}

@media only screen and (min-width: 769px) {
  .download .service_title_txt:before, .download .service_title_txt:after {
    background-image: url(../img/download/title_el.png);
    background-size: 55.375em 1.438em;
    width: 55.375em;
    height: 1.438em;
  }
}

@media only screen and (max-width: 768px) {
  .download .service_title_txt:before, .download .service_title_txt:after {
    background-image: url(../img/download/title_el_sp.png);
    background-size: 86.133vw 3.733vw;
    width: 86.133vw;
    height: 3.733vw;
  }
}

.download .service_title_txt:before {
  top: 0;
}

@media only screen and (min-width: 769px) {
  .download .service_title_txt:before {
    left: -0.188em;
  }
}

@media only screen and (max-width: 768px) {
  .download .service_title_txt:before {
    left: -0.4vw;
  }
}

.download .service_title_txt:after {
  bottom: 0;
  -webkit-transform: scaleX(-1) scaleY(-1);
          transform: scaleX(-1) scaleY(-1);
}

@media only screen and (min-width: 769px) {
  .download .service_title_txt:after {
    right: -0.188em;
  }
}

@media only screen and (max-width: 768px) {
  .download .service_title_txt:after {
    right: -0.4vw;
  }
}

.download .service_title_txt h1 {
  color: #333333;
  font-weight: 500;
}

@media only screen and (min-width: 769px) {
  .download .service_title_txt h1 {
    font-size: 1.875em;
  }
}

@media only screen and (max-width: 768px) {
  .download .service_title_txt h1 {
    font-size: 4.8vw;
    line-height: 1.556em;
  }
}

.download .service_title_txt h2 {
  color: #333333;
  font-weight: 500;
}

@media only screen and (min-width: 769px) {
  .download .service_title_txt h2 {
    font-size: 2.25em;
  }
}

@media only screen and (max-width: 768px) {
  .download .service_title_txt h2 {
    font-size: 5.867vw;
    line-height: 1.364em;
  }
}

.download .service_txt {
  color: #333333;
}

@media only screen and (min-width: 769px) {
  .download .service_txt {
    font-size: 1.125em;
    line-height: 1.778em;
    margin-bottom: 4.125em;
  }
}

@media only screen and (max-width: 768px) {
  .download .service_txt {
    font-size: 3.467vw;
    width: 77.333vw;
    line-height: 6.4vw;
    margin-bottom: 8vw;
  }
}

.download .service_list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: -ms-grid;
  display: grid;
}

@media only screen and (min-width: 769px) {
  .download .service_list {
    -ms-grid-columns: (1fr)[2];
        grid-template-columns: repeat(2, 1fr);
    gap: 1.875em 2.813em;
  }
}

@media only screen and (max-width: 768px) {
  .download .service_list {
    -ms-grid-columns: (1fr)[1];
        grid-template-columns: repeat(1, 1fr);
    gap: 4.267vw;
  }
}

.download .service_list li {
  color: #333333;
  background: #fff;
  position: relative;
  -webkit-box-shadow: rgba(99, 99, 99, 0.2) 0px 2px 8px 0px;
          box-shadow: rgba(99, 99, 99, 0.2) 0px 2px 8px 0px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

@media only screen and (min-width: 769px) {
  .download .service_list li {
    padding-left: 3.438em;
    border-radius: 0.625em;
    width: 29.375em;
    height: 6.25em;
  }
}

@media only screen and (max-width: 768px) {
  .download .service_list li {
    width: 84vw;
    height: 17.067vw;
    padding-left: 8.8vw;
    border-radius: 1.333vw;
  }
}

.download .service_list li p {
  font-weight: 500;
}

@media only screen and (min-width: 769px) {
  .download .service_list li p {
    font-size: 1.313em;
    line-height: 1.619em;
  }
}

@media only screen and (max-width: 768px) {
  .download .service_list li p {
    font-size: 3.467vw;
    line-height: 5.867vw;
    letter-spacing: 0.2vw;
  }
}

.download .service_list li p span {
  color: #0068b6;
}

.download .service_list li p:before {
  content: "";
  background: url("../img/top/quality_check.png") no-repeat 50% 50%;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  position: absolute;
}

@media only screen and (min-width: 769px) {
  .download .service_list li p:before {
    width: 2.381em;
    height: 2.381em;
    top: -0.476em;
    left: -1.19em;
  }
}

@media only screen and (max-width: 768px) {
  .download .service_list li p:before {
    top: -1.333vw;
    left: -4vw;
    width: 8vw;
    height: 8vw;
  }
}

@media only screen and (min-width: 769px) {
  .download .file {
    background: url("../img/download/file_bg.jpg") no-repeat 50% 0%;
    background-size: 125em 58.813em;
  }
}

@media only screen and (max-width: 768px) {
  .download .file {
    background: url("../img/download/file_bg_sp.jpg") no-repeat 50% 0;
    background-size: 100vw 129.733vw;
  }
}

.download .file_title_txt {
  color: #fff;
}

@media only screen and (min-width: 769px) {
  .download .file_title_txt {
    padding-top: 3.75em;
    padding-left: 6.875em;
    margin-bottom: 9.5em;
  }
}

@media only screen and (max-width: 768px) {
  .download .file_title_txt {
    padding-top: 9.2vw;
    padding-left: 8vw;
    margin-bottom: 59.733vw;
  }
}

@media only screen and (min-width: 769px) {
  .download .file_title_txt img {
    width: 18.75em;
  }
}

@media only screen and (max-width: 768px) {
  .download .file_title_txt img {
    width: 61.6vw;
  }
}

@media only screen and (min-width: 769px) {
  .download .file_title_txt h2 {
    font-size: 1.875em;
    line-height: 2.367em;
  }
}

@media only screen and (max-width: 768px) {
  .download .file_title_txt h2 {
    font-size: 5.867vw;
    line-height: 12vw;
  }
}

@media only screen and (min-width: 769px) {
  .download .file_title_txt h3 {
    font-size: 3em;
    line-height: 1.208em;
  }
}

@media only screen and (max-width: 768px) {
  .download .file_title_txt h3 {
    font-size: 9.867vw;
    line-height: 11.2vw;
  }
}

.download .file_title_txt h4 {
  font-weight: normal;
}

@media only screen and (min-width: 769px) {
  .download .file_title_txt h4 {
    font-size: 1.125em;
    line-height: 1.556em;
    margin-top: 1.667em;
  }
}

@media only screen and (max-width: 768px) {
  .download .file_title_txt h4 {
    font-size: 3.467vw;
    line-height: 5.867vw;
    margin-top: 4vw;
  }
}

.download .file_title_txt h5 {
  font-weight: normal;
}

@media only screen and (min-width: 769px) {
  .download .file_title_txt h5 {
    font-size: 0.875em;
    line-height: 1.714em;
    margin-top: 1em;
  }
}

@media only screen and (max-width: 768px) {
  .download .file_title_txt h5 {
    font-size: 2.4vw;
    line-height: 5.067vw;
    margin-top: 0.533vw;
  }
}

.download .file_form {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin: 0 auto;
}

@media only screen and (min-width: 769px) {
  .download .file_form {
    width: 48.125em;
    gap: 1.25em;
  }
}

@media only screen and (max-width: 768px) {
  .download .file_form {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    width: 85.333vw;
    gap: 6.667vw;
  }
}

.download .file_form .form_group {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}

@media only screen and (max-width: 768px) {
  .download .file_form .form_group {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}

.download .file_form .form_group label {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -ms-flex-item-align: start;
      align-self: start;
  color: #333333;
}

@media only screen and (min-width: 769px) {
  .download .file_form .form_group label {
    font-size: 1.125em;
    width: 11.111em;
    margin-top: 0.667em;
  }
}

@media only screen and (max-width: 768px) {
  .download .file_form .form_group label {
    font-size: 3.733vw;
    width: 85.333vw;
    margin-bottom: 2.667vw;
  }
}

.download .file_form .form_group label .required {
  background: #0068b6;
  color: #fff;
  display: inline-block;
}

@media only screen and (min-width: 769px) {
  .download .file_form .form_group label .required {
    font-size: 0.813em;
    padding: 0.231em 0.615em;
  }
}

@media only screen and (max-width: 768px) {
  .download .file_form .form_group label .required {
    font-size: 2.667vw;
    padding: 0.933vw 1.333vw;
  }
}

.download .file_form .form_group .input_wrapper {
  display: table-cell;
  vertical-align: middle;
}

@media only screen and (min-width: 769px) {
  .download .file_form .form_group .input_wrapper {
    width: 34.375em;
  }
}

@media only screen and (max-width: 768px) {
  .download .file_form .form_group .input_wrapper {
    width: 85.333vw;
  }
}

.download .file_form .form_group input[type="text"],
.download .file_form .form_group input[type="tel"],
.download .file_form .form_group input[type="email"],
.download .file_form .form_group select,
.download .file_form .form_group textarea {
  width: 100%;
  background: #f2f2f2;
  font-family: inherit;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  border: none;
  outline: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  border-radius: 0;
}

@media only screen and (min-width: 769px) {
  .download .file_form .form_group input[type="text"],
  .download .file_form .form_group input[type="tel"],
  .download .file_form .form_group input[type="email"],
  .download .file_form .form_group select,
  .download .file_form .form_group textarea {
    font-size: 1.063em;
    padding: 0.706em 0.941em;
  }
}

@media only screen and (max-width: 768px) {
  .download .file_form .form_group input[type="text"],
  .download .file_form .form_group input[type="tel"],
  .download .file_form .form_group input[type="email"],
  .download .file_form .form_group select,
  .download .file_form .form_group textarea {
    padding: 4vw 3.6vw;
    font-size: 3.467vw;
  }
}

.download .file_form .form_group select {
  cursor: pointer;
  background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23666' d='M6 8L0 0h12z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
}

@media only screen and (min-width: 769px) {
  .download .file_form .form_group select {
    background-position: right 0.75em center;
  }
}

@media only screen and (max-width: 768px) {
  .download .file_form .form_group select {
    background-position: right 2.667vw center;
  }
}

.download .file_form .form_group textarea {
  resize: vertical;
  line-height: 1.5;
  font-family: inherit;
}

@media only screen and (min-width: 769px) {
  .download .file_form .form_group textarea {
    min-height: 8.125em;
  }
}

@media only screen and (max-width: 768px) {
  .download .file_form .form_group textarea {
    min-height: 40vw;
  }
}

.download .file_form .form_submit {
  text-align: center;
}

@media only screen and (min-width: 769px) {
  .download .file_form .form_submit {
    margin-top: 1.625em;
  }
}

@media only screen and (max-width: 768px) {
  .download .file_form .form_submit {
    margin-top: 1.333vw;
  }
}

.download .file_form .form_submit .submit_btn {
  border: none;
  border-radius: 0;
  cursor: pointer;
  background: url("../img/download/form_submit.png") no-repeat center;
  background-size: contain;
  color: transparent;
}

@media only screen and (min-width: 769px) {
  .download .file_form .form_submit .submit_btn {
    width: 17.5em;
    height: 4.375em;
  }
}

@media only screen and (max-width: 768px) {
  .download .file_form .form_submit .submit_btn {
    width: 61.2vw;
    height: 15.333vw;
  }
}

.download .contact_form .form_group.error input,
.download .contact_form .form_group.error select,
.download .contact_form .form_group.error textarea {
  background-color: #fdf2f2;
}

.download .contact_form .form_group.success input,
.download .contact_form .form_group.success select,
.download .contact_form .form_group.success textarea {
  background-color: #f2fdf5;
}

.download .contact_form .error_message {
  color: #e74c3c;
  font-size: 0.875em;
  margin-top: 0.313em;
  display: none;
}

@media only screen and (max-width: 768px) {
  .download .contact_form .error_message {
    font-size: 1.6vw;
  }
}

.download .contact_form .error_message.show {
  display: block;
}

@media only screen and (min-width: 769px) {
  .download {
    padding-bottom: 8.125em;
  }
}

@media only screen and (max-width: 768px) {
  .download {
    padding-bottom: 18.667vw;
  }
}

.archive_page .contents_list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}

@media only screen and (min-width: 769px) {
  .archive_page .contents_list {
    gap: 3.125em 1.25em;
  }
}

@media only screen and (max-width: 768px) {
  .archive_page .contents_list {
    margin: 0 auto;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    gap: 13.333vw;
  }
}

@media only screen and (min-width: 769px) {
  .archive_page .contents_item {
    width: 21.875em;
  }
}

@media only screen and (max-width: 768px) {
  .archive_page .contents_item {
    width: 85.333vw;
  }
}

.archive_page .contents_item a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  text-decoration: none;
  color: #333333;
}

@media only screen and (min-width: 769px) {
  .archive_page .contents_item a {
    gap: 0.625em;
  }
}

@media only screen and (max-width: 768px) {
  .archive_page .contents_item a {
    gap: 2.667vw;
  }
}

@media only screen and (min-width: 769px) {
  .archive_page .contents_img {
    width: 21.875em;
  }
}

@media only screen and (max-width: 768px) {
  .archive_page .contents_img {
    width: 85.333vw;
  }
}

.archive_page .contents_img img {
  width: 100%;
  height: auto;
}

.archive_page .contents_txt p {
  color: #333333;
}

@media only screen and (min-width: 769px) {
  .archive_page .contents_txt p {
    font-size: 1.063em;
    line-height: 1.941em;
  }
}

@media only screen and (max-width: 768px) {
  .archive_page .contents_txt p {
    font-size: 4vw;
    line-height: 6.4vw;
  }
}

@media only screen and (min-width: 769px) {
  .archive_page .pagination {
    margin-top: 4.688em;
  }
}

@media only screen and (max-width: 768px) {
  .archive_page .pagination {
    margin-top: 14.667vw;
  }
}

.archive_page .pagination__wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

@media only screen and (min-width: 769px) {
  .archive_page .pagination__wrap {
    gap: 1.25em;
  }
}

@media only screen and (max-width: 768px) {
  .archive_page .pagination__wrap {
    gap: 2vw;
  }
}

.archive_page .pagination .page-numbers {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  text-decoration: none;
  font-weight: 500;
  color: #000000;
}

@media only screen and (min-width: 769px) {
  .archive_page .pagination .page-numbers {
    font-size: 1.25em;
    min-width: 2em;
    height: 2em;
    gap: 1em;
  }
}

@media only screen and (max-width: 768px) {
  .archive_page .pagination .page-numbers {
    min-width: 6.667vw;
    height: 6.667vw;
    font-size: 3.6vw;
    padding: 0 2vw;
  }
}

.archive_page .pagination .page-numbers.current {
  background: #0068b6;
  color: #ffffff;
  cursor: default;
}

.archive_page .pagination .page-numbers.first, .archive_page .pagination .page-numbers.prev, .archive_page .pagination .page-numbers.next, .archive_page .pagination .page-numbers.last {
  background: none;
  border: none;
  min-width: auto;
  position: relative;
}

@media only screen and (min-width: 769px) {
  .archive_page .pagination .page-numbers.first, .archive_page .pagination .page-numbers.prev, .archive_page .pagination .page-numbers.next, .archive_page .pagination .page-numbers.last {
    gap: 0.5em;
  }
}

@media only screen and (max-width: 768px) {
  .archive_page .pagination .page-numbers.first {
    -webkit-transform: rotate(180deg);
            transform: rotate(180deg);
  }
}

@media only screen and (max-width: 768px) and (max-width: 768px) {
  .archive_page .pagination .page-numbers.first img {
    width: 2.667vw;
  }
}

.archive_page .pagination .page-numbers.first::before {
  content: "";
  display: inline-block;
  background-size: contain;
  vertical-align: middle;
  -webkit-transform: rotate(180deg);
          transform: rotate(180deg);
}

@media only screen and (min-width: 769px) {
  .archive_page .pagination .page-numbers.first::before {
    background-size: contain;
    width: 1em;
    height: 0.875em;
    background: url("../img/archive/pagination_arrow02.png") no-repeat center;
  }
}

@media only screen and (max-width: 768px) {
  .archive_page .pagination .page-numbers.prev {
    -webkit-transform: rotate(180deg);
            transform: rotate(180deg);
  }
  .archive_page .pagination .page-numbers.prev img {
    width: 1.467vw;
  }
}

.archive_page .pagination .page-numbers.prev::before {
  content: "";
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: rotate(180deg);
          transform: rotate(180deg);
}

@media only screen and (min-width: 769px) {
  .archive_page .pagination .page-numbers.prev::before {
    background-size: contain;
    background: url("../img/archive/pagination_arrow.png") no-repeat center;
    width: 0.563em;
    height: 0.875em;
  }
}

@media only screen and (max-width: 768px) {
  .archive_page .pagination .page-numbers.next img {
    width: 1.467vw;
  }
}

.archive_page .pagination .page-numbers.next::after {
  content: "";
  display: inline-block;
}

@media only screen and (min-width: 769px) {
  .archive_page .pagination .page-numbers.next::after {
    background-size: contain;
    width: 0.563em;
    height: 0.875em;
    background: url("../img/archive/pagination_arrow.png") no-repeat center;
  }
}

@media only screen and (max-width: 768px) {
  .archive_page .pagination .page-numbers.last img {
    width: 2.667vw;
  }
}

@media only screen and (min-width: 769px) {
  .archive_page .pagination .page-numbers.last::after {
    content: "";
    display: inline-block;
    background-size: contain;
    width: 1em;
    height: 0.875em;
    background: url("../img/archive/pagination_arrow02.png") no-repeat center;
  }
}

.archive_page .pagination .page-numbers.disabled {
  color: #999999;
  cursor: default;
  pointer-events: none;
}

.archive_page .pagination .page-numbers.disabled:hover {
  text-decoration: none;
}

.archive_page .sidebar {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}

@media only screen and (min-width: 769px) {
  .archive_page .sidebar {
    gap: 2.5em;
  }
}

@media only screen and (max-width: 768px) {
  .archive_page .sidebar {
    width: 85.333vw;
    margin: 0 auto;
    gap: 8.667vw;
  }
}

.archive_page .sidebar .sidebar_title h2 {
  background-color: #0068b6;
  color: #ffffff;
  text-align: center;
  font-weight: 500;
}

@media only screen and (min-width: 769px) {
  .archive_page .sidebar .sidebar_title h2 {
    font-size: 1.25em;
    line-height: 1.2em;
    padding: 0.7em 0;
    letter-spacing: 0.1em;
  }
}

@media only screen and (max-width: 768px) {
  .archive_page .sidebar .sidebar_title h2 {
    font-size: 5.333vw;
    line-height: 3em;
    letter-spacing: 0.5vw;
  }
}

.archive_page .sidebar .support_record {
  background-color: #f2f2f2;
}

@media only screen and (max-width: 768px) {
  .archive_page .sidebar .support_record {
    width: 85.333vw;
    margin: 0 auto;
  }
}

.archive_page .sidebar .support_record .support_record_list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

@media only screen and (min-width: 769px) {
  .archive_page .sidebar .support_record .support_record_list {
    padding: 1.875em 0.938em;
    gap: 2.875em;
  }
}

@media only screen and (max-width: 768px) {
  .archive_page .sidebar .support_record .support_record_list {
    padding: 8vw 0;
    gap: 12vw;
  }
}

@media only screen and (min-width: 769px) {
  .archive_page .sidebar .support_record .support_record_list li {
    width: 13.75em;
  }
}

@media only screen and (max-width: 768px) {
  .archive_page .sidebar .support_record .support_record_list li {
    width: 77.333vw;
  }
}

.archive_page .sidebar .support_record .support_record_list li a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  text-decoration: none !important;
}

@media only screen and (min-width: 769px) {
  .archive_page .sidebar .support_record .support_record_list li a {
    gap: 0.625em;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}

@media only screen and (max-width: 768px) {
  .archive_page .sidebar .support_record .support_record_list li a {
    gap: 2.667vw;
  }
}

@media only screen and (min-width: 769px) {
  .archive_page .sidebar .support_record .support_record_img {
    width: 13.75em;
  }
}

@media only screen and (max-width: 768px) {
  .archive_page .sidebar .support_record .support_record_img {
    width: 37.333vw;
  }
}

.archive_page .sidebar .support_record .support_record_img img {
  width: 100%;
  height: auto;
}

@media only screen and (max-width: 768px) {
  .archive_page .sidebar .support_record .support_record_txt {
    width: 37.333vw;
  }
}

.archive_page .sidebar .support_record .support_record_txt p {
  color: #333333;
}

@media only screen and (min-width: 769px) {
  .archive_page .sidebar .support_record .support_record_txt p {
    font-size: 0.813em;
    line-height: 1.769em;
  }
}

@media only screen and (max-width: 768px) {
  .archive_page .sidebar .support_record .support_record_txt p {
    font-size: 3.733vw;
    line-height: 7.2vw;
  }
}

.archive_page .sidebar .support_record .support_record_btn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
}

@media only screen and (min-width: 769px) {
  .archive_page .sidebar .support_record .support_record_btn {
    gap: 0.625em;
    padding: 0 0.938em 2.5em;
  }
}

@media only screen and (max-width: 768px) {
  .archive_page .sidebar .support_record .support_record_btn {
    gap: 1.333vw;
    padding: 0 4.667vw 10.667vw 0;
  }
}

.archive_page .sidebar .support_record .support_record_btn p {
  color: #333333;
  text-decoration: underline;
}

@media only screen and (min-width: 769px) {
  .archive_page .sidebar .support_record .support_record_btn p {
    font-size: 0.938em;
  }
}

@media only screen and (min-width: 769px) {
  .archive_page .sidebar .support_record .support_record_btn img {
    width: 1.25em;
  }
}

@media only screen and (max-width: 768px) {
  .archive_page .sidebar .support_record .support_record_btn img {
    width: 4vw;
  }
}

.archive_page .sidebar .recommend_article .recommend_article_list {
  background-color: #f2f2f2;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}

@media only screen and (min-width: 769px) {
  .archive_page .sidebar .recommend_article .recommend_article_list {
    padding: 1.25em 0.938em;
    gap: 1.438em;
  }
}

@media only screen and (max-width: 768px) {
  .archive_page .sidebar .recommend_article .recommend_article_list {
    gap: 8vw;
    padding: 9.333vw 6.667vw;
  }
}

@media only screen and (min-width: 769px) {
  .archive_page .sidebar .recommend_article .recommend_article_link {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    gap: 0.625em;
  }
}

@media only screen and (max-width: 768px) {
  .archive_page .sidebar .recommend_article .recommend_article_link {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: 1.867vw 66.667vw;
        grid-template-columns: 1.867vw 66.667vw;
    gap: 2.667vw;
  }
}

.archive_page .sidebar .recommend_article .recommend_article_link:before {
  content: "";
  display: block;
  position: relative;
}

@media only screen and (min-width: 769px) {
  .archive_page .sidebar .recommend_article .recommend_article_link:before {
    background-image: url(../img/archive/arrow.png);
    background-size: contain;
    background-repeat: no-repeat;
    width: 0.438em;
    height: 0.688em;
    top: 0.375em;
  }
}

@media only screen and (max-width: 768px) {
  .archive_page .sidebar .recommend_article .recommend_article_link:before {
    background-image: url(../img/archive/arrow.png);
    background-size: contain;
    background-repeat: no-repeat;
    width: 4.533vw;
    height: 3.067vw;
    top: 1.867vw;
  }
}

.archive_page .sidebar .recommend_article .recommend_article_txt {
  color: #333333;
}

@media only screen and (min-width: 769px) {
  .archive_page .sidebar .recommend_article .recommend_article_txt {
    font-size: 0.813em;
    line-height: 1.769em;
    width: 14.615em;
  }
}

@media only screen and (max-width: 768px) {
  .archive_page .sidebar .recommend_article .recommend_article_txt {
    font-size: 3.467vw;
    line-height: 6.933vw;
  }
}

@media only screen and (min-width: 769px) {
  .archive_page .sidebar .banner {
    width: 15.625em;
  }
}

@media only screen and (max-width: 768px) {
  .archive_page .sidebar .banner {
    width: 85.333vw;
  }
}

@media only screen and (min-width: 769px) {
  .archive_page {
    margin-bottom: 5.625em;
  }
}

@media only screen and (max-width: 768px) {
  .archive_page {
    margin-top: 9.333vw !important;
    margin-bottom: 21.333vw;
  }
}

@media only screen and (min-width: 769px) {
  .archive_page .inner_ctx {
    display: -ms-grid;
    display: grid;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -ms-grid-columns: 45em 15.625em;
        grid-template-columns: 45em 15.625em;
    gap: 1.875em;
  }
}

@media only screen and (max-width: 768px) {
  .archive_page .inner_ctx {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    gap: 10.667vw;
  }
}

@media only screen and (min-width: 769px) {
  .cta {
    background: url("../img/cta/bg.jpg") no-repeat 50% 0%;
    background-size: 125em auto;
    padding: 3.75em 0;
    margin-top: 3.125em;
  }
}

@media only screen and (max-width: 768px) {
  .cta {
    background: url("../img/cta/bg_sp.jpg") no-repeat 50% 0;
    background-size: 100vw auto;
    padding: 14.667vw 0 13.333vw;
    margin-top: 5.333vw;
  }
}

.cta ul {
  display: -webkit-box !important;
  display: -ms-flexbox !important;
  display: flex !important;
  -webkit-box-pack: center !important;
      -ms-flex-pack: center !important;
          justify-content: center !important;
  -webkit-box-align: center !important;
      -ms-flex-align: center !important;
          align-items: center !important;
  max-width: none !important;
  margin: 0 !important;
  margin-bottom: 0 !important;
  -webkit-box-orient: horizontal !important;
  -webkit-box-direction: normal !important;
      -ms-flex-direction: row !important;
          flex-direction: row !important;
}

@media only screen and (min-width: 769px) {
  .cta ul {
    gap: 2.5em;
  }
}

@media only screen and (max-width: 768px) {
  .cta ul {
    -webkit-box-orient: vertical !important;
    -webkit-box-direction: normal !important;
        -ms-flex-direction: column !important;
            flex-direction: column !important;
    gap: 12vw;
  }
}

.cta ul li {
  position: relative;
  font-weight: normal !important;
  padding-left: 0 !important;
  line-height: normal !important;
  font-size: initial !important;
}

@media only screen and (min-width: 769px) {
  .cta ul li {
    width: 30em;
    height: 13.75em;
  }
}

@media only screen and (max-width: 768px) {
  .cta ul li {
    width: 76.8vw;
  }
}

.cta ul li::before {
  display: none !important;
}

.cta ul li:first-child:after {
  content: "";
  position: absolute;
  background-repeat: no-repeat;
  background-position: center;
}

@media only screen and (min-width: 769px) {
  .cta ul li:first-child:after {
    background-image: url(../img/cta/cta_contact_el.png);
    background-size: 12.625em 6.875em;
    width: 12.625em;
    height: 6.875em;
    left: -3.25em;
    top: -3.125em;
  }
}

@media only screen and (max-width: 768px) {
  .cta ul li:first-child:after {
    background-image: url(../img/cta/cta_contact_elsp.png);
    background-size: 32.4vw 17.6vw;
    width: 32.4vw;
    height: 17.6vw;
    left: -8.533vw;
    top: -8vw;
  }
}

.cta ul li:last-child:after {
  content: "";
  position: absolute;
  background-repeat: no-repeat;
  background-position: center;
}

@media only screen and (min-width: 769px) {
  .cta ul li:last-child:after {
    background-image: url(../img/cta/cta_example_el.png);
    background-size: 24.625em 3.125em;
    width: 24.625em;
    height: 3.125em;
    left: 2.688em;
    top: -1.875em;
  }
}

@media only screen and (max-width: 768px) {
  .cta ul li:last-child:after {
    background-image: url(../img/cta/cta_example_elsp.png);
    background-size: 63.2vw 8vw;
    width: 63.2vw;
    height: 8vw;
    left: 6.933vw;
    top: -4.933vw;
  }
}

.footer {
  background-color: #f2f2f2;
}

@media only screen and (max-width: 768px) {
  .footer {
    padding-bottom: 20vw;
  }
}

@media only screen and (min-width: 769px) {
  .footer .inner_ctx {
    padding: 0 6.25em;
  }
}

.footer_top {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

@media only screen and (min-width: 769px) {
  .footer_top {
    padding: 3.75em 0;
  }
}

@media only screen and (max-width: 768px) {
  .footer_top {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    padding-top: 10vw;
    gap: 6.133vw;
  }
}

@media only screen and (min-width: 769px) {
  .footer_logo img {
    width: 22em;
  }
}

@media only screen and (max-width: 768px) {
  .footer_logo img {
    width: 61.6vw;
  }
}

.footer_btn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

@media only screen and (min-width: 769px) {
  .footer_btn {
    gap: 0.625em;
  }
}

@media only screen and (max-width: 768px) {
  .footer_btn {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 5.333vw;
  }
}

@media only screen and (min-width: 769px) {
  .footer_btn .tel a img {
    width: 17.5em;
  }
}

@media only screen and (max-width: 768px) {
  .footer_btn .tel a img {
    width: 73.333vw;
  }
}

@media only screen and (min-width: 769px) {
  .footer_btn .contact a img {
    width: 17.5em;
  }
}

@media only screen and (max-width: 768px) {
  .footer_btn .contact a img {
    width: 73.333vw;
  }
}

.footer_content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}

@media only screen and (min-width: 769px) {
  .footer_content {
    padding: 0 0 3.125em;
    gap: 4.75em;
  }
}

@media only screen and (max-width: 768px) {
  .footer_content {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    padding: 10.667vw 0;
    gap: 5.333vw;
  }
}

.footer_company {
  width: 100%;
}

.footer_company h3 {
  color: #000000;
  font-weight: 700;
}

@media only screen and (min-width: 769px) {
  .footer_company h3 {
    font-size: 1.25em;
    margin-bottom: 1em;
  }
}

@media only screen and (max-width: 768px) {
  .footer_company h3 {
    font-size: 3.733vw;
    margin-bottom: 2.667vw;
  }
}

.footer_company p {
  color: #333333;
}

@media only screen and (min-width: 769px) {
  .footer_company p {
    font-size: 0.875em;
    line-height: 2.143em;
  }
}

@media only screen and (max-width: 768px) {
  .footer_company p {
    font-size: 2.667vw;
    line-height: 5.333vw;
  }
}

.footer_nav {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

@media only screen and (min-width: 769px) {
  .footer_nav {
    gap: 1.25em;
  }
}

@media only screen and (max-width: 768px) {
  .footer_nav {
    gap: 2.933vw;
  }
}

.footer_nav_col ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.footer_nav_col ul li {
  border-bottom: 1px solid #cccccc;
}

@media only screen and (min-width: 769px) {
  .footer_nav_col ul li {
    width: 11.875em;
    margin-bottom: 1.25em;
    padding-bottom: 1.25em;
  }
}

@media only screen and (max-width: 768px) {
  .footer_nav_col ul li {
    width: 28vw;
    margin-bottom: 2.667vw;
    padding-bottom: 2.667vw;
  }
}

.footer_nav_col ul li:last-child {
  margin-bottom: 0;
}

.footer_nav_col ul li a {
  color: #333333;
  text-decoration: none;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  position: relative;
}

@media only screen and (min-width: 769px) {
  .footer_nav_col ul li a {
    font-size: 1.063em;
    gap: 0.471em;
  }
}

@media only screen and (max-width: 768px) {
  .footer_nav_col ul li a {
    font-size: 2.667vw;
    gap: 1.333vw;
  }
}

.footer_nav_col ul li a::before {
  content: "";
  display: inline-block;
}

@media only screen and (min-width: 769px) {
  .footer_nav_col ul li a::before {
    background: url("../img/footer/arrow.png") no-repeat center center;
    background-size: contain;
    width: 0.313em;
    height: 0.625em;
  }
}

@media only screen and (max-width: 768px) {
  .footer_nav_col ul li a::before {
    background: url("../img/footer/arrow.png") no-repeat center center;
    background-size: contain;
    width: 0.8vw;
    height: 1.6vw;
  }
}

.footer_bottom {
  background-color: #333333;
  color: #ffffff;
}

@media only screen and (min-width: 769px) {
  .footer_bottom .inner_ctx {
    padding: 1.25em 0;
  }
}

@media only screen and (max-width: 768px) {
  .footer_bottom .inner_ctx {
    padding: 3.333vw 0;
  }
}

.footer_bottom .copyright {
  text-align: center;
  margin: 0;
  font-weight: 300;
}

@media only screen and (min-width: 769px) {
  .footer_bottom .copyright {
    font-size: 0.813em;
    letter-spacing: 0.1em;
  }
}

@media only screen and (max-width: 768px) {
  .footer_bottom .copyright {
    font-size: 1.867vw;
    letter-spacing: 0.1vw;
  }
}
/*# sourceMappingURL=style.css.map */