@charset "UTF-8";
@import url("https://fonts.googleapis.com/earlyaccess/notosansjp.css");
@import url("https://fonts.googleapis.com/css2?family=Open+Sans:wght@400;700&display=swap");
a {
  color: #c30e23;
  transition-duration: 0.2s;
}
a:hover {
  opacity: 0.85;
}

/* ----------------------------------------------------------
reset
---------------------------------------------------------- */
body, h1, h2, h3, h4, h5, h6, p, ol, ul, li, blockquote, pre, a, div {
  font-family: "Noto Sans JP", "游ゴシック", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;
  margin: 0;
  padding: 0;
  font-size: 100%;
  line-height: inherit;
  box-sizing: border-box;
}

body {
  -webkit-text-size-adjust: 100%;
  line-height: 1;
}

ol, ul {
  list-style: none;
}

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

th, td {
  vertical-align: top;
  text-align: left;
  font-weight: normal;
}

img {
  border: 0;
  vertical-align: bottom;
}

a {
  text-decoration: none;
}

/* ----------------------------------------------------------
.mod
---------------------------------------------------------- */
.mod-visible {
  visibility: visible;
}

.mod-hidden {
  visibility: hidden;
}

.mod-sp {
  display: none !important;
}

@media screen and (max-width: 767px) {
  .mod-pc {
    display: none !important;
  }
  .mod-sp {
    display: block !important;
  }
}
.mod-en {
  font-family: "Open Sans", serif;
}

.mod-min {
  font-family: "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "ＭＳ Ｐ明朝", "MS PMincho", serif;
}

/* ----------------------------------------------------------
.slick-slider
---------------------------------------------------------- */
.slick-slider {
  position: relative;
  display: block;
  box-sizing: border-box;
  user-select: none;
  touch-action: pan-y;
  -webkit-tap-highlight-color: transparent;
}
.slick-slider li {
  list-style: none;
}
.slick-slider .slick-list {
  position: relative;
  overflow: hidden;
  display: block;
  margin: 0;
  padding: 0;
}
.slick-slider .slick-list:focus {
  outline: none;
}
.slick-slider .slick-list.dragging {
  cursor: pointer;
  cursor: hand;
}
.slick-slider .slick-track,
.slick-slider .slick-list {
  transform: translate3d(0, 0, 0);
}
.slick-slider .slick-track {
  position: relative;
  left: 0;
  top: 0;
  display: block;
}
.slick-slider .slick-track:before, .slick-slider .slick-track:after {
  content: "";
  display: table;
}
.slick-slider .slick-track:after {
  clear: both;
}
.slick-loading .slick-slider .slick-track {
  visibility: hidden;
}

.slick-slide {
  float: left;
  height: 100%;
  min-height: 1px;
  display: none;
}
[dir=rtl] .slick-slide {
  float: right;
}
.slick-slide img {
  display: block;
}
.slick-slide.slick-loading img {
  display: none;
}
.slick-slide.dragging img {
  pointer-events: none;
}
.slick-initialized .slick-slide {
  display: block;
}
.slick-loading .slick-slide {
  visibility: hidden;
}
.slick-vertical .slick-slide {
  display: block;
  height: auto;
  border: 1px solid transparent;
}

.slick-arrow.slick-hidden {
  display: none;
}

/* ----------------------------------------------------------
.slider
---------------------------------------------------------- */
.mod-slider-mv .slick-dots {
  position: absolute;
  left: 0px;
  bottom: 0px;
  text-align: center;
  padding: 5px;
}
.mod-slider-mv .slick-dots li {
  display: inline-block;
  width: 10px;
  height: 10px;
  background: #ccc;
  margin: 0 5px;
  border-radius: 5px;
}
.mod-slider-mv .slick-dots li button {
  display: none;
}
.mod-slider-mv .slick-dots li.slick-active {
  background: #888;
}
.mod-slider-mv ._item {
  display: flex;
  position: relative;
}
.mod-slider-mv ._item ._image {
  flex: 1;
}
.mod-slider-mv ._item ._texts {
  flex: 1;
  margin: 0 0 0 10px;
}

@media print, screen and (min-width: 768px) {
  .container {
    overflow: hidden;
  }
  /* ----------------------------------------------------------
  .header
  ---------------------------------------------------------- */
  .area-header-wrap {
    height: 127px;
    position: relative;
    z-index: 10;
  }
  .area-header {
    position: relative;
  }
  .area-header img {
    width: 100%;
  }
  .area-header ._inner {
    padding: 10px 0 0 0;
    position: relative;
    display: flex;
    justify-content: space-between;
  }
  .area-header ._inner-left {
    width: 100px;
    display: flex;
    gap: 10px;
    flex-direction: column;
  }
  .area-header ._inner-right {
    display: flex;
    gap: 10px;
    flex-direction: column;
    align-items: center;
  }
  .area-header ._btns {
    display: flex;
    justify-content: space-between;
    box-shadow: 0px 2px 10px rgba(0, 0, 0, 0.25);
  }
  .area-header ._logo {
    width: 302px;
  }
  .area-header ._btn {
    cursor: pointer;
    transition-duration: 0.2s;
  }
  .area-header ._btn:hover {
    filter: brightness(1.1);
  }
  .area-header ._btn-tel,
  .area-header ._btn-web,
  .area-header ._btn-sec {
    width: 180px;
  }
  .area-header ._sub {
    width: 293px;
  }
  .area-header ._sub2 {
    width: 403px;
  }
  .mod-menu-btn-sp {
    display: none;
  }
  .area-menu {
    padding: 20px 0 10px 10px;
  }
  .area-menu ._link {
    display: flex;
    gap: 10px;
    line-height: 1.75;
  }
  .area-menu ._link a {
    letter-spacing: 0.1em;
    color: #231815;
  }
  /* ----------------------------------------------------------
  footer
  ---------------------------------------------------------- */
  /* ----------------------------------------------------------
  .block01
  ---------------------------------------------------------- */
  /* ----------------------------------------------------------
  .block-form
  ---------------------------------------------------------- */
  /* ----------------------------------------------------------
  .block-contact-form input forms
  ---------------------------------------------------------- */
}
@media print, screen and (min-width: 768px) and (min-width: 901px) {
  .area-menu ._link a {
    font-size: 17px;
  }
}
@media screen and (min-width: 768px) and (min-width: 768px) and (max-width: 900px) {
  .area-menu ._link a {
    font-size: 0.8854166667vw;
  }
}
@media print, screen and (min-width: 768px) {
  .area-menu ._link a span.is-A {
    color: #E4007F;
  }
  .area-menu ._link a span.is-B {
    color: #00A0E9;
  }
  .area-modal-menu {
    display: none;
  }
  .area-footer-btn-sp {
    display: none;
  }
  .block-copy {
    padding: 30px 0;
    background: #23438A;
    text-align: center;
    color: #fff;
    line-height: 1.4;
  }
  .block-copy small {
    font-size: 18px;
  }
  .btn-pagetop {
    position: fixed;
    display: block;
    text-align: center;
    cursor: pointer;
    bottom: 20px;
    right: 20px;
    width: 100px;
    height: 100px;
  }
  .btn-pagetop img {
    width: 100%;
  }
  .block-footer {
    background-color: #fff;
    padding: 80px 0 100px 0;
    text-align: center;
  }
  .block-footer img {
    width: 100%;
  }
  .block-footer ._logo {
    display: block;
    width: 433px;
    margin: 0 auto;
  }
  body {
    background-color: #fff;
    color: #23438A;
  }
  body img {
    width: 100%;
  }
  ._inner {
    max-width: 900px;
    margin: 0 auto;
  }
}
@media print, screen and (min-width: 768px) and (min-width: 1920px) {
  ._inner {
    max-width: 46.875vw;
  }
}
@media print, screen and (min-width: 768px) {
  .block-01-10 {
    text-align: center;
  }
  .block-11-20 {
    text-align: center;
  }
  .block-21-30 {
    text-align: center;
  }
  .block-01 {
    position: relative;
    z-index: 100;
  }
  .block-01 ._inner {
    position: relative;
  }
  .block-01 ._inner:after {
    display: block;
    content: "";
    padding-top: 94.6666666667%;
  }
  .block-01 ._scenes {
    position: relative;
  }
  .block-01 ._scene1 {
    background: url(../images/block01/bg2.jpg?) center top no-repeat;
    background-size: cover;
  }
  .block-01 ._scene1 ._p {
    position: absolute;
    top: 0%;
    left: 0.44%;
    width: 101.56%;
    height: 100.94%;
  }
  .block-01 ._scene2 {
    background: url(../images/block01/bg.jpg) center top no-repeat;
    background-size: cover;
  }
  .block-01 ._scene2 ._p {
    position: absolute;
    top: -1.29%;
    left: 2.67%;
    width: 97.33%;
    height: 100.7%;
  }
  .block-01 ._scene2 {
    position: absolute;
    inset: 0;
    opacity: 0;
    animation: infinite_loop 10s ease-in-out 0s infinite;
  }
  @keyframes infinite_loop {
    0% {
      opacity: 0;
    }
    40% {
      opacity: 0;
    }
    50% {
      opacity: 1;
    }
    90% {
      opacity: 1;
    }
    100% {
      opacity: 0;
    }
  }
  .block-02 {
    background: url(../images/block02/bg.jpg?) center top no-repeat;
    background-size: cover;
  }
  .block-02 ._inner {
    position: relative;
  }
  .block-02 ._inner:after {
    display: block;
    content: "";
    padding-top: 53.7777777778%;
  }
  .block-02 ._inner ._p1 {
    position: absolute;
    top: 7.85%;
    left: 29.89%;
    width: 67%;
    height: 79.34%;
  }
  .block-02 ._inner ._btn {
    position: absolute;
    top: 56.82%;
    left: 45.11%;
    width: 55%;
    height: 26.45%;
  }
  .block-03 {
    background: url(../images/block03/bg.jpg?) center top no-repeat;
    background-size: cover;
  }
  .block-03 ._inner {
    position: relative;
  }
  .block-03 ._inner:after {
    display: block;
    content: "";
    padding-top: 141.8888888889%;
  }
  .block-03 ._inner ._p1 {
    position: absolute;
    top: 19.66%;
    left: 2.33%;
    width: 92.67%;
    height: 80.19%;
  }
  .block-03 ._inner ._title {
    position: absolute;
    top: 1.49%;
    left: 2.33%;
    width: 94.89%;
    height: 16.21%;
  }
  .block-04 {
    background: url(../images/block04/bg.jpg?) center top no-repeat;
    background-size: cover;
  }
  .block-04 ._inner {
    position: relative;
  }
  .block-04 ._inner:after {
    display: block;
    content: "";
    padding-top: 57.1111111111%;
  }
  .block-04 ._inner ._p1 {
    position: absolute;
    top: 1.95%;
    left: 22.78%;
    width: 73.89%;
    height: 89.88%;
  }
  .block-04 ._inner ._btn {
    position: absolute;
    top: 10.51%;
    left: 17.89%;
    width: 73.22%;
    height: 33.07%;
  }
  .block-05 {
    background: url(../images/block05/bg.jpg?) center top no-repeat;
    background-size: cover;
  }
  .block-05 ._inner {
    position: relative;
  }
  .block-05 ._inner:after {
    display: block;
    content: "";
    padding-top: 123.1111111111%;
  }
  .block-05 ._inner ._texts {
    position: absolute;
    top: 15.88%;
    left: 2.56%;
    width: 97.56%;
    height: 79.33%;
  }
  .block-05 ._inner ._title {
    position: absolute;
    top: 5.42%;
    left: 2.67%;
    width: 57.56%;
    height: 6.77%;
  }
  .block-06 {
    background: url(../images/block06/bg.jpg?) center top no-repeat;
    background-size: cover;
  }
  .block-06 ._inner {
    position: relative;
  }
  .block-06 ._inner:after {
    display: block;
    content: "";
    padding-top: 351.4444444444%;
  }
  .block-06 ._inner ._title {
    position: absolute;
    top: 2.31%;
    left: 2.56%;
    width: 94.22%;
    height: 6.26%;
  }
  .block-06 ._inner ._p1 {
    position: absolute;
    top: 10.97%;
    left: 1.78%;
    width: 98.33%;
    height: 25.17%;
  }
  .block-06 ._inner ._p3 {
    position: absolute;
    top: 66.46%;
    left: 1.78%;
    width: 98.33%;
    height: 30.86%;
  }
  .block-06 ._inner ._p2 {
    position: absolute;
    top: 38.73%;
    left: 0.11%;
    width: 99.89%;
    height: 22.1%;
  }
  .block-11 ._row1 {
    background: url(../images/block11/bg.jpg?) center top no-repeat;
    background-size: cover;
  }
  .block-11 ._row1 ._inner {
    position: relative;
  }
  .block-11 ._row1 ._inner:after {
    display: block;
    content: "";
    padding-top: 180.3333333333%;
  }
  .block-11 ._row1 ._inner ._p2 {
    position: absolute;
    top: 43.81%;
    left: -6.22%;
    width: 107%;
    height: 52.74%;
  }
  .block-11 ._row1 ._inner ._p1 {
    position: absolute;
    top: 4.13%;
    left: 4.11%;
    width: 95.11%;
    height: 52.37%;
  }
  .block-11 ._row1 ._inner ._p1 {
    z-index: 10;
  }
  .block-11 ._row2 {
    background: url(../images/block11/bg2.jpg?) center top no-repeat;
    background-size: cover;
  }
  .block-11 ._row2 ._inner {
    position: relative;
  }
  .block-11 ._row2 ._inner:after {
    display: block;
    content: "";
    padding-top: 88.7777777778%;
  }
  .block-11 ._row2 ._inner ._p1 {
    position: absolute;
    top: -2.88%;
    left: 1.89%;
    width: 106.44%;
    height: 94.49%;
  }
  .block-11 ._row3 {
    background: url(../images/block11/bg3.jpg?) center top no-repeat;
    background-size: cover;
  }
  .block-11 ._row3 ._inner {
    position: relative;
  }
  .block-11 ._row3 ._inner:after {
    display: block;
    content: "";
    padding-top: 88.7777777778%;
  }
  .block-11 ._row3 ._inner ._p1 {
    position: absolute;
    top: 10.51%;
    left: 1.89%;
    width: 106.44%;
    height: 84.98%;
  }
  .block-11 ._row4 {
    background: url(../images/block11/bg4.jpg?) center top no-repeat;
    background-size: cover;
  }
  .block-11 ._row4 ._inner {
    position: relative;
  }
  .block-11 ._row4 ._inner:after {
    display: block;
    content: "";
    padding-top: 103.1111111111%;
  }
  .block-11 ._row4 ._inner ._p1 {
    position: absolute;
    top: 8.84%;
    left: 1.89%;
    width: 106.44%;
    height: 90.84%;
  }
  .block-11 ._row5 {
    background: url(../images/block11/bg5.jpg?2) center top no-repeat;
    background-size: cover;
  }
  .block-11 ._row5 ._inner {
    position: relative;
  }
  .block-11 ._row5 ._inner:after {
    display: block;
    content: "";
    padding-top: 160.4444444444%;
  }
  .block-11 ._row5 ._inner ._p1 {
    position: absolute;
    top: 5.68%;
    left: 1.89%;
    width: 96.33%;
    height: 89.61%;
  }
  .block-12 ._row1 {
    background-color: #fff;
    background-size: cover;
    overflow: hidden;
  }
  .block-12 ._row1 ._inner {
    position: relative;
  }
  .block-12 ._row1 ._inner:after {
    display: block;
    content: "";
    padding-top: 63.3333333333%;
  }
  .block-12 ._row1 ._inner ._p2 {
    position: absolute;
    top: 14.21%;
    left: 53.44%;
    width: 64.33%;
    height: 102.98%;
  }
  .block-12 ._row1 ._inner ._p1 {
    position: absolute;
    top: 2.81%;
    left: -4.56%;
    width: 104.56%;
    height: 84.04%;
  }
  .block-12 ._row2 {
    background: url(../images/block12/bg2.jpg?) center top no-repeat;
    background-size: cover;
  }
  .block-12 ._row2 ._inner {
    position: relative;
  }
  .block-12 ._row2 ._inner:after {
    display: block;
    content: "";
    padding-top: 104.6666666667%;
  }
  .block-12 ._row2 ._inner ._p1 {
    position: absolute;
    top: 6.16%;
    left: -21.33%;
    width: 131%;
    height: 88.64%;
  }
  .block-12 ._row3 {
    background: url(../images/block12/bg3.jpg?) center top no-repeat;
    background-size: cover;
  }
  .block-12 ._row3 ._inner {
    position: relative;
  }
  .block-12 ._row3 ._inner:after {
    display: block;
    content: "";
    padding-top: 114.6666666667%;
  }
  .block-12 ._row3 ._inner ._p1 {
    position: absolute;
    top: 5.52%;
    left: 2.11%;
    width: 94.44%;
    height: 84.11%;
  }
  .block-12 ._row4 {
    background: url(../images/block12/bg4.jpg?) center top no-repeat;
    background-size: cover;
  }
  .block-12 ._row4 ._inner {
    position: relative;
  }
  .block-12 ._row4 ._inner:after {
    display: block;
    content: "";
    padding-top: 261.4444444444%;
  }
  .block-12 ._row4 ._inner ._p1 {
    position: absolute;
    top: 2.38%;
    left: 2.11%;
    width: 95.56%;
    height: 63.32%;
  }
  .block-13 {
    background: url(../images/block13/bg.jpg?) center top no-repeat;
    background-size: cover;
  }
  .block-13 ._inner {
    position: relative;
  }
  .block-13 ._inner:after {
    display: block;
    content: "";
    padding-top: 257.2222222222%;
  }
  .block-13 ._inner ._p3 {
    position: absolute;
    top: 55.25%;
    left: 2.33%;
    width: 95.33%;
    height: 44.75%;
  }
  .block-13 ._inner ._p1 {
    position: absolute;
    top: 2.81%;
    left: -0.11%;
    width: 100%;
    height: 6.52%;
  }
  .block-13 ._inner ._p2 {
    position: absolute;
    top: 12.74%;
    left: 2.33%;
    width: 95.33%;
    height: 35.08%;
  }
  .block-14 {
    background: url(../images/block14/bg.jpg?) center top no-repeat;
    background-size: cover;
  }
  .block-14 ._inner {
    position: relative;
  }
  .block-14 ._inner:after {
    display: block;
    content: "";
    padding-top: 57.2222222222%;
  }
  .block-14 ._inner ._p1 {
    position: absolute;
    top: 1.75%;
    left: -2.22%;
    width: 98.89%;
    height: 97.86%;
  }
  .block-14 ._inner ._btn {
    position: absolute;
    top: 10.87%;
    left: 14.33%;
    width: 78.22%;
    height: 33.01%;
  }
  .block-15 {
    background: url(../images/block15/bg.jpg?3) center top no-repeat;
    background-size: cover;
  }
  .block-15 ._inner {
    position: relative;
  }
  .block-15 ._inner:after {
    display: block;
    content: "";
    padding-top: 214.3333333333%;
  }
  .block-15 ._inner ._p1 {
    position: absolute;
    top: 4.3%;
    left: 0.78%;
    width: 78.67%;
    height: 3.68%;
  }
  .block-15 ._inner ._p2 {
    position: absolute;
    top: 13.48%;
    left: 1.11%;
    width: 93.11%;
    height: 82.79%;
  }
  .block-16 {
    background-color: #D1DFF6;
    padding: 100px 0;
  }
  .block-16 ._note {
    font-size: 16px;
    text-align: left;
    margin: 20px 0;
  }
  .block-16 ._title {
    margin-bottom: 30px;
  }
  .block-faq {
    background-color: #E5F5FF;
    padding: 50px 0 100px 0;
  }
  .block-faq ._inner {
    display: flex;
    gap: 30px;
    flex-direction: column;
  }
  .block-map iframe {
    width: 100%;
    height: 600px;
    border: none;
  }
  .block-form {
    padding: 0 0 40px 0;
    background: #E5F5FF;
    color: #23438A;
  }
  .block-form ._title {
    padding: 100px 0 50px 0;
    position: relative;
  }
  .block-form ._title:before {
    content: "";
    display: block;
    position: absolute;
    top: 0px;
    left: 0px;
    right: 0;
    height: 180px;
    background: #fff;
  }
  .block-form ._title h2 {
    position: relative;
  }
  .block-form ._title ._lead {
    margin-top: 30px;
    font-size: 24px;
    text-align: left;
    line-height: 1.5;
  }
  .block-form a {
    color: #23438A;
  }
  .block-form ._box {
    background-color: #fff;
  }
  .block-form ._w60 {
    width: 60px;
  }
  .block-form ._w100 {
    width: 100px;
  }
  .block-form ._w150 {
    width: 150px;
  }
  .block-form ._w200 {
    width: 200px;
  }
  .block-form ._w400 {
    width: 400px;
  }
  .block-form ._w10p {
    width: calc(10% - 10px);
  }
  .block-form ._w20p {
    width: calc(20% - 10px);
  }
  .block-form ._w30p {
    width: calc(30% - 10px);
  }
  .block-form ._w45p {
    width: calc(45% - 10px);
  }
  .block-form ._w40p {
    width: calc(40% - 10px);
  }
  .block-form ._w50p {
    width: calc(50% - 10px);
  }
  .block-form ._w60p {
    width: calc(60% - 10px);
  }
  .block-form ._w70p {
    width: calc(70% - 10px);
  }
  .block-form ._w80p {
    width: calc(80% - 10px);
  }
  .block-form ._w90p {
    width: calc(90% - 10px);
  }
  .block-form ._w100p {
    width: 100%;
  }
  .block-form {
    /* ---------- table ---------- ---------- */
    /* ---------- misc ---------- ---------- */
  }
  .block-form table._form-row-table {
    border-collapse: separate;
    border-spacing: 0;
    width: 100%;
    margin: 10px 0;
    border-bottom: 1px solid #172A88;
  }
}
@media print, screen and (min-width: 768px) and (min-width: 901px) {
  .block-form table._form-row-table {
    font-size: 17px;
  }
}
@media screen and (min-width: 768px) and (min-width: 768px) and (max-width: 900px) {
  .block-form table._form-row-table {
    font-size: 1.1458333333vw;
  }
}
@media print, screen and (min-width: 768px) {
  .block-form table._form-row-table p {
    margin: 0;
  }
  .block-form table._form-row-table th {
    position: relative;
    font-weight: bold;
    line-height: 1.4;
    text-align: left;
    width: 220px;
    border-top: 1px solid #172A88;
    padding: 1.5em 0.5em 1em 1em;
  }
  .block-form table._form-row-table td {
    position: relative;
    line-height: 1.4;
    vertical-align: middle;
    border-top: 1px solid #172A88;
    padding: 1em 2em 1em 1em;
  }
  .block-form ._row {
    position: relative;
    padding-top: 5px;
    padding-bottom: 5px;
  }
  .block-form ._row._row-error {
    color: red;
    background: #ffe;
    font-size: 16px;
  }
  .block-form ._row._row-error {
    display: none;
  }
  .block-form ._row._row-note {
    color: #23438A;
    font-size: 16px;
  }
  .block-form ._row._row-note2 {
    color: #23438A;
    font-size: 16px;
  }
  .block-form ._row ._col-note2 {
    color: #23438A;
    font-size: 16px;
  }
  .block-form ._row span {
    position: relative;
    display: inline-block;
    vertical-align: middle;
    box-sizing: border-box;
  }
  .block-form ._row span._col + ._col {
    margin-left: 5px;
  }
  .block-form ._req {
    display: inline-block;
    position: absolute;
    background: #EC6D7B;
    color: #fff;
    font-weight: normal;
    top: 25px;
    right: 15px;
    padding: 5px 5px 3px 5px;
    font-size: 13px;
  }
  .block-form ._btn-post {
    padding: 10px 20px;
    margin: 5px 0;
    background: #888;
    color: #fff;
    text-decoration: none;
    transition-duration: 0.2s;
    cursor: pointer;
  }
  .block-form ._btn-post:hover {
    background: #666;
  }
  .block-form ._form-row-p {
    text-align: center;
    margin: 40px 0;
    line-height: 1.6;
  }
  .block-form ._form-row-p p {
    font-size: 20px;
  }
  .block-form ._form-row-thanks {
    max-width: 600px;
    margin: 0 auto;
    padding: 100px 20px 200px 20px;
    display: flex;
    gap: 20px;
    flex-direction: column;
  }
  .block-form ._form-row-thanks h3 {
    font-size: 24px;
    text-align: center;
  }
  .block-form ._form-row-thanks p {
    text-align: left;
    font-size: 20px;
    line-height: 1.75;
  }
  .block-form ._form-row-error {
    text-align: center;
    color: red;
    margin: 40px 0;
    line-height: 1.6;
  }
  .block-form ._policy-box {
    margin-top: 20px;
    border: 1px solid #172A88;
    padding: 20px;
    line-height: 1.8;
    overflow: scroll;
    height: 200px;
  }
  .block-form ._polic-anno {
    padding: 20px 0;
  }
  .block-form ._form-row-btns {
    margin: 40px 0 60px 0;
    padding: 0 15px;
    display: flex;
    gap: 20px;
    flex-direction: column;
    align-items: center;
  }
  .block-form ._form-row-btns ._note {
    display: flex;
    gap: 20px;
    flex-direction: column;
  }
  .block-form ._form-row-btns ._note p {
    text-align: left;
    font-size: 22px;
    line-height: 1.75;
  }
  .block-form ._form-row-btns ._note ._add {
    font-size: 26px;
    text-align: center;
    font-weight: bold;
  }
  .block-form ._form-row-btns ._btn-send {
    position: relative;
    text-align: center;
    border: none;
    outline: none;
    color: #fff;
    text-decoration: none;
    transition-duration: 0.2s;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    cursor: pointer;
    background-color: #000;
    background: #EC6D7B url(../images/form/btn_bg.png?4) left center;
    background-size: cover;
    box-shadow: 0px 5px 5px rgba(0, 0, 0, 0.2);
    margin: 5px 0;
    width: 246px;
    height: 86px;
    display: inline-block;
    font-size: 30px;
  }
  .block-form ._form-row-btns ._btn-send:hover {
    opacity: 0.8;
  }
  .block-form ._form-row-btns ._btn-back {
    position: relative;
    text-align: center;
    text-decoration: none;
    transition-duration: 0.2s;
    cursor: pointer;
    background: #fff;
    border: 1px solid #ccc;
    margin: 5px 20px;
    display: inline-block;
    padding: 22px 70px;
    font-size: 24px;
  }
  .block-form ._form-row-btns ._btn-back:hover {
    background: #ddd;
  }
  .block-form {
    /* ---------- input,textarea ---------- ---------- */
    /* ---------- radio, checkbox ---------- ---------- */
  }
}
@media print, screen and (min-width: 768px) and (min-width: 901px) {
  .block-form input[type=text],
  .block-form input[type=number],
  .block-form textarea,
  .block-form select {
    font-size: 17px;
  }
  .block-form input[type=text]::placeholder,
  .block-form input[type=number]::placeholder,
  .block-form textarea::placeholder,
  .block-form select::placeholder {
    font-size: 17px;
  }
}
@media screen and (min-width: 768px) and (min-width: 768px) and (max-width: 900px) {
  .block-form input[type=text],
  .block-form input[type=number],
  .block-form textarea,
  .block-form select {
    font-size: 1.1458333333vw;
  }
  .block-form input[type=text]::placeholder,
  .block-form input[type=number]::placeholder,
  .block-form textarea::placeholder,
  .block-form select::placeholder {
    font-size: 1.1458333333vw;
  }
}
@media print, screen and (min-width: 768px) {
  .block-form input[type=text],
  .block-form input[type=number],
  .block-form textarea,
  .block-form select {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    border: none;
    border: 1px solid #172A88;
    border-radius: 0;
    width: calc(100% - 12px);
    padding: 10px 5px;
    background: #E5F5FF;
    vertical-align: top;
  }
  .block-form input[type=text]:focus,
  .block-form input[type=number]:focus,
  .block-form textarea:focus,
  .block-form select:focus {
    background: #E5F5FF;
  }
  .block-form input[type=text]._error,
  .block-form input[type=number]._error,
  .block-form textarea._error,
  .block-form select._error {
    background: #f7e9eb;
  }
  .block-form select {
    width: 100%;
  }
  .block-form input::-webkit-input-placeholder,
  .block-form textarea::-webkit-input-placeholder {
    color: #bbbbbb;
    font-size: 17px;
  }
  .block-form input:-ms-input-placeholder,
  .block-form textarea:-ms-input-placeholder {
    color: #bbbbbb;
    font-size: 17px;
  }
  .block-form input::-moz-placeholder,
  .block-form textarea::-moz-placeholder {
    color: #bbbbbb;
    font-size: 17px;
  }
  .block-form select {
    padding-right: 30px;
    background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAcAAAAGCAYAAAAPDoR2AAAAU0lEQVQImWXMsRFAQBhE4c+NlrRwiWpkciqgAzVQjQbEssskvxlzNtl982a2yTnv6P1zJAwolSgYEk6slVxwpoAJV+wLM7zyxhh7DNZ+rjZ00eABf7EPZ13p3eYAAAAASUVORK5CYII=");
    background-size: 8px 8px;
    background-repeat: no-repeat;
    background-position: right 10px top 50%;
  }
  .block-form select::-ms-expand {
    display: none;
  }
  .block-form textarea {
    resize: none;
    height: 200px;
  }
  .block-form ._list li {
    display: inline-block;
    padding: 0 20px 0 0;
  }
  .block-form ._list-radio label,
  .block-form ._list-checkbox label {
    position: relative;
    padding-left: 30px;
    cursor: pointer;
    display: inline-block;
    transition-duration: 0.2s;
    line-height: 1.4;
    cursor: pointer;
  }
  .block-form ._list-radio label:hover,
  .block-form ._list-checkbox label:hover {
    opacity: 0.8;
  }
  .block-form ._list-radio label {
    margin: 5px 0;
  }
  .block-form ._list-radio label:after {
    content: "";
    position: absolute;
    display: block;
    top: 50%;
    left: 0;
    margin-top: -12px;
    width: 18px;
    height: 18px;
    background: #fff;
    border-radius: 2px;
  }
  .block-form ._list-radio label:before {
    content: "";
    display: block;
    position: absolute;
    top: 50%;
    left: 5px;
    margin-top: -7px;
    width: 12px;
    height: 12px;
    opacity: 0;
    z-index: 10;
  }
  .block-form ._list-radio label:after {
    border: 2px solid #ddd;
  }
  .block-form ._list-radio label:before {
    background: #888;
  }
  .block-form ._list-radio input[type=radio] {
    display: none;
  }
  .block-form ._list-radio input[type=radio]:checked + label:before {
    opacity: 1;
  }
  .block-form ._list-radio label:before {
    border-radius: 50%;
  }
  .block-form ._list-radio label:after {
    border-radius: 50%;
  }
  .block-form ._list-checkbox label {
    margin: 5px 0;
  }
  .block-form ._list-checkbox label:after {
    content: "";
    position: absolute;
    display: block;
    top: 50%;
    left: 4px;
    margin-top: -7px;
    width: 12px;
    height: 12px;
    border-radius: 1px;
  }
  .block-form ._list-checkbox label:before {
    content: "";
    position: absolute;
    display: block;
    top: 50%;
    left: 0;
    margin-top: -11px;
    width: 16px;
    height: 16px;
    border-radius: 2px;
  }
  .block-form ._list-checkbox label:after {
    background: #fff;
  }
  .block-form ._list-checkbox label:before {
    border: 2px solid #ddd;
    background: #fff;
  }
  .block-form ._list-checkbox input[type=checkbox] {
    display: none;
  }
  .block-form ._list-checkbox input[type=checkbox]:checked + label:after {
    background: #888;
  }
  .mod-date-sel .input-group {
    display: flex;
    align-items: center;
    background-color: #e6f7ff;
    border: 1px solid #172A88;
    border-radius: 5px;
    padding: 8px 12px;
  }
  .mod-date-sel .input-group input[type=text] {
    border: none;
    background-color: #fff;
  }
  .mod-date-sel .input-group input[type=text][placeholder=年] {
    width: 50px;
  }
  .mod-date-sel .input-group input[type=text][placeholder=月], .mod-date-sel .input-group input[type=text][placeholder=日] {
    width: 35px;
  }
  .mod-date-sel .input-group input[type=text][name$=-hour] {
    width: 35px;
  }
  .mod-date-sel .input-group input[type=text][name$=-min] {
    width: 35px;
  }
  .mod-date-sel .input-group span {
    margin: 0 5px;
  }
  .mod-btn {
    cursor: pointer;
    transition-duration: 0.2s;
  }
  .mod-btn:hover {
    opacity: 1;
    filter: brightness(1.1);
  }
  .mod-toggle-icon {
    --boxW:40px;
    --boxH:40px;
    --bar:40px;
    --thick:4px;
    position: relative;
    width: var(--boxW);
    height: var(--boxH);
    border-radius: 50%;
    cursor: pointer;
    transition-duration: 0.2s;
  }
  .mod-toggle-icon.is-fill {
    background-color: #000;
  }
  .mod-toggle-icon.is-fill:before, .mod-toggle-icon.is-fill:after {
    background: #fff;
  }
  .mod-toggle-icon.is-small {
    --boxW:30px;
    --boxH:30px;
    --bar:19px;
    --thick:1px;
  }
  .mod-toggle-icon:before, .mod-toggle-icon:after {
    content: "";
    display: block;
    position: absolute;
    background: #fff;
    top: calc((var(--boxH) - var(--thick)) / 2);
    left: calc((var(--boxW) - var(--bar)) / 2);
    width: var(--bar);
    height: var(--thick);
    /* transform: rotate(-45deg); */
  }
  .mod-toggle-icon:after {
    transform: rotate(90deg);
  }
  .js-toggle-open .mod-toggle-icon:after {
    display: none;
  }
  .mod-toggle-icon:hover {
    opacity: 0.8;
  }
  .mod-toggle {
    background-color: #fff;
    border-radius: 10px;
    text-align: left;
  }
  .mod-toggle + .mod-toggle {
    margin-top: 20px;
  }
  .mod-toggle ._head {
    position: relative;
    cursor: pointer;
    padding: 30px 20px 20px 100px;
    font-size: 26px;
    line-height: 1.4;
    color: #fff;
    background-color: #036EB8;
    font-weight: 400;
    font-family: serif;
  }
  .mod-toggle ._head .mod-toggle-icon {
    position: absolute;
    top: calc(50% - 20px);
    right: 30px;
  }
  .mod-toggle ._head:before {
    content: "Q";
    color: #fff;
    display: block;
    position: absolute;
    top: 50%;
    left: 30px;
    font-size: 40px;
    font-weight: 200;
    transform: translate(0, -50%);
    font-family: serif;
  }
  .mod-toggle ._body {
    position: relative;
    padding: 30px 40px 30px 100px;
    font-size: 20px;
    display: none;
  }
  .mod-toggle ._body:before {
    content: "A";
    display: block;
    color: #036EB8;
    position: absolute;
    top: 50%;
    left: 30px;
    font-size: 40px;
    font-weight: 200;
    transform: translate(0, -50%);
    font-family: serif;
  }
  .mod-toggle ._body p {
    line-height: 1.6;
  }
  .mod-price {
    margin-bottom: 2px;
  }
  .mod-price .mod-toggle-icon {
    --boxW:27px;
    --boxH:27px;
    --bar:27px;
    --thick:3px;
  }
  .mod-price ._head {
    position: relative;
    background-color: #2EA7E0;
    padding: 20px;
    font-weight: bold;
    color: #fff;
    font-size: 20px;
  }
  .mod-price ._head .mod-toggle-icon {
    position: absolute;
    top: calc(50% - 15px);
    right: 30px;
  }
  .mod-price ._body {
    display: none;
  }
  .mod-table-price {
    background-color: #fff;
    width: 100%;
  }
  .mod-table-price th {
    border-bottom: 1px solid #172A88;
    padding: 10px;
    line-height: 1.4;
    font-size: 20px;
  }
  .mod-table-price td {
    border-bottom: 1px solid #172A88;
    padding: 10px;
    line-height: 1.4;
    font-size: 20px;
    text-align: right;
  }
}
@media screen and (max-width: 767px) {
  .container {
    overflow: hidden;
  }
  /* ----------------------------------------------------------
  .header
  ---------------------------------------------------------- */
  .area-header-wrap {
    background: #fff;
    height: 16vw;
  }
  .area-header {
    position: relative;
  }
  .area-header img {
    width: 100%;
  }
  .area-header ._inner {
    position: relative;
    display: flex;
    justify-content: space-between;
    padding: 0 2vw 0 0;
  }
  .area-header ._logo {
    padding: 2.5vw 0 0 2vw;
    width: 45vw;
    height: auto;
    box-sizing: border-box;
  }
  .area-header ._sub {
    position: absolute;
    top: 4vw;
    right: 2vw;
    width: 50vw;
  }
  .area-header ._sub2 {
    display: none;
  }
  .area-header ._btns {
    display: none;
  }
  .mod-menu-btn-sp {
    position: absolute;
    top: 0px;
    right: 0px;
    width: 50px;
    height: 50px;
    background: #E4157F;
    display: flex;
    justify-content: center;
    align-items: center;
  }
  .mod-menu-btn-sp span {
    color: #fff;
    font-size: 11px;
    letter-spacing: 0.1em;
  }
  .mod-menu-btn-sp span:nth-child(2) {
    display: none;
  }
  body.js-gmenu-active .mod-menu-btn-sp span:nth-child(1) {
    display: none;
  }
  body.js-gmenu-active .mod-menu-btn-sp span:nth-child(2) {
    display: block;
  }
  .area-menu {
    display: none;
  }
  .area-modal-menu {
    position: fixed;
    z-index: -1;
    visibility: hidden;
    opacity: 0;
    transition-duration: 0.4s;
    transform: translate(0, -200px);
    top: 50px;
    left: 0px;
    right: 0px;
    bottom: 0px;
    min-height: 140px;
    background: #fff;
    padding: 30px 20px 40px 20px;
    box-shadow: 0px 2px 5px rgba(0, 0, 0, 0.05);
    overflow-y: scroll;
    -webkit-overflow-scrolling: touch;
  }
  body.js-gmenu-active .area-modal-menu {
    visibility: visible;
    z-index: 50;
    opacity: 1;
    transform: translate(0, 0);
  }
  .area-modal-menu a {
    color: #333;
  }
  .area-modal-menu a.is-under {
    color: #ccc;
  }
  .area-modal-menu a.is-under:before {
    background: #ccc;
  }
  .area-modal-menu ._link {
    display: flex;
    flex-direction: column;
  }
  .area-modal-menu ._link li {
    border-top: 1px solid #000;
  }
  .area-modal-menu ._link a {
    padding: 10px 0;
    display: block;
    line-height: 1.75;
    letter-spacing: 0.1em;
    color: #231815;
    font-size: 14px;
  }
  .area-modal-menu ._link a span.is-A {
    color: #E4007F;
  }
  .area-modal-menu ._link a span.is-B {
    color: #00A0E9;
  }
  .area-modal-menu ._btns {
    margin-top: 10px;
    display: flex;
    flex-direction: column;
    gap: 10px;
    width: 50%;
  }
  .area-modal-menu ._btns ._btn {
    display: block;
    font-size: 14px;
    padding: 10px;
    font-weight: bold;
    letter-spacing: 0.05em;
    color: #fff;
    text-align: left;
    box-shadow: 2px 2px 5px rgba(0, 0, 0, 0.25);
    position: relative;
  }
  .area-modal-menu ._btns ._btn.is-taiken {
    background-color: #004E9D;
  }
  .area-modal-menu ._btns ._btn.is-youkou {
    background-color: #2EA7E0;
  }
  .area-modal-menu ._btns ._btn.is-entry {
    background-color: #E61673;
  }
  .area-modal-menu ._btns ._btn.is-official {
    background-color: #E0999B;
  }
  .area-modal-menu ._btns ._btn:after {
    content: "";
    display: block;
    position: absolute;
    top: calc(50% - 5px);
    right: 10px;
    background: url(/images/common/icon.png) left top no-repeat;
    background-size: contain;
    width: 10px;
    height: 10px;
  }
  /* ----------------------------------------------------------
  footer
  ---------------------------------------------------------- */
  .block-copy {
    background: #23438A;
    text-align: center;
    color: #fff;
    line-height: 1.4;
    padding: 8px 0 80px 0;
  }
  .block-copy small {
    font-size: 10px;
  }
  .btn-pagetop {
    position: fixed;
    display: block;
    text-align: center;
    cursor: pointer;
    bottom: 65px;
    right: 10px;
    width: 40px;
    height: 40px;
  }
  .btn-pagetop img {
    width: 100%;
  }
  .area-footer-btn-sp {
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0px;
    display: flex;
    z-index: 200;
    box-shadow: 0px -2px 5px rgba(0, 0, 0, 0.15);
  }
  .area-footer-btn-sp ._inner {
    display: flex;
  }
  .area-footer-btn-sp ._inner ._btn {
    flex: 1;
    display: block;
  }
  .block-footer {
    background-color: #fff;
    padding: 40px 20px 20px 20px;
    text-align: center;
    display: flex;
    gap: 20px;
    flex-direction: column;
  }
  .block-footer img {
    width: 100%;
  }
  .block-footer ._logo {
    width: 240px;
    margin: 0 auto;
  }
  .block-footer ._info {
    margin-top: 20px;
  }
  /* ----------------------------------------------------------
  .block01
  ---------------------------------------------------------- */
  body {
    background-color: #fff;
    color: #23438A;
  }
  body img {
    max-width: 100%;
  }
  .block-01-10 {
    text-align: center;
  }
  .block-11-20 {
    text-align: center;
  }
  .block-21-30 {
    text-align: center;
  }
  .block-01 {
    margin-top: -20px;
    position: relative;
  }
  .block-01 ._p2 {
    position: absolute;
    inset: 0;
    opacity: 0;
    animation: infinite_loop 10s ease-in-out 0s infinite;
  }
  @keyframes infinite_loop {
    0% {
      opacity: 0;
    }
    40% {
      opacity: 0;
    }
    50% {
      opacity: 1;
    }
    90% {
      opacity: 1;
    }
    100% {
      opacity: 0;
    }
  }
  .block-02 {
    background: url(../images/block02/bg.jpg?) center top no-repeat;
    background-size: cover;
  }
  .block-02 ._inner {
    position: relative;
  }
  .block-02 ._inner:after {
    display: block;
    content: "";
    padding-top: 53.7777777778%;
  }
  .block-02 ._inner ._p1 {
    position: absolute;
    top: 7.85%;
    left: 29.89%;
    width: 67%;
    height: 79.34%;
  }
  .block-02 ._inner ._btn {
    position: absolute;
    top: 56.82%;
    left: 45.11%;
    width: 55%;
    height: 26.45%;
  }
  .block-03 {
    background: url(../images/block03/bg.jpg?) center top no-repeat;
    background-size: cover;
  }
  .block-03 ._inner {
    position: relative;
  }
  .block-03 ._inner:after {
    display: block;
    content: "";
    padding-top: 141.8888888889%;
  }
  .block-03 ._inner ._p1 {
    position: absolute;
    top: 19.66%;
    left: 2.33%;
    width: 92.67%;
    height: 80.19%;
  }
  .block-03 ._inner ._title {
    position: absolute;
    top: 1.49%;
    left: 2.33%;
    width: 94.89%;
    height: 16.21%;
  }
  .block-04 {
    background: url(../images/block04/bg.jpg?) center top no-repeat;
    background-size: cover;
  }
  .block-04 ._inner {
    position: relative;
  }
  .block-04 ._inner:after {
    display: block;
    content: "";
    padding-top: 57.1111111111%;
  }
  .block-04 ._inner ._p1 {
    position: absolute;
    top: 1.95%;
    left: 22.78%;
    width: 73.89%;
    height: 89.88%;
  }
  .block-04 ._inner ._btn {
    position: absolute;
    top: 10.51%;
    left: 17.89%;
    width: 73.22%;
    height: 33.07%;
  }
  .block-05 {
    background: url(../images/block05/bg.jpg?) center top no-repeat;
    background-size: cover;
  }
  .block-05 ._inner {
    position: relative;
  }
  .block-05 ._inner:after {
    display: block;
    content: "";
    padding-top: 123.1111111111%;
  }
  .block-05 ._inner ._texts {
    position: absolute;
    top: 15.88%;
    left: 2.56%;
    width: 97.56%;
    height: 79.33%;
  }
  .block-05 ._inner ._title {
    position: absolute;
    top: 5.42%;
    left: 2.67%;
    width: 57.56%;
    height: 6.77%;
  }
  .block-06 {
    background: url(../images/block06/bg.jpg?) center top no-repeat;
    background-size: cover;
  }
  .block-06 ._inner {
    position: relative;
  }
  .block-06 ._inner:after {
    display: block;
    content: "";
    padding-top: 351.4444444444%;
  }
  .block-06 ._inner ._title {
    position: absolute;
    top: 2.31%;
    left: 2.56%;
    width: 94.22%;
    height: 6.26%;
  }
  .block-06 ._inner ._p1 {
    position: absolute;
    top: 10.97%;
    left: 1.78%;
    width: 98.33%;
    height: 25.17%;
  }
  .block-06 ._inner ._p3 {
    position: absolute;
    top: 66.46%;
    left: 1.78%;
    width: 98.33%;
    height: 30.86%;
  }
  .block-06 ._inner ._p2 {
    position: absolute;
    top: 38.73%;
    left: 0.11%;
    width: 99.89%;
    height: 22.1%;
  }
  .block-11 ._row1 {
    background: url(../images/block11/bg.jpg?) center top no-repeat;
    background-size: cover;
  }
  .block-11 ._row1 ._inner {
    position: relative;
  }
  .block-11 ._row1 ._inner:after {
    display: block;
    content: "";
    padding-top: 180.3333333333%;
  }
  .block-11 ._row1 ._inner ._p2 {
    position: absolute;
    top: 43.81%;
    left: -6.22%;
    width: 107%;
    height: 52.74%;
  }
  .block-11 ._row1 ._inner ._p1 {
    position: absolute;
    top: 4.13%;
    left: 4.11%;
    width: 95.11%;
    height: 52.37%;
  }
  .block-11 ._row1 ._inner ._p1 {
    z-index: 10;
  }
  .block-11 ._row2 {
    background: url(../images/block11/bg2.jpg?) center top no-repeat;
    background-size: cover;
  }
  .block-11 ._row2 ._inner {
    position: relative;
  }
  .block-11 ._row2 ._inner:after {
    display: block;
    content: "";
    padding-top: 88.7777777778%;
  }
  .block-11 ._row2 ._inner ._p1 {
    position: absolute;
    top: -2.88%;
    left: 1.89%;
    width: 106.44%;
    height: 94.49%;
  }
  .block-11 ._row3 {
    background: url(../images/block11/bg3.jpg?) center top no-repeat;
    background-size: cover;
  }
  .block-11 ._row3 ._inner {
    position: relative;
  }
  .block-11 ._row3 ._inner:after {
    display: block;
    content: "";
    padding-top: 88.7777777778%;
  }
  .block-11 ._row3 ._inner ._p1 {
    position: absolute;
    top: 10.51%;
    left: 1.89%;
    width: 106.44%;
    height: 84.98%;
  }
  .block-11 ._row4 {
    background: url(../images/block11/bg4.jpg?) center top no-repeat;
    background-size: cover;
  }
  .block-11 ._row4 ._inner {
    position: relative;
  }
  .block-11 ._row4 ._inner:after {
    display: block;
    content: "";
    padding-top: 103.1111111111%;
  }
  .block-11 ._row4 ._inner ._p1 {
    position: absolute;
    top: 8.84%;
    left: 1.89%;
    width: 106.44%;
    height: 90.84%;
  }
  .block-11 ._row5 {
    background: url(../images/block11/bg5.jpg?2) center top no-repeat;
    background-size: cover;
  }
  .block-11 ._row5 ._inner {
    position: relative;
  }
  .block-11 ._row5 ._inner:after {
    display: block;
    content: "";
    padding-top: 160.4444444444%;
  }
  .block-11 ._row5 ._inner ._p1 {
    position: absolute;
    top: 5.68%;
    left: 1.89%;
    width: 96.33%;
    height: 89.61%;
  }
  .block-12 ._row1 {
    background-color: #fff;
    background-size: cover;
    overflow: hidden;
  }
  .block-12 ._row1 ._inner {
    position: relative;
  }
  .block-12 ._row1 ._inner:after {
    display: block;
    content: "";
    padding-top: 63.3333333333%;
  }
  .block-12 ._row1 ._inner ._p2 {
    position: absolute;
    top: 14.21%;
    left: 53.44%;
    width: 64.33%;
    height: 102.98%;
  }
  .block-12 ._row1 ._inner ._p1 {
    position: absolute;
    top: 2.81%;
    left: -4.56%;
    width: 104.56%;
    height: 84.04%;
  }
  .block-12 ._row2 {
    background: url(../images/block12/bg2.jpg?) center top no-repeat;
    background-size: cover;
  }
  .block-12 ._row2 ._inner {
    position: relative;
  }
  .block-12 ._row2 ._inner:after {
    display: block;
    content: "";
    padding-top: 104.6666666667%;
  }
  .block-12 ._row2 ._inner ._p1 {
    position: absolute;
    top: 6.16%;
    left: -21.33%;
    width: 131%;
    height: 88.64%;
  }
  .block-12 ._row3 {
    background: url(../images/block12/bg3.jpg?) center top no-repeat;
    background-size: cover;
  }
  .block-12 ._row3 ._inner {
    position: relative;
  }
  .block-12 ._row3 ._inner:after {
    display: block;
    content: "";
    padding-top: 114.6666666667%;
  }
  .block-12 ._row3 ._inner ._p1 {
    position: absolute;
    top: 5.52%;
    left: 2.11%;
    width: 94.44%;
    height: 84.11%;
  }
  .block-12 ._row4 {
    background: url(../images/block12/bg4.jpg?) center top no-repeat;
    background-size: cover;
  }
  .block-12 ._row4 ._inner {
    position: relative;
  }
  .block-12 ._row4 ._inner:after {
    display: block;
    content: "";
    padding-top: 261.4444444444%;
  }
  .block-12 ._row4 ._inner ._p1 {
    position: absolute;
    top: 2.38%;
    left: 2.11%;
    width: 95.56%;
    height: 63.32%;
  }
  .block-13 {
    background: url(../images/block13/bg.jpg?) center top no-repeat;
    background-size: cover;
  }
  .block-13 ._inner {
    position: relative;
  }
  .block-13 ._inner:after {
    display: block;
    content: "";
    padding-top: 257.2222222222%;
  }
  .block-13 ._inner ._p3 {
    position: absolute;
    top: 55.25%;
    left: 2.33%;
    width: 95.33%;
    height: 44.75%;
  }
  .block-13 ._inner ._p1 {
    position: absolute;
    top: 2.81%;
    left: -0.11%;
    width: 100%;
    height: 6.52%;
  }
  .block-13 ._inner ._p2 {
    position: absolute;
    top: 12.74%;
    left: 2.33%;
    width: 95.33%;
    height: 35.08%;
  }
  .block-14 {
    background: url(../images/block14/bg.jpg?) center top no-repeat;
    background-size: cover;
  }
  .block-14 ._inner {
    position: relative;
  }
  .block-14 ._inner:after {
    display: block;
    content: "";
    padding-top: 57.2222222222%;
  }
  .block-14 ._inner ._p1 {
    position: absolute;
    top: 1.75%;
    left: -2.22%;
    width: 98.89%;
    height: 97.86%;
  }
  .block-14 ._inner ._btn {
    position: absolute;
    top: 10.87%;
    left: 14.33%;
    width: 78.22%;
    height: 33.01%;
  }
  .block-15 {
    background: url(../images/block15/bg.jpg?3) center top no-repeat;
    background-size: cover;
  }
  .block-15 ._inner {
    position: relative;
  }
  .block-15 ._inner:after {
    display: block;
    content: "";
    padding-top: 214.3333333333%;
  }
  .block-15 ._inner ._p1 {
    position: absolute;
    top: 4.3%;
    left: 0.78%;
    width: 78.67%;
    height: 3.68%;
  }
  .block-15 ._inner ._p2 {
    position: absolute;
    top: 13.48%;
    left: 1.11%;
    width: 93.11%;
    height: 82.79%;
  }
  .block-16 {
    background: url(../images/block16/bg.jpg?) center top no-repeat;
    background-size: cover;
    padding: 40px 20px;
  }
  .block-16 ._inner {
    position: relative;
  }
  .block-16 ._note {
    font-size: 12px;
    margin: 10px 0;
  }
  .block-16 ._title {
    margin-bottom: 20px;
  }
  .block-faq {
    background-color: #E5F5FF;
    padding: 50px 20px 100px 20px;
  }
  .block-faq ._inner {
    display: flex;
    gap: 30px;
    flex-direction: column;
  }
  .block-map iframe {
    width: 100%;
    height: 100vw;
    border: none;
  }
  /* ----------------------------------------------------------
  .block-form
  ---------------------------------------------------------- */
  .block-form {
    position: relative;
    padding: 0 0 40px 0;
    background: #E5F5FF;
    color: #444D67;
  }
  .block-form a {
    color: #444D67;
  }
  .block-form ._title {
    padding: 40px 20px;
    text-align: center;
    background: #fff;
  }
  .block-form ._title h2 {
    position: relative;
    text-align: center;
  }
  .block-form ._title ._lead {
    margin-top: 30px;
    font-size: 14px;
    text-align: left;
    line-height: 1.5;
  }
  .block-form ._box {
    background-color: #fff;
    padding: 40px 20px 10px 20px;
  }
  .block-form ._w60 {
    width: 3.125vw;
  }
  .block-form ._w100 {
    width: 5.2083333333vw;
  }
  .block-form ._w200 {
    width: 10.4166666667vw;
  }
  .block-form ._w400 {
    width: 20.8333333333vw;
  }
  .block-form ._w40-sp {
    width: 40px;
  }
  .block-form ._w50-sp {
    width: 50px;
  }
  .block-form ._w60-sp {
    width: 60px;
  }
  .block-form ._w80-sp {
    width: 80px;
  }
  .block-form ._w100-sp {
    width: 100px;
  }
  .block-form ._w200-sp {
    width: 200px;
  }
  .block-form ._w400-sp {
    width: 400px;
  }
  .block-form ._w50p-sp {
    width: 50%;
  }
  .block-form ._w100p-sp {
    width: 100%;
  }
  .block-form {
    /* ---------- table ---------- ---------- */
    /* ---------- misc ---------- ---------- */
  }
  .block-form table._form-row-table {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
    margin: 10px 0;
    border-bottom: 1px solid #172A88;
    font-size: 14px;
  }
  .block-form table._form-row-table p {
    margin: 0;
  }
  .block-form table._form-row-table th {
    position: relative;
    font-weight: bold;
    line-height: 1.4;
    text-align: left;
    box-sizing: border-box;
    display: block;
    border-top: 1px solid #172A88;
    padding: 15px 0 0 0;
  }
  .block-form table._form-row-table th br {
    display: none;
  }
  .block-form table._form-row-table td {
    position: relative;
    line-height: 1.4;
    box-sizing: border-box;
    display: block;
    padding: 0 0 10px 15px;
  }
  .block-form ._row {
    position: relative;
    padding-top: 5px;
    padding-bottom: 5px;
  }
  .block-form ._row._row-error {
    color: red;
    background: #ffe;
    font-size: 85%;
  }
  .block-form ._row._row-error {
    display: none;
  }
  .block-form ._row._row-note {
    color: #23438A;
    font-size: 16px;
  }
  .block-form ._row._row-note2 {
    color: #23438A;
    font-size: 16px;
  }
  .block-form ._row ._col-note2 {
    color: #23438A;
    font-size: 16px;
  }
  .block-form ._row._row-note {
    font-size: 12px;
  }
  .block-form ._row._row-note2 {
    font-size: 12px;
  }
  .block-form ._row ._col-note2 {
    font-size: 12px;
  }
  .block-form ._row span {
    position: relative;
    display: inline-block;
    vertical-align: middle;
    box-sizing: border-box;
  }
  .block-form ._row span._col + ._col {
    margin-top: 5px;
    margin-bottom: 5px;
  }
  .block-form ._row span._col-sp + ._col-sp {
    margin-left: 5px;
  }
  .block-form ._req {
    display: inline-block;
    position: absolute;
    background: #EC6D7B;
    color: #fff;
    font-weight: normal;
    top: 15px;
    right: 15px;
    padding: 2px 5px;
    font-size: 11px;
  }
  .block-form ._btn-post {
    padding: 10px 20px;
    margin: 5px 0;
    background: #888;
    color: #fff;
    text-decoration: none;
    transition-duration: 0.2s;
    cursor: pointer;
  }
  .block-form ._btn-post:hover {
    background: #666;
  }
  .block-form ._form-row-p {
    text-align: center;
    margin: 40px 0;
    line-height: 1.6;
  }
  .block-form ._form-row-thanks {
    margin: 0 auto;
    padding: 67px 13px 133px 13px;
    display: flex;
    gap: 13px;
    flex-direction: column;
  }
  .block-form ._form-row-thanks h3 {
    font-size: 16px;
    text-align: center;
  }
  .block-form ._form-row-thanks p {
    text-align: left;
    font-size: 13px;
    line-height: 1.75;
  }
  .block-form ._form-row-error {
    text-align: center;
    color: red;
    margin: 40px 0;
    line-height: 1.6;
  }
  .block-form ._policy-box {
    margin-top: 20px;
    padding: 20px;
    line-height: 1.8;
    overflow: scroll;
    height: 100px;
    border: 1px solid #172A88;
  }
  .block-form ._polic-anno {
    padding: 20px 0;
  }
  .block-form ._form-row-btns {
    margin: 20px;
    display: flex;
    gap: 20px;
    flex-direction: column;
    align-items: center;
  }
  .block-form ._form-row-btns p {
    margin-top: 10px;
    line-height: 1.7;
    font-size: 12px;
    font-weight: bold;
  }
  .block-form ._form-row-btns ._add {
    font-size: 14px;
    text-align: center;
  }
  .block-form ._form-row-btns ._btns {
    padding: 20px 0;
  }
  .block-form ._form-row-btns ._btn-send {
    position: relative;
    text-align: center;
    border: none;
    outline: none;
    color: #fff;
    text-decoration: none;
    transition-duration: 0.2s;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    cursor: pointer;
    background-color: #C5006E;
    background: #EC6D7B url(../images/form/btn_bg.png?3) left center;
    border-radius: 15px;
    background-size: auto 100%;
    box-shadow: 0px 5px 5px rgba(0, 0, 0, 0.2);
    margin: 3px 0;
    width: 164px;
    height: 57px;
    display: block;
    font-size: 18px;
  }
  .block-form ._form-row-btns ._btn-send:hover {
    opacity: 0.8;
  }
  .block-form ._form-row-btns ._btn-back {
    position: relative;
    text-align: center;
    text-decoration: none;
    transition-duration: 0.2s;
    cursor: pointer;
    background: #eee;
    border: 1px solid #ccc;
    border-radius: 15px;
    margin: 10px 0;
    display: block;
    padding: 10px;
    box-sizing: border-box;
    width: 100%;
    font-size: 18px;
  }
  .block-form ._form-row-btns ._btn-back:hover {
    background: #ddd;
  }
  /* ----------------------------------------------------------
  .block-contact-form input forms
  ---------------------------------------------------------- */
  .block-form {
    /* ---------- input,textarea ---------- ---------- */
    /* ---------- radio, checkbox ---------- ---------- */
  }
  .block-form input[type=text],
  .block-form input[type=number],
  .block-form textarea,
  .block-form select {
    font-size: 12px;
  }
  .block-form input[type=text]::placeholder,
  .block-form input[type=number]::placeholder,
  .block-form textarea::placeholder,
  .block-form select::placeholder {
    font-size: 12px;
  }
  .block-form input[type=text],
  .block-form input[type=number],
  .block-form textarea,
  .block-form select {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    border: none;
    border: 1px solid #172A88;
    border-radius: 0;
    width: calc(100% - 12px);
    padding: 10px 5px;
    background: #E5F5FF;
    vertical-align: top;
  }
  .block-form input[type=text]:focus,
  .block-form input[type=number]:focus,
  .block-form textarea:focus,
  .block-form select:focus {
    background: #E5F5FF;
  }
  .block-form input[type=text]._error,
  .block-form input[type=number]._error,
  .block-form textarea._error,
  .block-form select._error {
    background: #f7e9eb;
  }
  .block-form select {
    width: 100%;
  }
  .block-form input::-webkit-input-placeholder,
  .block-form textarea::-webkit-input-placeholder {
    color: #bbbbbb;
    font-size: 22px;
  }
  .block-form input:-ms-input-placeholder,
  .block-form textarea:-ms-input-placeholder {
    color: #bbbbbb;
    font-size: 22px;
  }
  .block-form input::-moz-placeholder,
  .block-form textarea::-moz-placeholder {
    color: #bbbbbb;
    font-size: 22px;
  }
  .block-form select {
    padding-right: 30px;
    background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAcAAAAGCAYAAAAPDoR2AAAAU0lEQVQImWXMsRFAQBhE4c+NlrRwiWpkciqgAzVQjQbEssskvxlzNtl982a2yTnv6P1zJAwolSgYEk6slVxwpoAJV+wLM7zyxhh7DNZ+rjZ00eABf7EPZ13p3eYAAAAASUVORK5CYII=");
    background-size: 8px 8px;
    background-repeat: no-repeat;
    background-position: right 10px top 50%;
  }
  .block-form select::-ms-expand {
    display: none;
  }
  .block-form textarea {
    resize: none;
    height: 100px;
  }
  .block-form ._list li {
    display: inline-block;
    padding: 0 20px 0 0;
  }
  .block-form ._list-radio,
  .block-form ._list-checkbox {
    display: flex;
    flex-direction: column;
  }
  .block-form ._list-radio label,
  .block-form ._list-checkbox label {
    position: relative;
    padding-left: 30px;
    cursor: pointer;
    display: inline-block;
    transition-duration: 0.2s;
    line-height: 1.4;
    cursor: pointer;
  }
  .block-form ._list-radio label:hover,
  .block-form ._list-checkbox label:hover {
    opacity: 0.8;
  }
  .block-form ._list-radio label {
    margin: 5px 0;
  }
  .block-form ._list-radio label:after {
    content: "";
    position: absolute;
    display: block;
    top: 50%;
    left: 0;
    margin-top: -12px;
    width: 18px;
    height: 18px;
    background: #fff;
    border-radius: 2px;
  }
  .block-form ._list-radio label:before {
    content: "";
    display: block;
    position: absolute;
    top: 50%;
    left: 5px;
    margin-top: -7px;
    width: 12px;
    height: 12px;
    opacity: 0;
    z-index: 10;
  }
  .block-form ._list-radio label:after {
    border: 2px solid #ddd;
  }
  .block-form ._list-radio label:before {
    background: #888;
  }
  .block-form ._list-radio input[type=radio] {
    display: none;
  }
  .block-form ._list-radio input[type=radio]:checked + label:before {
    opacity: 1;
  }
  .block-form ._list-radio label:before {
    border-radius: 50%;
  }
  .block-form ._list-radio label:after {
    border-radius: 50%;
  }
  .block-form ._list-checkbox label {
    margin: 5px 0;
  }
  .block-form ._list-checkbox label:after {
    content: "";
    position: absolute;
    display: block;
    top: 50%;
    left: 4px;
    margin-top: -7px;
    width: 12px;
    height: 12px;
    border-radius: 1px;
  }
  .block-form ._list-checkbox label:before {
    content: "";
    position: absolute;
    display: block;
    top: 50%;
    left: 0;
    margin-top: -11px;
    width: 16px;
    height: 16px;
    border-radius: 2px;
  }
  .block-form ._list-checkbox label:after {
    background: #fff;
  }
  .block-form ._list-checkbox label:before {
    border: 2px solid #ddd;
    background: #fff;
  }
  .block-form ._list-checkbox input[type=checkbox] {
    display: none;
  }
  .block-form ._list-checkbox input[type=checkbox]:checked + label:after {
    background: #888;
  }
  .mod-date-sel .input-group {
    margin-top: 10px;
    display: flex;
    align-items: center;
    background-color: #e6f7ff;
    border: 1px solid #172A88;
    border-radius: 5px;
    padding: 8px 12px;
  }
  .mod-date-sel .input-group input[type=text] {
    border: none;
    background-color: #fff;
  }
  .mod-date-sel .input-group input[type=text][placeholder=年] {
    width: 50px;
  }
  .mod-date-sel .input-group input[type=text][placeholder=月], .mod-date-sel .input-group input[type=text][placeholder=日] {
    width: 35px;
  }
  .mod-date-sel .input-group input[type=text][name$=-hour] {
    width: 35px;
  }
  .mod-date-sel .input-group input[type=text][name$=-min] {
    width: 35px;
  }
  .mod-date-sel .input-group span {
    margin: 0 5px;
  }
  .mod-btn {
    cursor: pointer;
  }
  .mod-toggle-icon {
    --boxW:20px;
    --boxH:20px;
    --bar:11px;
    --thick:2px;
    position: relative;
    width: var(--boxW);
    height: var(--boxH);
    border-radius: 50%;
    cursor: pointer;
    transition-duration: 0.2s;
  }
  .mod-toggle-icon.is-fill {
    background-color: #000;
  }
  .mod-toggle-icon.is-fill:before, .mod-toggle-icon.is-fill:after {
    background: #fff;
  }
  .mod-toggle-icon.is-small {
    --boxW:15px;
    --boxH:15px;
    --bar:10px;
    --thick:1px;
  }
  .mod-toggle-icon:before, .mod-toggle-icon:after {
    content: "";
    display: block;
    position: absolute;
    background: #fff;
    top: calc((var(--boxH) - var(--thick)) / 2);
    left: calc((var(--boxW) - var(--bar)) / 2);
    width: var(--bar);
    height: var(--thick);
    /* transform:rotate(-45deg);*/
  }
  .mod-toggle-icon:after {
    transform: rotate(90deg);
  }
  .js-toggle-open .mod-toggle-icon:after {
    display: none;
  }
  .mod-toggle-icon:hover {
    opacity: 0.8;
  }
  .mod-toggle {
    border-radius: 5px;
    text-align: left;
  }
  .mod-toggle + .mod-toggle {
    margin-top: 10px;
  }
  .mod-toggle ._head {
    position: relative;
    cursor: pointer;
    padding: 15px 40px 10px 50px;
    font-size: 14px;
    line-height: 1.4;
    background-color: #036EB8;
    color: #fff;
    font-weight: bold;
  }
  .mod-toggle ._head .mod-toggle-icon {
    position: absolute;
    top: calc(50% - 10px);
    right: 15px;
  }
  .mod-toggle ._head:before {
    content: "Q";
    color: #fff;
    display: block;
    position: absolute;
    top: 50%;
    left: 15px;
    font-size: 24px;
    font-weight: 200;
    transform: translate(0, -50%);
    font-family: serif;
  }
  .mod-toggle ._body {
    position: relative;
    padding: 15px 20px 15px 50px;
    font-size: 14px;
    display: none;
  }
  .mod-toggle ._body:before {
    content: "A";
    color: #036EB8;
    display: block;
    position: absolute;
    top: 50%;
    left: 15px;
    font-size: 24px;
    font-weight: 200;
    transform: translate(0, -50%);
    font-family: serif;
  }
  .mod-toggle ._body p {
    line-height: 1.6;
  }
  .mod-price {
    margin-bottom: 2px;
  }
  .mod-price .mod-toggle-icon {
    --boxW:18px;
    --boxH:18px;
    --bar:18px;
    --thick:2px;
  }
  .mod-price ._head {
    position: relative;
    background-color: #2EA7E0;
    padding: 13px;
    font-weight: bold;
    text-align: left;
    color: #fff;
    font-size: 13px;
  }
  .mod-price ._head .mod-toggle-icon {
    position: absolute;
    top: calc(50% - 10px);
    right: 10px;
  }
  .mod-price ._body {
    display: none;
  }
  .mod-table-price {
    width: 100%;
    background-color: #fff;
  }
  .mod-table-price th {
    border-bottom: 1px solid #172A88;
    padding: 7px;
    line-height: 1.4;
    font-size: 13px;
  }
  .mod-table-price td {
    border-bottom: 1px solid #172A88;
    padding: 7px;
    line-height: 1.4;
    font-size: 13px;
    text-align: right;
  }
}
._test {
  margin: 20px 0;
  background: #ffc;
  padding: 20px;
  border: 1px dashed red;
  vertical-align: middle;
  text-align: center;
}
._test input {
  width: 200px !important;
  display: inline-block;
  vertical-align: middle !important;
}

/*

bg...2000
contents...1200

*/