@charset "UTF-8";
/* =========================
変数 
============================*/
body {
  --s-val: 10px;
  --max-w-menu: 1635px;
  --w-menu: 87vw;
  --base-color: #000;
  --base-color-2: #555;
  --color-dark-blue: #052850;
  --border-color: #555;
  --color-bg-main: #E7E4DD;
  --color-bg-gray: #F7F7F7;
}

/* レスポンシブ */
@media screen and (max-width: 767px) {
  body {
    --s-val: 9px;
  }
}
@media screen and (max-width: 540px) {
  body {
    --w-menu: 100%;
  }
}
/* === このCSSは全ページ共通です === */
/* =========================
共通 
============================*/
body {
  --page-pdg-inline: calc(var(--s-val) * 2);
  --max-w-out: calc(1200px + calc(var(--page-pdg-inline) * 2));
  --max-w-in: calc(1100px + calc(var(--page-pdg-inline) * 2));
  --max-w-offset: calc(1320 / 1440 * 100%);
  --color-bg-txt: #C7C7C7;
  --border-position: 8.3vw;
}

/* =========================
お問い合わせ
============================*/
.footer-cta {
  padding: calc(var(--s-val) * 12) var(--page-pdg-inline);
  position: relative;
}
.footer-cta::before {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.6);
  position: absolute;
  top: 0;
  left: 0;
  z-index: -9;
}
.footer-cta::after {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  background: url(../images/common/footer-cta_bg.webp) no-repeat center center;
  background-size: cover;
  position: absolute;
  top: 0;
  left: 0;
  z-index: -10;
}
.footer-cta__lead {
  color: #fff;
  font-size: calc(var(--s-val) * 4);
  text-align: center;
}
.footer-cta__btn {
  display: block;
  max-width: 238px;
  width: 100%;
  padding: calc(var(--s-val) * 1.5) calc(var(--s-val) * 1);
  margin: calc(var(--s-val) * 2.6) auto 0;
  border-radius: calc(var(--s-val) * 0.5);
  color: var(--color-dark-blue);
  background-color: #fff;
  font-size: calc(var(--s-val) * 1.4);
  font-weight: bold;
  text-align: center;
}

/* レスポンシブ ============= */
@media screen and (max-width: 767px) {
  .footer-cta {
    padding: 15% var(--page-pdg-inline);
  }
  .footer-cta__lead {
    font-size: calc(var(--s-val) * 3.2);
  }
  .footer-cta__btn {
    margin: 5% auto 0;
  }
}
/* =========================
フッター
============================*/
.g-footer__main {
  padding: 6.5% var(--page-pdg-inline) 6%;
  background-color: #555;
  color: #fff;
}
.g-footer__main-menu {
  max-width: var(--max-w-menu);
  width: var(--w-menu);
  margin-inline: auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  gap: 8%;
}
.g-footer__logo {
  width: calc(var(--s-val) * 34.9);
  aspect-ratio: 239/24;
}
.g-footer__logo svg {
  width: 100%;
  height: 100%;
  fill: #fff;
}
.g-footer__list {
  white-space: nowrap;
  font-size: calc(var(--s-val) * 1.4);
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  max-width: 602px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: calc(var(--s-val) * 1) calc(var(--s-val) * 4);
}
.g-footer__list a {
  display: block;
}
.g-footer__contact a {
  line-height: 1em;
  color: #fff;
  background-color: var(--color-dark-blue);
  width: calc(var(--s-val) * 11.8);
  aspect-ratio: 118/28;
  padding: 0 calc(var(--s-val) * 0.5);
  border-radius: calc(var(--s-val) * 0.3);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.g-footer__sns {
  max-width: var(--max-w-menu);
  width: var(--w-menu);
  margin: calc(var(--s-val) * 1.8) auto 0;
  padding-left: 7px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: calc(var(--s-val) * 1.5);
}
.g-footer__sns a {
  width: calc(var(--s-val) * 2.4);
  aspect-ratio: 1/1;
}
.g-footer__sns a svg {
  width: 100%;
  height: 100%;
  fill: #fff;
}
.g-footer__sub {
  padding: 2% var(--page-pdg-inline);
}
.g-footer__sub-menu {
  white-space: nowrap;
  color: #555;
  font-size: calc(var(--s-val) * 1.4);
  max-width: var(--max-w-menu);
  width: var(--w-menu);
  margin-inline: auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: calc(var(--s-val) * 1) 0;
}
.g-footer__sub-menu li {
  padding: calc(var(--s-val) * 0.1) calc(var(--s-val) * 1);
}
.g-footer__sub-menu li:not(:last-of-type) {
  border-right: 1px solid currentColor;
}
.g-footer__sub-menu li:last-of-type {
  -webkit-padding-end: 0;
          padding-inline-end: 0;
}

/* レスポンシブ ============= */
@media screen and (max-width: 767px) {
  .g-footer__main {
    padding: 9% var(--page-pdg-inline) 8%;
  }
  .g-footer__main-menu {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: calc(var(--s-val) * 3);
  }
  .g-footer__logo {
    width: 100%;
    max-width: 314px;
  }
  .g-footer__list {
    max-width: 100%;
    width: 100%;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    gap: calc(var(--s-val) * 0.8) calc(var(--s-val) * 2);
  }
  .g-footer__sns {
    margin: calc(var(--s-val) * 3) auto 0;
  }
  .g-footer__sub-menu {
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
}
@media screen and (max-width: 428px) {
  .g-footer__main {
    padding: 11% var(--page-pdg-inline) 10%;
  }
  .g-footer__list {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
  .g-footer__sub {
    padding: 4% var(--page-pdg-inline);
  }
  .g-footer__sub-menu {
    max-width: 250px;
  }
  .g-footer__sub-menu li {
    border-right: 1px solid currentColor;
  }
  .g-footer__sub-menu li:nth-last-of-type(even) {
    border-left: 1px solid currentColor;
  }
  .g-footer__sub-menu li:last-of-type {
    padding: calc(var(--s-val) * 0.1) calc(var(--s-val) * 1);
  }
}