@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&family=Poppins:wght@400;500;700;900&display=swap");
html, body, div, span, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, abbr, address, cite, code, del, dfn, em, img, ins, kbd, q, samp, small, strong, sub, sup, var, b, i, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, figcaption, figure, footer, header, hgroup, menu, nav, section, summary, time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
}

body {
  line-height: 1;
}

article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {
  display: block;
}

nav ul {
  list-style: none;
}

blockquote, q {
  quotes: none;
}

blockquote:before, blockquote:after, q:before, q:after {
  content: none;
}

a {
  margin: 0;
  padding: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
}

ins {
  background-color: #ff9;
  color: #000;
  text-decoration: none;
}

mark {
  background-color: #ff9;
  color: #000;
  font-style: italic;
  font-weight: bold;
}

del {
  text-decoration: line-through;
}

abbr[title], dfn[title] {
  border-bottom: 1px dotted;
  cursor: help;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

hr {
  display: block;
  height: 1px;
  border: 0;
  border-top: 1px solid #ccc;
  margin: 1em 0;
  padding: 0;
}

input, select {
  vertical-align: middle;
}

main {
  display: block;
}

/* BASE COLOR
------------------------------------------------------------*/
/* variable SETTING
------------------------------------------------------------*/
/* BRAKEPOINT SETTING
------------------------------------------------------------*/
/* MIXIN
------------------------------------------------------------*/
/* BASE
------------------------------------------------------------*/
/* SITE SETTING
------------------------------------------------------------*/
@media print, screen and (min-width: 769px) {
  * {
    margin: 0;
    padding: 0;
    zoom: 1;
  }
  *, *:before, *:after {
    -o-box-sizing: border-box;
    -ms-box-sizing: border-box;
    box-sizing: border-box;
  }
  html {
    -webkit-text-size-adjust: none;
    font-size: 62.5%;
  }
  body {
    color: #263238;
    background: #FFF;
    font-size: 1.6rem;
    line-height: 1.8;
    font-family: "Noto Sans JP", "Yu Gothic", "游ゴシック", YuGothic, "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "MS Pゴシック", Helvetica, Arial, Verdana, sans-serif;
    font-weight: 400;
    font-feature-settings: "palt";
    letter-spacing: 0.024em;
  }
  h1, h2, h3, h4, h5, h6 {
    font-weight: 500;
  }
  img {
    -ms-interpolation-mode: bicubic;
    vertical-align: bottom;
  }
  i, strong {
    font-style: normal;
  }
  a {
    text-decoration: none;
    outline: none;
    cursor: pointer;
    color: #263238;
  }
  a:hover {
    text-decoration: none;
    color: #3b4d56;
  }
  a:hover img {
    opacity: 0.8;
  }
  .clear {
    clear: both;
  }
  .clearfix:after {
    content: "";
    display: block;
    clear: both;
  }
  .inner {
    max-width: 1200px;
    margin: 0 auto;
    position: relative;
    top: 0;
    left: 0;
  }
  ul, ol {
    list-style: none;
  }
  input[type=text],
  input[type=tel],
  input[type=email],
  input[type=submit],
  textarea {
    -webkit-appearance: none;
  }
}
@media screen and (max-width: 768px) {
  * {
    margin: 0;
    padding: 0;
    zoom: 1;
  }
  *, *:before, *:after {
    -o-box-sizing: border-box;
    -ms-box-sizing: border-box;
    box-sizing: border-box;
  }
  html {
    -webkit-text-size-adjust: none;
    font-size: 62.5%;
  }
  body {
    color: #263238;
    background: #FFF;
    font-size: 1.4rem;
    line-height: 1.8;
    font-family: "Noto Sans JP", "Yu Gothic", "游ゴシック", YuGothic, "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "MS Pゴシック", Helvetica, Arial, Verdana, sans-serif;
    font-weight: 400;
    font-feature-settings: "palt";
    letter-spacing: 0.024em;
  }
  h1, h2, h3, h4, h5, h6 {
    font-weight: 500;
  }
  img {
    -ms-interpolation-mode: bicubic;
    vertical-align: bottom;
  }
  i, strong {
    font-style: normal;
  }
  a {
    text-decoration: none;
    outline: none;
    cursor: pointer;
    color: #263238;
  }
  a:hover {
    text-decoration: none;
    color: #3b4d56;
  }
  a:hover img {
    opacity: 0.8;
  }
  .clear {
    clear: both;
  }
  .clearfix:after {
    content: "";
    display: block;
    clear: both;
  }
  .inner {
    max-width: 1200px;
    margin: 0 auto;
    position: relative;
    top: 0;
    left: 0;
  }
  ul, ol {
    list-style: none;
  }
  input[type=text],
  input[type=tel],
  input[type=email],
  input[type=submit],
  textarea {
    -webkit-appearance: none;
  }
}
hgroup {
  margin: 0 0 42px;
}
@media only screen and (max-width: 767px) {
  hgroup {
    margin: 0 0 28px;
  }
}
hgroup.center {
  text-align: center;
}
hgroup .bold {
  font-weight: 700;
}
hgroup .black {
  font-weight: 900;
}
hgroup .primary {
  color: #1864AB;
}
hgroup .sp {
  display: none;
}
@media only screen and (max-width: 767px) {
  hgroup .sp {
    display: block;
  }
}

h2.large {
  font-size: 5rem;
  line-height: 1.4;
}
@media only screen and (max-width: 1100px) {
  h2.large {
    font-size: 3rem;
  }
}
@media only screen and (max-width: 767px) {
  h2.large {
    font-size: 2.4rem;
  }
}
h2.line {
  position: relative;
  padding: 0 0 20px;
}
h2.line:after {
  content: "";
  width: 80px;
  height: 5px;
  -webkit-clip-path: polygon(7% 0, 100% 0%, 93% 100%, 0% 100%);
          clip-path: polygon(7% 0, 100% 0%, 93% 100%, 0% 100%);
  background: rgb(138, 190, 234);
  background: linear-gradient(90deg, rgb(138, 190, 234) 0%, rgb(72, 159, 238) 100%);
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
}

h3.middle {
  font-size: 3rem;
  line-height: 1.4;
}

.tableStyle {
  width: 100%;
  border-collapse: collapse;
}
.tableStyle th, .tableStyle td {
  padding: 20px;
  text-align: left;
}
.tableStyle th {
  line-height: 1.4;
  vertical-align: middle;
}

.button-area.center {
  text-align: center;
}
.button-area a {
  display: inline-block;
}
@media only screen and (max-width: 767px) {
  .button-area a {
    display: block;
  }
}
.button-area a.btn {
  background-color: #C92A2A;
  color: #FFF;
  font-weight: 700;
  padding: 15px 72px;
  border-radius: 8px;
}
@media only screen and (max-width: 767px) {
  .button-area a.btn {
    display: block;
    padding: 15px;
    width: 250px;
    margin: 0 auto;
    text-align: center;
  }
}
.button-area a.arw {
  background-image: url(../../images/common/arw.svg);
  background-repeat: no-repeat;
  background-position: right 30px center;
  transition: all 0.2s;
}
.button-area a.arw:hover {
  background-position: right 25px center;
}
.button-area a.radius {
  border-radius: 99px;
}
.button-area a.mid {
  background: #FFF;
  border: 1px solid #DAE0E2;
  padding: 8px 15px;
  margin-right: 12px;
  border-radius: 5px;
  text-align: center;
  font-size: 1.4rem;
  line-height: 1.4;
  font-weight: 700;
  width: 28%;
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
}

.page-top {
  width: 100%;
  background: #bdc8cc;
  text-align: center;
  position: absolute;
  top: 0;
  left: 0;
}
.page-top a {
  display: block;
  padding: 6px;
  color: #263238;
}

#site-breadcrumb {
  width: 100%;
  height: 150px;
  position: relative;
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  margin: 0 0 50px;
}
@media only screen and (max-width: 767px) {
  #site-breadcrumb {
    height: 0;
    margin: 0;
  }
}
#site-breadcrumb nav {
  width: 100%;
  position: absolute;
  bottom: -37px;
  left: 0;
}
@media only screen and (max-width: 767px) {
  #site-breadcrumb nav {
    position: relative;
    bottom: 0;
    padding: 5%;
  }
}
#site-breadcrumb nav ol li {
  list-style: none;
  float: left;
  font-size: 1.2rem;
  color: #A4A4A4;
  position: relative;
}
@media only screen and (max-width: 767px) {
  #site-breadcrumb nav ol li {
    font-size: 1.1rem;
  }
}
#site-breadcrumb nav ol li:after {
  content: "";
  background: url(../../images/common/breadcrumb.svg) no-repeat center;
  background-size: 6px auto;
  width: 6px;
  height: 10px;
  display: inline-block;
  padding: 0 15px;
}
#site-breadcrumb nav ol li:last-child::after {
  content: none;
}
#site-breadcrumb nav ol li a {
  color: #A4A4A4;
}
@media only screen and (max-width: 767px) {
  #site-breadcrumb nav ol li a {
    display: inline-block;
  }
}

/*-- 各固定ページのfv画像（SPのみ表示） --*/
@media only screen and (max-width: 767px) {
  .fvImage {
    width: 100%;
    height: 200px;
    overflow: hidden;
    margin: 0 0 42px;
  }
}
@media only screen and (max-width: 767px) {
  .fvImage img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
  }
}

input[type=text],
input[type=tel],
input[type=email],
textarea, select {
  font-size: 1.5rem;
  background: #F3F7FA;
  border: 1px solid #DAE0E2;
  width: 100%;
  padding: 8px 10px;
  line-height: 1.8;
}
@media only screen and (max-width: 767px) {
  input[type=text],
  input[type=tel],
  input[type=email],
  textarea, select {
    display: block;
    margin: 0 0 5px;
    width: 100% !important;
  }
}
input[type=text]:focus,
input[type=tel]:focus,
input[type=email]:focus,
textarea:focus, select:focus {
  border: none;
  transform: scale(1.02);
}
input[type=text].s,
input[type=tel].s,
input[type=email].s,
textarea.s, select.s {
  width: 50%;
}

textarea {
  height: 150px;
}

select {
  width: 50%;
  color: #3b4d56;
}
@media only screen and (max-width: 1100px) {
  select {
    width: 80%;
  }
}
@media only screen and (max-width: 767px) {
  select {
    width: 100%;
  }
}

input[type=checkbox] {
  display: inline-block;
  width: 16px;
  height: 16px;
  margin-right: 4px;
}

input[type=submit],
input[type=reset],
button[type=submit] {
  border: none;
  color: #FFF;
  background: url(../../images/common/arw.svg) no-repeat right 30px center #C92A2A;
  font-family: "Noto Sans JP", "Yu Gothic", "游ゴシック", YuGothic, "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "MS Pゴシック", Helvetica, Arial, Verdana, sans-serif;
  font-weight: 400;
  font-feature-settings: "palt";
  letter-spacing: 0.024em;
  font-size: 1.6rem;
  display: inline-block;
  padding: 20px 12px;
  width: 35%;
  margin: 0 1%;
  border-radius: 7px;
  cursor: pointer;
  transition: all 200ms 0ms ease-in-out;
}
input[type=submit]:hover,
input[type=reset]:hover,
button[type=submit]:hover {
  background: url(../../images/common/arw.svg) no-repeat right 25px center #db5555;
}
@media only screen and (max-width: 767px) {
  input[type=submit],
  input[type=reset],
  button[type=submit] {
    display: block;
    padding: 15px;
    margin: 0 0 10px;
    font-size: 1.5rem;
    font-weight: 700;
    width: 100%;
    text-align: center;
  }
}

input[type=reset] {
  background: #93a4aa;
}

.grecaptcha-badge {
  visibility: hidden;
}

/* Block Style (theme check 対応)
------------------------------------------------------------*/
.wp-caption {
  margin: auto;
  text-align: center;
  max-width: 100%;
}

.wp-caption-text {
  display: inline-block;
  color: #8a8a8a;
  margin: 10px 0 0;
}

.gallery-caption {
  font-size: 1rem;
}

.bypostauthor {
  font-size: 1rem;
}

.alignleft {
  display: inline;
  float: left;
  margin-right: 1.5em;
}

.alignright {
  display: inline;
  float: right;
  margin-left: 1.5em;
}

.aligncenter {
  clear: both;
  display: block;
  margin-left: auto;
  margin-right: auto;
}

.alignwide {
  width: 100%;
  max-width: 100%;
  margin-left: auto;
  margin-right: auto;
  clear: both;
}

.alignfull {
  margin: 2rem calc(50% - 50vw);
  max-width: 100vw;
  width: 100vw;
}

/* Text meant only for screen readers. */
.screen-reader-text {
  clip: rect(1px, 1px, 1px, 1px);
  position: absolute !important;
  height: 1px;
  width: 1px;
  overflow: hidden;
}

#site-header {
  width: 100%;
  height: 82px;
  padding: 0 3%;
  border-top: 8px solid;
  -o-border-image: linear-gradient(to right, #174176, #004EA2, #002B59) 1;
     border-image: linear-gradient(to right, #174176, #004EA2, #002B59) 1;
  display: flex;
  flex-flow: row wrap;
  justify-content: space-between;
  align-items: center;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 999;
  /*-- logo --*/
  /*-- global navi --*/
  /*-- menu button --*/
}
@media only screen and (max-width: 1100px) {
  #site-header {
    position: absolute;
    top: 0;
    left: 0;
  }
}
@media only screen and (max-width: 767px) {
  #site-header {
    height: 60px;
  }
}
#site-header:before {
  content: "";
  width: 100%;
  height: 100%;
  background: #fff;
  transform: translateY(-80px);
  transition: all 0.2s 0.2s linear;
  position: absolute;
  top: 0;
  left: 0;
}
#site-header.is-fixed:before {
  transform: translateY(0);
}
#site-header .logo {
  position: relative;
  z-index: 2;
}
#site-header .logo img {
  width: auto;
  height: 35px;
}
@media only screen and (max-width: 1100px) {
  #site-header .logo img {
    height: 30px;
  }
}
#site-header .logo.active {
  transition: all 0.2s;
}
#site-header .logo.active img {
  filter: brightness(0) invert(1);
}
#site-header .site-navi {
  position: relative;
}
@media only screen and (max-width: 1100px) {
  #site-header .site-navi {
    position: fixed;
    top: 0;
    left: 0;
    z-index: 1;
    width: 100vw;
    height: 100vh;
    opacity: 0;
    visibility: hidden;
    background: rgb(23, 65, 118);
    background: linear-gradient(90deg, rgb(23, 65, 118) 0%, rgb(0, 78, 162) 27%, rgb(0, 43, 89) 100%);
    transition: 0.4s;
    display: block;
    padding: 82px 0;
  }
  #site-header .site-navi.active {
    opacity: 1;
    visibility: visible;
  }
}
@media only screen and (max-width: 767px) {
  #site-header .site-navi {
    padding: 60px 0;
  }
}
@media only screen and (min-width: 1101px) {
  #site-header .site-navi ul {
    display: flex;
    align-items: center;
  }
}
#site-header .site-navi ul > li {
  list-style: none;
  float: left;
  margin-left: 35px;
}
@media only screen and (max-width: 1100px) {
  #site-header .site-navi ul > li {
    float: none;
    margin: 0;
    width: 100%;
  }
}
@media only screen and (min-width: 1101px) {
  #site-header .site-navi ul > li:last-child a {
    background: url(../../images/common/arw.svg) no-repeat right 30px center #C92A2A;
    background-size: 6px auto;
    color: #FFF;
    padding: 10px 50px;
    border-radius: 8px;
    transition: all 0.2s;
  }
  #site-header .site-navi ul > li:last-child a:hover {
    background-position: right 25px center;
  }
}
#site-header .site-navi ul > li a {
  display: block;
  color: #263238;
  font-size: 1.5rem;
  font-weight: 500;
}
@media only screen and (max-width: 1100px) {
  #site-header .site-navi ul > li a {
    background: url(../../images/common/arw.svg) no-repeat right 3% center;
    background-size: 6px auto;
    color: #FFF;
    padding: 1.2rem 3%;
  }
}
@media only screen and (max-width: 1100px) {
  #site-header .site-navi ul > li a {
    padding: 1.2rem 5%;
  }
}
#site-header .site-navi__button {
  display: none;
}
@media only screen and (max-width: 1100px) {
  #site-header .site-navi__button {
    position: fixed;
    top: 0;
    right: 0;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    width: 82px;
    height: 82px;
    transition: all 0.4s;
    cursor: pointer;
    z-index: 300;
  }
  #site-header .site-navi__button span {
    display: block;
    width: 30px;
    height: 2px;
    background: #263238;
    transition: all 0.4s;
  }
  #site-header .site-navi__button span:nth-of-type(1) {
    transform: translateY(-6px);
  }
  #site-header .site-navi__button span:nth-of-type(3) {
    transform: translateY(6px);
  }
}
@media only screen and (max-width: 767px) {
  #site-header .site-navi__button {
    width: 60px;
    height: 60px;
  }
}
#site-header .site-navi__button.active {
  transition: transform 250ms ease;
}
#site-header .site-navi__button.active span {
  background: #FFF;
}
#site-header .site-navi__button.active span:nth-of-type(1) {
  transform: translateY(2px) rotate(-315deg);
}
#site-header .site-navi__button.active span:nth-of-type(2) {
  opacity: 0;
}
#site-header .site-navi__button.active span:nth-of-type(3) {
  transform: translateY(-2px) rotate(315deg);
}

/* keyframe
------------------------------------------------------------*/
@keyframes DownAnime {
  from {
    opacity: 0;
    transform: translateY(-100px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
#site-footer {
  width: 100%;
  background: rgb(23, 65, 118);
  background: linear-gradient(90deg, rgb(23, 65, 118) 0%, rgb(0, 78, 162) 27%, rgb(0, 43, 89) 100%);
  color: #FFF;
  font-size: 1.4rem;
  /*-- company --*/
  /*-- mark --*/
  /*-- copyright --*/
}
#site-footer .grid {
  padding: 55px 0 35px;
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: end;
}
@media only screen and (max-width: 1100px) {
  #site-footer .grid {
    padding: 35px 3% 25px;
  }
}
@media only screen and (max-width: 767px) {
  #site-footer .grid {
    display: block;
    padding: 35px 5% 25px;
  }
}
@media only screen and (max-width: 767px) {
  #site-footer .company {
    text-align: center;
    font-size: 1.3rem;
    margin: 0 0 18px;
  }
}
#site-footer .company figure {
  margin: 0 0 24px;
}
@media only screen and (max-width: 1100px) {
  #site-footer .company figure {
    margin: 0 0 12px;
  }
}
#site-footer .company figure img {
  width: auto;
  height: 40px;
  filter: brightness(0) invert(1);
}
@media only screen and (max-width: 1100px) {
  #site-footer .company figure img {
    height: 35px;
  }
}
#site-footer .mark {
  color: #DAE0E2;
  text-align: right;
}
@media only screen and (max-width: 767px) {
  #site-footer .mark {
    display: grid;
    grid-template-columns: 60px auto;
    gap: 10px;
    align-items: center;
    font-size: 1.2rem;
    text-align: left;
  }
}
#site-footer .mark figure {
  margin: 0 0 15px;
}
@media only screen and (max-width: 767px) {
  #site-footer .mark figure {
    margin: 0;
  }
}
#site-footer .mark figure img {
  width: auto;
  height: 74px;
}
#site-footer .copy {
  display: block;
  text-align: center;
  padding: 5px;
  font-size: 1.4rem;
  color: #FFF;
  background: #043460;
}
@media only screen and (max-width: 1100px) {
  #site-footer .copy {
    font-size: 1.3rem;
  }
}
@media only screen and (max-width: 767px) {
  #site-footer .copy {
    font-size: 1.2rem;
  }
}

#site-wrapper, #site-footer {
  position: relative;
  overflow: hidden;
}

.site-module {
  background: #F6FCFE;
}
.site-module.wrap {
  padding: 82px 5%;
}
@media only screen and (max-width: 1100px) {
  .site-module.wrap {
    padding: 62px 3%;
  }
}
@media only screen and (max-width: 767px) {
  .site-module.wrap {
    padding: 42px 5%;
  }
}
.site-module .max {
  max-width: 1400px;
}
.site-module .mid {
  max-width: 1080px;
}
.site-module .min {
  max-width: 980px;
}

.firstview {
  padding: 112px 5% 82px;
}
@media only screen and (max-width: 1100px) {
  .firstview {
    padding: 112px 3% 22px;
  }
}
@media only screen and (max-width: 767px) {
  .firstview {
    padding: 80px 5% 20px;
  }
}
.firstview .grid {
  display: grid;
  grid-template-columns: auto 58%;
  gap: 35px;
  align-items: center;
}
@media only screen and (max-width: 1366px) {
  .firstview .grid {
    grid-template-columns: auto 50%;
  }
}
@media only screen and (max-width: 820px) {
  .firstview .grid {
    gap: 5px;
  }
}
@media only screen and (max-width: 767px) {
  .firstview .grid {
    grid-template-columns: 1fr;
    text-align: center;
  }
}
.firstview .grid p {
  font-weight: 700;
  font-size: 1.8rem;
  line-height: 1.5;
  color: #349ACD;
  background: #FFF;
  text-align: center;
  padding: 3px 20px;
  border-radius: 99px;
  box-shadow: 0 0 12px rgba(24, 100, 171, 0.2);
}
@media only screen and (max-width: 1366px) {
  .firstview .grid p {
    font-size: 1.6rem;
  }
}
@media only screen and (max-width: 1024px) {
  .firstview .grid p {
    font-size: 1.5rem;
  }
}
@media only screen and (max-width: 820px) {
  .firstview .grid p {
    font-size: 1.3rem;
    padding: 3px 12px;
  }
}
@media only screen and (max-width: 767px) {
  .firstview .grid p {
    padding: 3px 30px;
  }
}
.firstview .grid p span {
  font-family: "Poppins", sans-serif;
  font-size: 3.2rem;
  font-weight: 900;
  font-style: italic;
  display: inline-block;
  margin-right: 3px;
}
@media only screen and (max-width: 1100px) {
  .firstview .grid p span {
    font-size: 1.8rem;
  }
}
@media only screen and (max-width: 767px) {
  .firstview__title {
    order: 2;
  }
}
.firstview__title strong {
  display: block;
  font-size: 5.2rem;
  font-weight: 900;
  margin: 18px 0 25px;
  line-height: 1.2;
  color: #1864AB;
}
@media only screen and (max-width: 1100px) {
  .firstview__title strong {
    font-size: 4.2rem;
  }
}
@media only screen and (max-width: 820px) {
  .firstview__title strong {
    font-size: 3rem;
  }
}
@media only screen and (max-width: 767px) {
  .firstview__title strong {
    margin: 12px 0;
    font-size: 3.2rem;
  }
}
.firstview__title strong > small {
  font-size: 4.5rem;
}
@media only screen and (max-width: 1100px) {
  .firstview__title strong > small {
    font-size: 2.5rem;
  }
}
@media only screen and (max-width: 767px) {
  .firstview__title strong > small {
    font-size: 2.2rem;
  }
}
.firstview__title > figure img {
  width: auto;
  height: 90px;
}
@media only screen and (max-width: 1100px) {
  .firstview__title > figure img {
    height: 45px;
  }
}
@media only screen and (max-width: 767px) {
  .firstview__title > figure img {
    height: 52px;
  }
}
.firstview__title .button-area {
  margin: 30px 0 0;
}
.firstview__image {
  position: relative;
  z-index: 2;
}
@media only screen and (max-width: 767px) {
  .firstview__image {
    order: 1;
  }
}
.firstview__image img {
  max-width: 100%;
  height: auto;
}
.firstview__image p {
  margin: 0 0 18px;
}
.firstview .pc {
  display: inline-block;
}
@media only screen and (max-width: 767px) {
  .firstview .pc {
    display: none;
  }
}
.firstview .sp {
  display: none;
}
@media only screen and (max-width: 767px) {
  .firstview .sp {
    display: inline-block;
  }
}

.about {
  text-align: center;
  font-size: 2.2rem;
  font-weight: 500;
  position: relative;
}
@media only screen and (max-width: 1100px) {
  .about {
    font-size: 1.8rem;
  }
}
@media only screen and (max-width: 767px) {
  .about {
    font-size: 1.6rem;
    text-align: left;
  }
}
.about .inner:after {
  content: url(../../images/common/bg.png);
  position: absolute;
  top: -350px;
  right: -680px;
}
.about__image {
  margin: 52px 0 0;
}
@media only screen and (max-width: 767px) {
  .about__image {
    margin: 32px 8% 0;
  }
}
.about__image img {
  max-width: 100%;
  height: auto;
}
@media only screen and (max-width: 767px) {
  .about__image .pc {
    display: none;
  }
}
.about__image .sp {
  display: none;
}
@media only screen and (max-width: 767px) {
  .about__image .sp {
    display: block;
  }
}

.data .inner:before, .data .inner:after {
  content: url(../../images/common/bg.png);
  position: absolute;
}
.data .inner:before {
  top: 100px;
  left: -680px;
  transform: scale(-1, 1);
}
.data .inner:after {
  bottom: -120px;
  right: -680px;
}
@media only screen and (max-width: 767px) {
  .data__logo {
    margin: 0 0 8px;
  }
}
.data__logo img {
  width: auto;
  height: 42px;
  filter: brightness(0) saturate(100%) invert(26%) sepia(100%) saturate(1302%) hue-rotate(190deg) brightness(90%) contrast(83%);
}
@media only screen and (max-width: 1100px) {
  .data__logo img {
    height: 32px;
  }
}
.data__grid {
  background: #FFF;
  border-radius: 50px;
  box-shadow: 0 0 34px rgba(0, 129, 204, 0.13);
  padding: 45px 55px;
  margin: 0 0 40px;
  display: grid;
  grid-template-columns: minmax(min-content, max-content) 1fr;
  gap: 80px;
  align-items: center;
  position: relative;
  z-index: 1;
}
@media only screen and (max-width: 1100px) {
  .data__grid {
    grid-template-columns: auto 43%;
    padding: 25px 35px;
    gap: 40px;
  }
}
@media only screen and (max-width: 767px) {
  .data__grid {
    grid-template-columns: 1fr;
    border-radius: 25px;
    padding: 25px 30px;
  }
}
@media only screen and (max-width: 767px) {
  .data__grid__data {
    order: 2;
  }
}
.data__grid__data span {
  display: inline-block;
  width: 180px;
  font-family: "Poppins", sans-serif;
  font-size: 1.5rem;
  font-weight: 600;
  color: #FFF;
  background: #1c76ca;
  padding: 2px 20px;
  border-radius: 99px;
  position: relative;
}
@media only screen and (max-width: 767px) {
  .data__grid__data span {
    width: 107px;
    font-size: 1.2rem;
    padding: 2px 10px;
  }
}
.data__grid__data span:before {
  content: "";
  width: 70px;
  height: 2px;
  background: #FFF;
  position: absolute;
  top: 50%;
  right: 20px;
  transform: translateY(-50%);
}
@media only screen and (max-width: 767px) {
  .data__grid__data span:before {
    width: 30px;
    right: 10px;
  }
}
.data__grid__data span:after {
  content: "";
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #FFF;
  position: absolute;
  top: 50%;
  right: 20px;
  transform: translateY(-50%);
}
@media only screen and (max-width: 767px) {
  .data__grid__data span:after {
    width: 7px;
    height: 7px;
    right: 10px;
  }
}
.data__grid__data strong {
  display: block;
  font-size: 3.4rem;
  font-weight: 900;
  line-height: 1.5;
  margin: 12px 0 25px;
}
@media only screen and (max-width: 1100px) {
  .data__grid__data strong {
    font-size: 2.2rem;
  }
}
@media only screen and (max-width: 767px) {
  .data__grid__data strong {
    margin: 8px 0 10px;
  }
}
.data__grid__data strong i {
  font-size: 5.4rem;
  color: #1864AB;
}
@media only screen and (max-width: 1100px) {
  .data__grid__data strong i {
    font-size: 3.2rem;
  }
}
@media only screen and (max-width: 767px) {
  .data__grid__data strong i {
    font-size: 3rem;
  }
}
.data__grid figure {
  text-align: center;
}
@media only screen and (max-width: 767px) {
  .data__grid figure {
    order: 1;
  }
}
.data__grid figure img {
  zoom: 0.45;
}
@media only screen and (max-width: 1100px) {
  .data__grid figure img {
    width: 85%;
    height: auto;
    margin: 25px auto 0;
  }
}

.function {
  background: #FFF;
}
.function__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 30px;
}
@media only screen and (max-width: 1100px) {
  .function__grid {
    grid-template-columns: 1fr;
  }
}
@media only screen and (max-width: 767px) {
  .function__grid {
    gap: 15px;
  }
}
.function__grid__data {
  background: #eef6fd;
  border-radius: 40px;
  padding: 35px;
}
@media only screen and (max-width: 1100px) {
  .function__grid__data {
    display: grid;
    grid-template-columns: 40% auto;
    gap: 40px;
    padding: 30px;
  }
}
@media only screen and (max-width: 767px) {
  .function__grid__data {
    padding: 30px 15px;
    grid-template-columns: 1fr;
    gap: 20px;
  }
}
.function__grid__data .image {
  position: relative;
  margin: 30px 0;
}
@media only screen and (max-width: 1100px) {
  .function__grid__data .image {
    display: flex;
    justify-content: center;
    align-items: center;
    margin: 0;
  }
}
@media only screen and (max-width: 767px) {
  .function__grid__data .image {
    margin: 30px 8%;
  }
}
.function__grid__data .image:before {
  content: "";
  width: 280px;
  height: 280px;
  border-radius: 50%;
  background: #d8e9f9;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
@media only screen and (max-width: 1100px) {
  .function__grid__data .image:before {
    width: 240px;
    height: 240px;
  }
}
@media only screen and (max-width: 767px) {
  .function__grid__data .image:before {
    width: 200px;
    height: 200px;
  }
}
.function__grid__data .image img {
  max-width: 100%;
  height: auto;
  position: relative;
  z-index: 2;
}
.function__grid__data dl dt {
  font-size: 1.7rem;
  font-weight: 700;
  text-align: center;
  padding: 24px 0 12px;
}
@media only screen and (max-width: 1100px) {
  .function__grid__data dl dt {
    padding: 0 0 12px;
    text-align: left;
  }
}
@media only screen and (max-width: 767px) {
  .function__grid__data dl dt {
    font-size: 1.4rem;
    text-align: center;
  }
}
.function__grid__data dl dt strong {
  display: block;
  font-size: 2.6rem;
  font-weight: 900;
  color: #1864AB;
}
@media only screen and (max-width: 767px) {
  .function__grid__data dl dt strong {
    font-size: 2.1rem;
  }
}
.function__grid__data dl dd .tag {
  display: inline-flex;
  align-items: center;
  font-size: 1.4rem;
  font-weight: 700;
  padding: 3px 12px;
  background: #FFF;
  border: 1px solid #DAE0E2;
  border-radius: 5px;
  margin-bottom: 20px;
}
@media only screen and (max-width: 1100px) {
  .function__grid__data dl dd .tag {
    font-size: 1.3rem;
  }
}
@media only screen and (max-width: 767px) {
  .function__grid__data dl dd .tag {
    font-size: 1.1rem;
    padding: 3px 8px;
    margin-bottom: 12px;
  }
}
.function__grid__data dl dd .tag img {
  display: inline-block;
  margin-right: 5px;
}
@media only screen and (max-width: 767px) {
  .function__grid__data dl dd .tag img {
    zoom: 0.75;
  }
}
.function__grid:last-of-type {
  grid-template-columns: repeat(4, 1fr);
  margin: 52px 0 0;
}
@media only screen and (max-width: 1100px) {
  .function__grid:last-of-type {
    grid-template-columns: repeat(2, 1fr);
    gap: 30px;
    margin: 30px 0 0;
  }
}
@media only screen and (max-width: 767px) {
  .function__grid:last-of-type {
    grid-template-columns: 1fr;
    margin: 15px 0 0;
  }
}
.function__grid:last-of-type .function__grid__data {
  display: grid;
  grid-template-rows: 230px auto auto;
  padding: 20px 35px 35px;
}
@media only screen and (max-width: 1100px) {
  .function__grid:last-of-type .function__grid__data {
    grid-template-columns: 1fr;
    grid-template-rows: 150px auto auto;
    gap: 15px;
    padding: 20px;
  }
}
.function__grid:last-of-type .function__grid__data .image {
  display: grid;
  place-content: center;
  margin: 0;
}
.function__grid:last-of-type .function__grid__data .image::before {
  width: 194px;
  height: 194px;
}
@media only screen and (max-width: 1100px) {
  .function__grid:last-of-type .function__grid__data .image::before {
    width: 150px;
    height: 150px;
  }
}
.function__grid:last-of-type .function__grid__data .image img {
  zoom: 0.5;
}
@media only screen and (max-width: 1100px) {
  .function__grid:last-of-type .function__grid__data .image img {
    zoom: 0.35;
  }
}
@media only screen and (max-width: 767px) {
  .function__grid:last-of-type .function__grid__data .image img {
    zoom: 0.3;
  }
}
.function__grid:last-of-type .function__grid__data dl dt {
  padding: 5px 0;
}
@media only screen and (max-width: 1100px) {
  .function__grid:last-of-type .function__grid__data dl dt strong {
    font-size: 2rem;
  }
}
@media only screen and (max-width: 767px) {
  .function__grid:last-of-type .function__grid__data:nth-of-type(2) img {
    zoom: 0.33;
  }
  .function__grid:last-of-type .function__grid__data:nth-of-type(3) img {
    zoom: 0.38;
  }
}

.voice__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 45px;
}
@media only screen and (max-width: 1100px) {
  .voice__grid {
    gap: 12px;
  }
}
@media only screen and (max-width: 767px) {
  .voice__grid {
    grid-template-columns: 1fr;
    gap: 20px;
  }
}
.voice__grid__data {
  border: 2px solid #5092CF;
  border-radius: 40px 40px 40px 0;
  padding: 30px;
  background: #FFF;
}
@media only screen and (max-width: 1100px) {
  .voice__grid__data {
    padding: 20px;
  }
}
@media only screen and (max-width: 767px) {
  .voice__grid__data {
    border-radius: 20px 20px 20px 0;
  }
}
.voice__grid__data dt {
  font-size: 2rem;
  font-weight: 900;
  color: #1864AB;
  line-height: 1.4;
  display: grid;
  grid-template-columns: 72px auto;
  align-items: center;
  gap: 18px;
  margin: 0 0 20px;
}
@media only screen and (max-width: 1100px) {
  .voice__grid__data dt {
    display: block;
    font-size: 1.7rem;
  }
}
@media only screen and (max-width: 767px) {
  .voice__grid__data dt {
    display: grid;
    grid-template-columns: 25% auto;
    gap: 15px;
    margin: 0 0 12px;
    font-size: 1.6rem;
  }
}
@media only screen and (max-width: 1100px) {
  .voice__grid__data dt figure {
    width: 42%;
    margin: 0 auto 10px;
  }
}
@media only screen and (max-width: 767px) {
  .voice__grid__data dt figure {
    width: auto;
  }
}
.voice__grid__data dt figure img {
  width: 100%;
  height: auto;
}

.price .inner {
  max-width: 1400px;
}
.price .inner:after {
  content: url(../../images/common/bg.png);
  transform: scale(-1, 1);
  position: absolute;
  bottom: -180px;
  left: -680px;
}
.price .inner_box {
  background: #FFF;
  border-radius: 27px;
  padding: 60px;
  position: relative;
  z-index: 1;
}
@media only screen and (max-width: 1100px) {
  .price .inner_box {
    padding: 50px 30px;
  }
}
@media only screen and (max-width: 767px) {
  .price .inner_box {
    padding: 30px 5%;
  }
}
.price__box {
  max-width: 70%;
  border: 3px solid #1c76ca;
  border-radius: 30px;
  padding: 30px 10%;
  margin: 0 auto;
}
@media only screen and (max-width: 1100px) {
  .price__box {
    width: 85%;
    max-width: 620px;
    padding: 30px;
  }
}
@media only screen and (max-width: 767px) {
  .price__box {
    width: 100%;
    padding: 20px;
    border-radius: 20px;
  }
}
.price__box .title {
  font-size: 2.2rem;
  font-weight: 700;
  background: #1c76ca;
  padding: 10px;
  margin: 0 0 15px;
  text-align: center;
  color: #FFF;
  border-radius: 10px;
}
@media only screen and (max-width: 1100px) {
  .price__box .title {
    font-size: 1.8rem;
    padding: 8px;
  }
}
@media only screen and (max-width: 1100px) {
  .price__box .title {
    font-size: 1.6rem;
    padding: 5px;
  }
}
.price__box .fee {
  display: flex;
  flex-flow: row wrap;
  justify-content: space-between;
  align-items: center;
}
@media only screen and (max-width: 767px) {
  .price__box .fee {
    display: block;
  }
}
.price__box .fee dt {
  font-size: 1.8rem;
  font-weight: 700;
  width: 25%;
  background: #DBEBFF;
  text-align: center;
  border-radius: 99px;
  padding: 5px;
}
@media only screen and (max-width: 767px) {
  .price__box .fee dt {
    width: 100%;
    font-size: 1.4rem;
  }
}
.price__box .fee dd {
  font-family: "Poppins", sans-serif;
  font-size: 4.6rem;
  font-weight: 700;
}
@media only screen and (max-width: 767px) {
  .price__box .fee dd {
    text-align: center;
    font-size: 3.5rem;
    line-height: 1.5;
  }
}
.price__box .fee dd.min {
  padding-right: 62px;
}
@media only screen and (max-width: 1100px) {
  .price__box .fee dd.min {
    padding-right: 52px;
  }
}
@media only screen and (max-width: 767px) {
  .price__box .fee dd.min {
    padding: 0;
  }
}
.price__box .fee dd span {
  font-size: 3rem;
  display: inline-block;
  margin-left: 5px;
}
@media only screen and (max-width: 767px) {
  .price__box .fee dd span {
    font-size: 2rem;
  }
}
.price__box .fee dd small {
  display: inline-block;
  font-family: "Noto Sans JP", "Yu Gothic", "游ゴシック", YuGothic, "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "MS Pゴシック", Helvetica, Arial, Verdana, sans-serif;
  font-weight: 400;
  font-feature-settings: "palt";
  letter-spacing: 0.024em;
  font-size: 1.8rem;
  margin-left: 8px;
}
@media only screen and (max-width: 1100px) {
  .price__box .fee dd small {
    font-size: 1.3rem;
  }
}
@media only screen and (max-width: 767px) {
  .price__box .fee dd small {
    display: inline-block;
    font-size: 1.2rem;
  }
}
.price__box ul {
  margin: 20px 0;
}
@media only screen and (max-width: 1100px) {
  .price__box ul {
    margin: 8px 0 18px;
  }
}
.price__box ul li {
  font-weight: 700;
}
.price__box ul li:before {
  content: "・";
  display: inline-block;
}
.price__box small {
  display: block;
  font-size: 1.4rem;
  text-align: center;
  margin: 24px 0 0;
}
@media only screen and (max-width: 1100px) {
  .price__box small {
    margin-top: 15px;
  }
}
@media only screen and (max-width: 1100px) {
  .price__box small {
    font-size: 1.2rem;
  }
}

.flow__data {
  background: #FFF;
  padding: 15px 30px 15px 0;
  margin: 0 0 42px;
  border-radius: 20px;
  display: grid;
  grid-template-columns: 10% 23% auto;
  gap: 45px;
  align-items: center;
  position: relative;
}
@media only screen and (max-width: 767px) {
  .flow__data {
    grid-template-columns: 30% auto;
    gap: 8px 30px;
    padding: 15px;
    margin: 0 0 32px;
  }
}
.flow__data:after {
  content: "";
  width: 60px;
  height: 15px;
  -webkit-clip-path: polygon(0 0, 50% 100%, 100% 0);
          clip-path: polygon(0 0, 50% 100%, 100% 0);
  background: #cae2f8;
  position: absolute;
  bottom: -30px;
  left: 50%;
  transform: translateX(-50%);
}
@media only screen and (max-width: 767px) {
  .flow__data:after {
    width: 40px;
    height: 12px;
    bottom: -23px;
  }
}
.flow__data:last-of-type {
  margin-bottom: 0;
}
.flow__data:last-of-type:after {
  content: none;
}
.flow__data__step {
  font-family: "Poppins", sans-serif;
  font-size: 1.4rem;
  font-weight: 700;
  color: #1864AB;
  letter-spacing: 4px;
  text-align: center;
  border-right: 1px solid #1864AB;
}
.flow__data__step > strong {
  display: block;
  font-size: 3rem;
  line-height: 1;
}
@media only screen and (max-width: 767px) {
  .flow__data__step > strong {
    font-size: 2.2rem;
  }
}
.flow__data__title {
  font-size: 2rem;
  font-weight: 900;
  color: #1864AB;
}
@media only screen and (max-width: 767px) {
  .flow__data__title {
    font-size: 1.7rem;
  }
}
.flow__data p {
  font-size: 1.8rem;
}
@media only screen and (max-width: 767px) {
  .flow__data p {
    grid-column: span 2/span 2;
    font-size: 1.4rem;
  }
}

.ctv {
  padding-top: 0;
}
.ctv_box {
  max-width: 1300px;
  margin: 0 auto;
  padding: 95px 5%;
  background: rgb(23, 65, 118);
  background: linear-gradient(90deg, rgb(23, 65, 118) 0%, rgb(0, 78, 162) 27%, rgb(0, 43, 89) 100%);
  border-radius: 27px;
  overflow: hidden;
  position: relative;
}
@media only screen and (max-width: 1100px) {
  .ctv_box {
    padding: 60px 5%;
  }
}
@media only screen and (max-width: 767px) {
  .ctv_box {
    padding: 32px 5%;
  }
}
.ctv_box:after {
  content: url(../../images/content/ctv_bg.png);
  zoom: 0.5;
  position: absolute;
  top: -10vw;
  right: -16vw;
}
.ctv .inner {
  display: flex;
  flex-flow: row wrap;
  justify-content: space-between;
  align-items: center;
  position: relative;
  z-index: 5;
}
@media only screen and (max-width: 767px) {
  .ctv .inner {
    display: block;
  }
}
.ctv__data {
  font-size: 3.8rem;
  font-weight: 700;
  line-height: 1.6;
  color: #FFF;
}
@media only screen and (max-width: 1100px) {
  .ctv__data {
    font-size: 2rem;
  }
}
@media only screen and (max-width: 767px) {
  .ctv__data {
    font-size: 1.7rem;
    margin: 0 0 18px;
  }
}
.ctv__data__image {
  display: inline-block;
}
.ctv__data__image img {
  filter: brightness(0) invert(1);
  width: auto;
  height: 60px;
}
@media only screen and (max-width: 1100px) {
  .ctv__data__image img {
    height: 35px;
  }
}
@media only screen and (max-width: 767px) {
  .ctv__data__image img {
    height: 30px;
  }
}
.ctv__data strong {
  display: block;
  font-size: 4rem;
}
@media only screen and (max-width: 1100px) {
  .ctv__data strong {
    font-size: 2.6rem;
  }
}
@media only screen and (max-width: 767px) {
  .ctv__data strong {
    font-size: 2rem;
  }
}

.sales {
  background: rgb(23, 65, 118);
  background: linear-gradient(90deg, rgb(23, 65, 118) 0%, rgb(0, 78, 162) 27%, rgb(0, 43, 89) 100%);
  padding: 82px 3%;
}
@media only screen and (max-width: 767px) {
  .sales {
    padding: 32px 3%;
  }
}
.sales__outer {
  max-width: 1800px;
  margin: 0 auto;
  background: #FFF;
  border-radius: 50px;
  padding: 62px 30px 82px;
}
@media only screen and (max-width: 767px) {
  .sales__outer {
    padding: 32px 5%;
  }
}
.sales__box {
  margin: 0 0 82px;
}
@media only screen and (max-width: 1100px) {
  .sales__box {
    margin: 0 0 52px;
  }
}
@media only screen and (max-width: 767px) {
  .sales__box {
    margin: 0 0 32px;
  }
}
.sales__box figure img {
  max-width: 100%;
  height: auto;
}
.sales__box figure .pc {
  display: block;
}
@media only screen and (max-width: 767px) {
  .sales__box figure .pc {
    display: none;
  }
}
.sales__box figure .sp {
  display: none;
}
@media only screen and (max-width: 767px) {
  .sales__box figure .sp {
    display: block;
  }
}
.sales__box:first-of-type {
  display: grid;
  grid-template-columns: auto 45%;
  align-items: center;
  gap: 180px;
  padding-bottom: 52px;
  border-bottom: 1px dashed #DAE0E2;
  position: relative;
}
@media only screen and (max-width: 1366px) {
  .sales__box:first-of-type {
    gap: 70px;
  }
}
@media only screen and (max-width: 1100px) {
  .sales__box:first-of-type {
    gap: 50px;
  }
}
@media only screen and (max-width: 767px) {
  .sales__box:first-of-type {
    grid-template-columns: 1fr;
    gap: 0;
    padding-bottom: 32px;
  }
}
.sales__box:first-of-type .sub {
  width: 100%;
  padding: 0;
  text-align: center;
  position: absolute;
  top: 0;
  left: 0;
}
@media only screen and (max-width: 1100px) {
  .sales__box:first-of-type .sub {
    top: -10px;
  }
}
@media only screen and (max-width: 767px) {
  .sales__box:first-of-type .sub {
    top: 0;
  }
}
.sales__box:first-of-type .sub img {
  max-width: 100%;
  height: auto;
}
.sales__box:first-of-type figure {
  padding: 60px 0 0;
  position: relative;
  z-index: 1;
}
@media only screen and (max-width: 1100px) {
  .sales__box:first-of-type figure {
    padding: 24px 0 0;
  }
}
@media only screen and (max-width: 767px) {
  .sales__box:first-of-type figure {
    order: 1;
    padding: 12px 0 0;
  }
}
@media only screen and (max-width: 767px) {
  .sales__box:first-of-type .sales__box__data {
    order: 2;
  }
}
.sales__box:first-of-type .sales__box__data hgroup {
  margin-bottom: 20px;
}
@media only screen and (max-width: 767px) {
  .sales__box:first-of-type .sales__box__data hgroup {
    text-align: center;
  }
}
.sales__box:first-of-type .sales__box__data hgroup h2 {
  font-size: 5.4rem;
  line-height: 1.3;
}
@media only screen and (max-width: 1100px) {
  .sales__box:first-of-type .sales__box__data hgroup h2 {
    font-size: 3.4rem;
  }
}
.sales__box:first-of-type .sales__box__data hgroup h2 > span {
  font-size: 4.4rem;
}
@media only screen and (max-width: 1100px) {
  .sales__box:first-of-type .sales__box__data hgroup h2 > span {
    font-size: 2.2rem;
  }
}
.sales__box:first-of-type .sales__box__data hgroup small {
  font-size: 2.8rem;
  font-weight: 700;
  color: #1864AB;
}
@media only screen and (max-width: 1100px) {
  .sales__box:first-of-type .sales__box__data hgroup small {
    font-size: 2rem;
  }
}
@media only screen and (max-width: 767px) {
  .sales__box:first-of-type .sales__box__data hgroup small {
    font-size: 2.2rem;
    font-weight: 900;
  }
}
.sales__box:first-of-type .sales__box__data .point {
  background: #dcecfa;
  display: grid;
  grid-template-columns: 50px auto;
  align-items: center;
  gap: 20px;
  padding: 20px 30px;
  border-radius: 10px;
}
@media only screen and (max-width: 1100px) {
  .sales__box:first-of-type .sales__box__data .point {
    padding: 20px;
  }
}
@media only screen and (max-width: 767px) {
  .sales__box:first-of-type .sales__box__data .point {
    grid-template-columns: 35px auto;
    gap: 12px;
  }
}
.sales__box:first-of-type .sales__box__data .point figure {
  padding: 0;
}
@media only screen and (max-width: 767px) {
  .sales__box:first-of-type .sales__box__data .point figure {
    order: initial;
  }
}
.sales__box:first-of-type .sales__box__data .point figcaption {
  font-size: 1.8rem;
  font-weight: 700;
}
@media only screen and (max-width: 1100px) {
  .sales__box:first-of-type .sales__box__data .point figcaption {
    font-size: 1.5rem;
  }
  .sales__box:first-of-type .sales__box__data .point figcaption br {
    display: none;
  }
}
@media only screen and (max-width: 767px) {
  .sales__box:first-of-type .sales__box__data .point figcaption {
    font-size: 1.4rem;
    line-height: 1.4;
  }
}
.sales__box:nth-of-type(2) .sales__box__title {
  text-align: center;
  font-size: 3rem;
  font-weight: 900;
  margin: 0 0 30px;
}
@media only screen and (max-width: 1100px) {
  .sales__box:nth-of-type(2) .sales__box__title {
    font-size: 2.2rem;
  }
}
@media only screen and (max-width: 767px) {
  .sales__box:nth-of-type(2) .sales__box__title {
    font-size: 1.6rem;
  }
}
.sales__box:nth-of-type(2) .sales__box__title .subtitle {
  display: block;
  width: 38%;
  background: #D1FF1A;
  font-size: 2rem;
  padding: 10px 30px;
  margin: 0 auto 20px;
  border-radius: 99px;
}
@media only screen and (max-width: 1100px) {
  .sales__box:nth-of-type(2) .sales__box__title .subtitle {
    width: 70%;
    font-size: 1.7rem;
  }
}
@media only screen and (max-width: 767px) {
  .sales__box:nth-of-type(2) .sales__box__title .subtitle {
    width: 100%;
    font-size: 1.4rem;
    padding: 8px 15px;
  }
}
.sales__box:nth-of-type(2) .sales__box__title .tab {
  display: inline-block;
  font-size: 2.4rem;
  color: #1864AB;
  background-color: #dcecfa;
  background-position: left 20px center;
  background-repeat: no-repeat;
  padding: 10px 20px 10px 55px;
  border-radius: 6px;
}
@media only screen and (max-width: 1100px) {
  .sales__box:nth-of-type(2) .sales__box__title .tab {
    font-size: 1.8rem;
    padding: 8px 15px 8px 55px;
  }
}
@media only screen and (max-width: 767px) {
  .sales__box:nth-of-type(2) .sales__box__title .tab {
    font-size: 1.5rem;
    background-position: left 15px center;
    background-size: 20px auto;
    padding: 5px 15px 5px 42px;
    margin: 0 0 5px;
  }
}
.sales__box:nth-of-type(2) .sales__box__title .tab.icon1 {
  background-image: url(../../images/content/sales_icon_01.svg);
}
.sales__box:nth-of-type(2) .sales__box__title .tab.icon2 {
  background-image: url(../../images/content/sales_icon_02.svg);
}
.sales__box:nth-of-type(2) .sales__box__title .tab.icon3 {
  background-image: url(../../images/content/sales_icon_03.svg);
}
.sales__box:nth-of-type(2) .note {
  display: block;
  font-size: 1.5rem;
  font-weight: 600;
  padding-left: 20px;
  position: relative;
}
@media only screen and (max-width: 1100px) {
  .sales__box:nth-of-type(2) .note {
    font-size: 1.3rem;
  }
}
@media only screen and (max-width: 767px) {
  .sales__box:nth-of-type(2) .note {
    padding: 0;
  }
}
.sales__box:nth-of-type(2) .note:before {
  content: "※";
  display: inline-block;
  margin-right: 5px;
}
.sales__box:last-of-type {
  margin-bottom: 0;
}

.faq {
  position: relative;
  overflow: hidden;
}
.faq .inner::after {
  content: url(../../images/common/bg.png);
  position: absolute;
  top: -280px;
  right: -780px;
}
.faq dl {
  margin: 0 auto 15px;
}
.faq dl:last-of-type {
  margin-bottom: 0;
}
.faq dl dt {
  position: relative;
  cursor: pointer;
  font-size: 2.2rem;
  font-weight: 700;
  background: #1864AB;
  color: #FFF;
  border-radius: 8px;
  padding: 8px 24px;
}
@media only screen and (max-width: 1100px) {
  .faq dl dt {
    font-size: 1.6rem;
  }
}
@media only screen and (max-width: 767px) {
  .faq dl dt {
    padding: 8px 40px 8px 15px;
    font-size: 1.4rem;
    line-height: 1.4;
  }
}
.faq dl dt:before, .faq dl dt:after {
  content: "";
  position: absolute;
  right: 24px;
  top: 0;
  bottom: 0;
  margin: auto 0;
  background-color: #FFF;
  width: 20px;
  height: 3px;
  transition: all 0.3s;
}
@media only screen and (max-width: 767px) {
  .faq dl dt:before, .faq dl dt:after {
    right: 15px;
    width: 15px;
    height: 2px;
  }
}
.faq dl dt:after {
  transform: rotate(90deg);
}
.faq dl dt span {
  font-family: "Poppins", sans-serif;
  display: inline-block;
  margin-right: 12px;
  font-size: 2.7rem;
  font-weight: 500;
}
@media only screen and (max-width: 1100px) {
  .faq dl dt span {
    font-size: 2.2rem;
  }
}
@media only screen and (max-width: 767px) {
  .faq dl dt span {
    font-size: 2rem;
    margin-right: 8px;
  }
}
.faq dl dt.is-active:before {
  transform: rotate(180deg);
}
.faq dl dt.is-active:after {
  transform: rotate(180deg);
  opacity: 0;
}
.faq dl dd {
  display: none;
  font-weight: 400;
  margin: 12px 0 0;
  padding: 20px;
  font-size: 1.8rem;
  background: #FFF;
  border-radius: 10px;
  box-shadow: 0 0 14px rgba(24, 100, 171, 0.2);
  position: relative;
}
@media only screen and (max-width: 767px) {
  .faq dl dd {
    padding-top: 15px;
    font-size: 1.4rem;
    line-height: 1.4;
  }
}

.inquery .inner {
  z-index: 1;
}
.inquery .form-area {
  background: #FFF;
  border-radius: 30px;
  padding: 50px 100px;
  position: relative;
  z-index: 1;
}
@media only screen and (max-width: 1100px) {
  .inquery .form-area {
    width: 100%;
    padding: 30px;
  }
}
@media only screen and (max-width: 767px) {
  .inquery .form-area {
    padding: 30px 20px;
  }
}
.inquery .form-area dl {
  display: grid;
  grid-template-columns: 22% auto;
  gap: 20px;
  margin: 0 0 25px;
}
@media only screen and (max-width: 767px) {
  .inquery .form-area dl {
    display: block;
  }
}
.inquery .form-area dl dt {
  font-weight: 600;
  position: relative;
}
@media only screen and (max-width: 767px) {
  .inquery .form-area dl dt {
    margin: 0 0 12px;
  }
}
.inquery .form-area dl dt:after {
  content: "任意";
  display: inline-block;
  font-size: 1.2rem;
  padding: 0 12px;
  border: 1px solid #a1b0b5;
  color: #a1b0b5;
  position: absolute;
  top: 4px;
  right: 0;
}
.inquery .form-area dl dt.hiss::after {
  content: "必須";
  border: 1px solid #C92A2A;
  color: #C92A2A;
}
.inquery .form-area .privacy-area {
  text-align: center;
}
@media only screen and (max-width: 767px) {
  .inquery .form-area .privacy-area {
    text-align: left;
    font-size: 1.3rem;
  }
}
.inquery .form-area .privacy-area a {
  background: url(../../images/content/inquery_icon_01.svg) no-repeat right center;
  padding-right: 18px;
  margin-right: 4px;
}
.inquery .form-area .privacy-area small {
  display: block;
}
.inquery .form-area .privacy-area .sp {
  display: none;
}
@media only screen and (max-width: 1100px) {
  .inquery .form-area .privacy-area .sp {
    display: block;
  }
}
@media only screen and (max-width: 767px) {
  .inquery .form-area .privacy-area .sp {
    display: none;
  }
}
.inquery .form-area .alert {
  font-size: 1.4rem;
  color: #C92A2A;
  position: relative;
}
.inquery .form-area .alert:before {
  content: "※";
  display: inline-block;
}
.inquery .button-area {
  margin: 32px 0 0;
}
.inquery .button-area.center {
  margin-bottom: 120px;
}
@media only screen and (max-width: 767px) {
  .inquery .button-area.center {
    margin-bottom: 30px;
  }
}
.inquery .align-center {
  text-align: center;
  margin: 120px 0 62px;
}
@media only screen and (max-width: 767px) {
  .inquery .align-center {
    text-align: left;
    margin: 120px 0 32px;
  }
}
.inquery.bg {
  position: relative;
}
.inquery.bg .inner::after {
  content: url(../../images/common/bg.png);
  transform: scale(-1, 1) translateY(-50%);
  position: absolute;
  top: 50%;
  left: -680px;
}/*# sourceMappingURL=style.css.map */