@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@200..900&display=swap");
/* ----------

Setting - variables
各種変数

---------- */
/* ----------

Setting - layouts
レイアウト設定

---------- */
/*** The new CSS reset - version 1.11.3 (last updated 25.8.2024) ***/
/* line 3, generics/_reset.scss */
*:where(:not(html,iframe,canvas,img,svg,video,audio):not(svg *,symbol *)) {
  all: unset;
  display: revert; }

/* line 3, generics/_reset.scss */
*, *::before, *::after {
  box-sizing: border-box; }

/* line 3, generics/_reset.scss */
html {
  -moz-text-size-adjust: none;
  -webkit-text-size-adjust: none;
  text-size-adjust: none; }

/* line 3, generics/_reset.scss */
a, button {
  cursor: revert; }

/* line 3, generics/_reset.scss */
ol, ul, menu, summary {
  list-style: none; }

/* line 3, generics/_reset.scss */
ol {
  counter-reset: revert; }

/* line 3, generics/_reset.scss */
img {
  max-inline-size: 100%;
  max-block-size: 100%; }

/* line 3, generics/_reset.scss */
table {
  border-collapse: collapse; }

/* line 3, generics/_reset.scss */
input, textarea {
  -webkit-user-select: auto; }

/* line 3, generics/_reset.scss */
textarea {
  white-space: revert; }

/* line 3, generics/_reset.scss */
meter {
  -webkit-appearance: revert;
  appearance: revert; }

/* line 3, generics/_reset.scss */
:where(pre) {
  all: revert;
  box-sizing: border-box; }

/* line 3, generics/_reset.scss */
::placeholder {
  color: unset; }

/* line 3, generics/_reset.scss */
:where([hidden]) {
  display: none; }

/* line 3, generics/_reset.scss */
:where([contenteditable]:not([contenteditable="false"])) {
  -moz-user-modify: read-write;
  -webkit-user-modify: read-write;
  overflow-wrap: break-word;
  -webkit-line-break: after-white-space;
  -webkit-user-select: auto; }

/* line 3, generics/_reset.scss */
:where([draggable="true"]) {
  -webkit-user-drag: element; }

/* line 3, generics/_reset.scss */
:where(dialog:modal) {
  all: revert;
  box-sizing: border-box; }

/* line 3, generics/_reset.scss */
::-webkit-details-marker {
  display: none; }

/* line 1, generics/_shared.scss */
* {
  font-size: 14px;
  font-weight: 600;
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-family: "Noto Serif JP", "Hiragino Mincho ProN", "YuMincho", "Yu Mincho", "MS PMincho", serif;
  letter-spacing: .2em; }

/* line 19, generics/_shared.scss */
a {
  color: #b1a48b;
  transition: all .3s; }
  /* line 23, generics/_shared.scss */
  a:hover {
    color: #009be1; }
  /* line 28, generics/_shared.scss */
  a[href*=".pdf"]::before {
    margin-right: 0.5em;
    content: url("/images/generics/shared/a/pdf.svg");
    vertical-align: middle; }

/* line 36, generics/_shared.scss */
small {
  font-size: .8em; }

/* line 41, generics/_shared.scss */
label {
  vertical-align: middle; }

/* line 45, generics/_shared.scss */
tr:empty {
  display: none; }

/* CSS Document */
/*
Whats: ヘッダー
How  : ヘッダー（navが子として入る）
Included in：app.scss
*/
/* line 7, objects/header.scss */
.header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  background-color: #fff;
  color: #4d6381;
  z-index: 1000;
  text-align: center; }
  /* line 19, objects/header.scss */
  .header__inner {
    margin-inline: auto;
    display: flex;
    align-items: center; }
    @media screen and (min-width: 800px) {
      /* line 19, objects/header.scss */
      .header__inner {
        max-width: 1200px;
        min-width: auto; } }
    @media screen and (max-width: 800px) {
      /* line 19, objects/header.scss */
      .header__inner {
        width: 100%; } }
  /* line 24, objects/header.scss */
  .header__logo, .header__title, .header__right {
    flex: 1; }
  /* line 27, objects/header.scss */
  .header__logo {
    text-align: left; }
    /* line 29, objects/header.scss */
    .header__logo > a {
      display: inline-block; }
      /* line 31, objects/header.scss */
      .header__logo > a > img {
        width: 112px;
        height: auto; }
  /* line 38, objects/header.scss */
  .header__title > a {
    display: block;
    line-height: 1;
    color: #1a1a1a;
    font-size: 25px;
    font-weight: 700; }
  /* line 46, objects/header.scss */
  .header__right {
    display: flex;
    justify-content: flex-end;
    align-items: center; }
    /* line 52, objects/header.scss */
    .header__right > div:not(:last-child) {
      padding-right: 10px;
      margin-right: 10px;
      border-right: 1px solid #4d6381; }
    /* line 57, objects/header.scss */
    .header__right > div > ul {
      display: flex;
      justify-content: flex-end;
      gap: 10px; }
    /* line 63, objects/header.scss */
    .header__right-sns > ul > li > a > img {
      width: auto;
      height: 27px; }
    /* line 67, objects/header.scss */
    .header__right-menu > ul > li > a {
      line-height: 1; }
      /* line 69, objects/header.scss */
      .header__right-menu > ul > li > a > img {
        width: auto;
        height: 40px; }
      /* line 73, objects/header.scss */
      .header__right-menu > ul > li > a > span {
        display: block;
        font-size: 10px;
        letter-spacing: 0; }
  /* line 81, objects/header.scss */
  .header__gnav-button {
    display: none; }
  @media screen and (min-width: 800px) {
    /* line 7, objects/header.scss */
    .header {
      height: 100px; }
      /* line 87, objects/header.scss */
      .header__inner {
        position: relative;
        padding: 30px 50px 0; } }
  @media screen and (max-width: 800px) {
    /* line 7, objects/header.scss */
    .header {
      width: 100vw;
      height: 84px; }
      /* line 95, objects/header.scss */
      .header__inner {
        padding: 15px; }
      /* line 98, objects/header.scss */
      .header__title {
        display: none;
        padding: 0 15px; }
        /* line 101, objects/header.scss */
        .header__title > a {
          line-height: 1;
          font-size: clamp(12px, 4.4vw, 24px);
          white-space: nowrap; }
      /* line 107, objects/header.scss */
      .header__gnav-button {
        display: block; } }

/*
Whats: header-address
How  : ヘッダー内address
Included in：app.scss
*/
/* line 8, objects/header-address.scss */
.header-address a {
  color: #4d6381; }
/* line 11, objects/header-address.scss */
.header-address__tel, .header-address__fax, .header-address__map > a {
  background-repeat: no-repeat; }
/* line 14, objects/header-address.scss */
.header-address__tel, .header-address__fax {
  padding-left: 20px;
  background-position: left 50%;
  background-size: 14px auto; }
/* line 19, objects/header-address.scss */
.header-address__tel {
  background-image: url("../img/common/icon-tel.svg"); }
/* line 22, objects/header-address.scss */
.header-address__fax {
  background-image: url("../img/common/icon-fax.svg"); }
/* line 25, objects/header-address.scss */
.header-address__map > a {
  display: block;
  padding-top: 26px;
  background-position: center top;
  background-size: 16px auto;
  background-image: url("../img/common/icon-map.svg"); }
@media screen and (min-width: 800px) {
  /* line 7, objects/header-address.scss */
  .header-address {
    display: grid;
    grid-template-columns: auto 40px;
    grid-template-rows: repeat(2, 20px);
    grid-column-gap: 20px;
    grid-row-gap: 6px; }
    /* line 40, objects/header-address.scss */
    .header-address__tel {
      grid-column: 1 / 2;
      grid-row: 1 / 2; }
    /* line 44, objects/header-address.scss */
    .header-address__fax {
      grid-column: 1 / 2;
      grid-row: 2 / 3; }
    /* line 48, objects/header-address.scss */
    .header-address__map {
      grid-column: 2 / 3;
      grid-row: 1 / 3; } }
@media screen and (max-width: 800px) {
  /* line 55, objects/header-address.scss */
  .header-address__tel, .header-address__fax {
    display: none; } }

/*
Whats: header-nav
How  : ヘッダー内nav枠
Included in：app.scss
*/
/* line 7, objects/gnav.scss */
.gnav {
  width: 100%;
  z-index: 2000; }
  /* line 10, objects/gnav.scss */
  .gnav__inner {
    margin-inline: auto; }
    @media screen and (min-width: 800px) {
      /* line 10, objects/gnav.scss */
      .gnav__inner {
        max-width: 1200px;
        min-width: auto; } }
    @media screen and (max-width: 800px) {
      /* line 10, objects/gnav.scss */
      .gnav__inner {
        width: 100%; } }
  @media screen and (min-width: 800px) {
    /* line 7, objects/gnav.scss */
    .gnav {
      position: fixed;
      top: 100px;
      height: 68px;
      background-color: #fff; }
      /* line 19, objects/gnav.scss */
      .gnav__button {
        display: none; } }
  @media screen and (max-width: 800px) {
    /* line 7, objects/gnav.scss */
    .gnav {
      position: fixed;
      top: 0;
      max-height: 80vh;
      margin-top: 84px;
      padding-bottom: 15px;
      width: 100vw;
      overflow-y: scroll;
      overflow-x: hidden; }
      /* line 33, objects/gnav.scss */
      .gnav__button {
        display: block;
        position: absolute;
        top: -69px;
        right: 15px;
        width: 40px;
        height: 40px; } }

/*
Whats: gnav-button
How  : グローバルナビボタン
Included in：app.scss
*/
/* line 7, objects/gnav-button.scss */
.gnav-button {
  position: relative;
  display: block;
  width: 40px;
  padding: 0;
  margin: 0;
  cursor: pointer; }
  /* line 17, objects/gnav-button.scss */
  .gnav-button__icon {
    position: relative;
    display: block;
    width: 40px;
    height: 40px;
    margin-inline: auto;
    background-color: #4d6381;
    border-radius: 50%; }
    /* line 26, objects/gnav-button.scss */
    .gnav-button__icon > span {
      content: '';
      position: absolute;
      top: 12px;
      left: 8px;
      display: block;
      width: 24px;
      height: 3px;
      border-radius: 1px;
      margin-bottom: 3px;
      background: #fff;
      transition: all .3s; }
      /* line 39, objects/gnav-button.scss */
      .gnav-button__icon > span:nth-child(2) {
        top: 19px; }
      /* line 42, objects/gnav-button.scss */
      .gnav-button__icon > span:nth-child(3) {
        top: 26px; }
  /* line 47, objects/gnav-button.scss */
  .gnav-button__text {
    position: absolute;
    top: 41px;
    font-size: 10px;
    display: block;
    width: 100%;
    color: #4d6381;
    letter-spacing: 0; }
  /* line 58, objects/gnav-button.scss */
  .gnav-button.--active .gnav-button__icon {
    transform: rotate(45deg); }
    /* line 63, objects/gnav-button.scss */
    .gnav-button.--active .gnav-button__icon > span:nth-child(1) {
      transform-origin: center center;
      transform: rotate(90deg) translateX(7px); }
    /* line 69, objects/gnav-button.scss */
    .gnav-button.--active .gnav-button__icon > span:nth-child(3) {
      transform-origin: center center;
      transform: rotate(-90deg) translateX(7px);
      opacity: 0; }

/*
Whats: header-nav-list
How  : ヘッダーnav内のリスト
Included in：app.scss
*/
/* line 7, objects/gnav-list.scss */
.gnav-list {
  position: relative; }
  /* line 10, objects/gnav-list.scss */
  .gnav-list > ul > li {
    text-align: center; }
    /* line 12, objects/gnav-list.scss */
    .gnav-list > ul > li > a {
      font-size: 10px;
      font-weight: 800;
      color: #000;
      letter-spacing: .25em; }
      /* line 18, objects/gnav-list.scss */
      .gnav-list > ul > li > a > span {
        display: block;
        font-size: 15px;
        font-weight: 800;
        color: #4d6381;
        letter-spacing: 0; }
      /* line 26, objects/gnav-list.scss */
      .gnav-list > ul > li > a:hover > span {
        color: #009be1; }
    /* line 31, objects/gnav-list.scss */
    .gnav-list > ul > li.--current > a > span {
      color: #009be1; }
  /* line 36, objects/gnav-list.scss */
  .gnav-list__tel {
    color: #4d6381; }
    /* line 39, objects/gnav-list.scss */
    .gnav-list__tel > a {
      display: block;
      font-size: 16px;
      text-align: center;
      color: #4d6381; }
      /* line 45, objects/gnav-list.scss */
      .gnav-list__tel > a:before {
        content: '';
        display: inline-block;
        width: 14px;
        height: 23px;
        margin-right: 5px;
        vertical-align: bottom;
        background-position: center center;
        background-size: contain;
        background-image: url("../img/common/icon-tel.svg");
        background-repeat: no-repeat; }
  @media screen and (min-width: 800px) {
    /* line 61, objects/gnav-list.scss */
    .gnav-list > ul {
      display: inline-flex;
      justify-content: center;
      gap: 50px;
      width: 100%;
      height: 68px;
      align-items: center; }
      /* line 69, objects/gnav-list.scss */
      .gnav-list > ul > li {
        display: inline-block;
        text-align: center; }
    /* line 74, objects/gnav-list.scss */
    .gnav-list__tel {
      position: absolute;
      right: 50px;
      bottom: 25px; } }
  @media screen and (max-width: 800px) {
    /* line 7, objects/gnav-list.scss */
    .gnav-list {
      position: fixed;
      top: 84px;
      display: block;
      width: 100%;
      padding-bottom: 15px;
      background-color: #fff;
      text-align: center;
      opacity: 0;
      pointer-events: none;
      transition: all .7s; }
      /* line 92, objects/gnav-list.scss */
      .gnav-list.--active {
        opacity: 1;
        pointer-events: auto; }
      /* line 97, objects/gnav-list.scss */
      .gnav-list > ul {
        width: 100%;
        padding: 15px 0 0;
        border-top: 2px solid #edebe8; }
        /* line 102, objects/gnav-list.scss */
        .gnav-list > ul > li {
          display: block;
          border-bottom: 2px solid #edebe8; }
          /* line 105, objects/gnav-list.scss */
          .gnav-list > ul > li > a {
            display: block;
            width: 100%;
            padding: 1em; }
      /* line 113, objects/gnav-list.scss */
      .gnav-list__tel > a {
        display: block;
        width: 100%;
        padding: 1em; } }

/*
Whats: Main
How  : mainタグ（コンテンツボディ）
Included in：app.scss
*/
/* line 6, objects/main.scss */
.main {
  margin-top: 168px;
  min-height: calc(100vh - 100px);
  padding-bottom: 60px;
  background-image: url("../img/common/main-bg.png"); }
  @media screen and (max-width: 800px) {
    /* line 6, objects/main.scss */
    .main {
      margin-top: 84px;
      padding-bottom: 30px; } }

/*
Whats: フッター
How  : フッター（footer-navが子として入る）
Included in：app.scss
*/
/* line 7, objects/footer.scss */
.footer {
  position: relative;
  bottom: 0;
  left: 0;
  right: 0;
  height: auto;
  /* フッターの高さ */
  background-color: #d1cdc5;
  color: #1a1a1a;
  text-align: center;
  z-index: 1000; }
  /* line 19, objects/footer.scss */
  .footer__inner {
    margin-inline: auto;
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 60px 0; }
    @media screen and (min-width: 800px) {
      /* line 19, objects/footer.scss */
      .footer__inner {
        max-width: 1200px;
        min-width: auto; } }
    @media screen and (max-width: 800px) {
      /* line 19, objects/footer.scss */
      .footer__inner {
        width: 100%; } }
  /* line 26, objects/footer.scss */
  .footer__copyright {
    padding: 1em 0;
    text-align: center;
    color: #1a1a1a;
    background-image: url("../img/common/main-bg.png");
    font-size: 10px; }
  @media screen and (min-width: 800px) {
    /* line 38, objects/footer.scss */
    .footer__address {
      display: inline-block;
      margin-right: 60px;
      padding-right: 60px;
      border-right: 1px solid #1a1a1a; } }
  @media screen and (max-width: 800px) {
    /* line 46, objects/footer.scss */
    .footer__inner {
      display: block;
      text-align: center;
      padding: 30px 15px; }
      /* line 50, objects/footer.scss */
      .footer__inner > .footer__nav {
        grid-area: nav; }
      /* line 51, objects/footer.scss */
      .footer__inner > .footer__address {
        grid-area: address; }
      /* line 52, objects/footer.scss */
      .footer__inner > .footer__copyright {
        grid-area: copyright; }
    /* line 54, objects/footer.scss */
    .footer__address {
      padding: 30px 0;
      margin-bottom: 30px;
      border-bottom: 1px solid #1a1a1a; }
    /* line 59, objects/footer.scss */
    .footer__nav {
      padding: 0 15px; } }

/*
Whats: フッター内nav
Included in：app.scss
*/
@media screen and (min-width: 800px) {
  /* line 5, objects/footer-nav.scss */
  .footer-nav {
    display: flex;
    justify-content: flex-start;
    gap: 0 30px;
    font-weight: 700; } }
/* line 13, objects/footer-nav.scss */
.footer-nav a {
  color: #1a1a1a; }
  /* line 15, objects/footer-nav.scss */
  .footer-nav a:hover {
    color: #009be1; }
/* line 19, objects/footer-nav.scss */
.footer-nav li {
  text-align: left; }
/* line 23, objects/footer-nav.scss */
.footer-nav > div {
  flex: 0 0 auto; }
  /* line 25, objects/footer-nav.scss */
  .footer-nav > div.--full {
    flex: 1 1 100%;
    margin-bottom: 15px; }
  /* line 30, objects/footer-nav.scss */
  .footer-nav > div > li:not(:last-child) {
    margin-bottom: 15px; }
  /* line 34, objects/footer-nav.scss */
  .footer-nav > div > li > a {
    font-size: 16px;
    display: block;
    padding-left: 24px;
    min-height: 18px;
    background-image: url("../img/common/arrow.svg");
    background-position: left center;
    background-repeat: no-repeat;
    background-size: 12px auto; }
    /* line 43, objects/footer-nav.scss */
    .footer-nav > div > li > a:hover {
      background-image: url("../img/common/arrow-point.svg"); }
  /* line 47, objects/footer-nav.scss */
  .footer-nav > div > li > ul {
    padding-top: 7.5px;
    padding-left: 1em; }
    /* line 51, objects/footer-nav.scss */
    .footer-nav > div > li > ul > li:not(:last-child) {
      margin-bottom: 10px; }
    /* line 54, objects/footer-nav.scss */
    .footer-nav > div > li > ul > li > a {
      font-size: 14px;
      padding-left: 1em; }
      /* line 57, objects/footer-nav.scss */
      .footer-nav > div > li > ul > li > a:before {
        content: '・'; }
@media screen and (max-width: 800px) {
  /* line 5, objects/footer-nav.scss */
  .footer-nav {
    display: flex;
    flex-wrap: wrap; }
    /* line 70, objects/footer-nav.scss */
    .footer-nav > div {
      flex: 1 1 45%;
      margin-bottom: 15px; }
      /* line 74, objects/footer-nav.scss */
      .footer-nav > div:nth-child(3) {
        flex: 2;
        width: 100%; }
      /* line 79, objects/footer-nav.scss */
      .footer-nav > div > li {
        margin-bottom: 15px; }
        /* line 82, objects/footer-nav.scss */
        .footer-nav > div > li > ul {
          margin-left: 0; }
          /* line 85, objects/footer-nav.scss */
          .footer-nav > div > li > ul > li {
            margin-bottom: 7.5px; }
            /* line 88, objects/footer-nav.scss */
            .footer-nav > div > li > ul > li > a {
              padding-left: 0; } }

/*
Whats: フッターaddress内プロフィール
Included in：app.scss
*/
/* line 5, objects/footer-profile.scss */
.footer-profile {
  text-align: center;
  font-size: 14px;
  font-weight: 700; }
  /* line 10, objects/footer-profile.scss */
  .footer-profile__logo {
    max-width: 155px;
    height: auto;
    margin-bottom: 10px; }
  /* line 15, objects/footer-profile.scss */
  .footer-profile__name {
    font-size: 20px; }
  /* line 18, objects/footer-profile.scss */
  .footer-profile__code {
    font-size: 12px; }
  /* line 21, objects/footer-profile.scss */
  .footer-profile__address {
    margin-bottom: 20px;
    font-size: 15px; }
  /* line 25, objects/footer-profile.scss */
  .footer-profile__tel {
    font-size: 19px; }
    /* line 27, objects/footer-profile.scss */
    .footer-profile__tel img {
      width: 23px;
      height: auto;
      margin-right: 5px;
      vertical-align: bottom; }
  /* line 34, objects/footer-profile.scss */
  .footer-profile__map {
    display: block;
    margin-top: 20px;
    /*display: inline-block;
    width: 158px;
    border-radius: 20px;
    background-image: url("../img/common/arrow-circle-white.svg");
    background-position: left center;
    background-repeat: no-repeat;
    background-size: 18px auto;
    */ }
    /* line 37, objects/footer-profile.scss */
    .footer-profile__map img {
      height: 39px;
      width: 158px; }

/*
Whats: section
How  : sectionタグ
Included in：app.scss
*/
/* line 6, objects/section.scss */
.section {
  margin-bottom: 60px; }
  /* line 7, objects/section.scss */
  .section__inner {
    margin-inline: auto; }
    @media screen and (min-width: 800px) {
      /* line 7, objects/section.scss */
      .section__inner {
        max-width: 1200px;
        min-width: auto; } }
    @media screen and (max-width: 800px) {
      /* line 7, objects/section.scss */
      .section__inner {
        width: 100%; } }
  /* line 12, objects/section.scss */
  .section.--bg_primary {
    background-color: #4d6381; }
    /* line 14, objects/section.scss */
    .section.--bg_primary * {
      color: #fff; }
  /* line 18, objects/section.scss */
  .section.--bg_secondary {
    background-color: #f4ece0; }
  /* line 21, objects/section.scss */
  .section.--bg_gray {
    background-color: #d1cdc5; }
  /* line 24, objects/section.scss */
  .section.--bg_palegray {
    background-color: #edebe8; }
  /* line 27, objects/section.scss */
  .section.--bg_white {
    background-color: #fff; }
  /* line 31, objects/section.scss */
  .section p {
    line-height: 2em;
    margin-bottom: 1em; }

/*
Whats: box
How?:  汎用paddingを持つ箱
Included in：app.scss
*/
@media screen and (min-width: 800px) {
  /* line 7, components/box.scss */
  .box {
    padding: 60px 30px; } }
@media screen and (max-width: 800px) {
  /* line 7, components/box.scss */
  .box {
    padding: 45px 15px 30px; } }

/*
Whats: button
How?:  各種ボタン
Included in：app.scss
*/
/* line 7, components/button.scss */
.button {
  --btn-color-text: #4d6381;
  --btn-color-bg: #fff;
  --btn-color-border: #4d6381;
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
  font-size: 18px;
  font-weight: 600;
  line-height: 1;
  letter-spacing: .15em;
  color: var(--btn-color-text);
  cursor: pointer;
  transition: all .5s; }
  /* line 29, components/button.scss */
  .button.--send {
    display: block;
    font-size: 14px; }
    /* line 32, components/button.scss */
    .button.--send > img {
      display: block;
      width: 50px;
      height: auto;
      margin-inline: auto;
      margin-bottom: 5px; }
  /* line 40, components/button.scss */
  .button:hover {
    filter: brightness(1.1);
    opacity: .9; }
  /* line 45, components/button.scss */
  .button.--small {
    font-size: 9px;
    min-width: 100px; }
  /* line 50, components/button.scss */
  .button.--large {
    min-width: 140px;
    padding: 0;
    border-radius: 15px;
    font-size: 13px;
    letter-spacing: .5em;
    line-height: 42px; }
  /* line 59, components/button.scss */
  .button.--secondary {
    --btn-color-bg: #b1a48b;
    --btn-color-border: #b1a48b; }
  /* line 65, components/button.scss */
  .button.--bordered {
    color: var(--btn-color-bg);
    background-color: var(--btn-color-text);
    border: 2px solid var(--btn-color-bg); }
  /* line 71, components/button.scss */
  .button.--arrow {
    padding-left: 25px;
    background-image: url("../img/common/arrow-primary.svg");
    background-position: left bottom;
    background-repeat: no-repeat;
    background-size: 20px auto; }
    /* line 78, components/button.scss */
    .button.--arrow.--bordered {
      background-image: url("../img/common/arrow-primary.svg"); }
      /* line 80, components/button.scss */
      .button.--arrow.--bordered.--secondary {
        background-image: url("../img/common/arrow-secondary.svg"); }

/*
Whats: button-box
How?:  ボタン配置用　基本センタリング、flex
Included in：app.scss
*/
/* line 7, components/button-box.scss */
.button-box {
  display: flex;
  justify-content: center;
  flex-wrap: wrap; }
  @media screen and (min-width: 800px) {
    /* line 7, components/button-box.scss */
    .button-box {
      padding: 60px 30px; } }
  @media screen and (max-width: 800px) {
    /* line 7, components/button-box.scss */
    .button-box {
      padding: 45px 15px 30px; } }
  @media screen and (min-width: 800px) {
    /* line 7, components/button-box.scss */
    .button-box {
      gap: 30px; } }
  @media screen and (max-width: 800px) {
    /* line 7, components/button-box.scss */
    .button-box {
      gap: 15px; } }

/*
Whats: fadein
How?:  スクロール時アニメーション用スタイル
Included in：app.scss
*/
/* line 9, components/fadein.scss */
.fadein {
  opacity: 0;
  transition: all 1.2s;
  transform: translate(0, 50px); }
  /* line 14, components/fadein.scss */
  .fadein.scrollin {
    opacity: 1 !important;
    transform: translate(0, 0) !important; }

/*
Whats: fadein-haader
How?:  トップのみヘッダー（＋fnav）をスクロール時に表示させる場合に使用する
Included in：app.scss
*/
@media screen and (min-width: 800px) {
  /* line 9, components/fadein-header.scss */
  body.--top .header, body.--top .gnav {
    opacity: 0;
    pointer-events: none;
    transition: opacity 1s; }
    /* line 15, components/fadein-header.scss */
    body.--top .header.--show, body.--top .gnav.--show {
      opacity: 1;
      pointer-events: auto; }
  /* line 21, components/fadein-header.scss */
  body.--top .main {
    margin-top: 0;
    min-height: 100vh; } }
/*
Whats: form
How?:  フォーム内基本パーツ

・フォームのアイテムはそれぞれitem化
・ラベル→input　pcは横並び　spでは改行
・必須（Required）用にinput右側を2emあける
　※ない場合のも作ったほうがいいかも？
・ラベル以外にnote枠を作る　spは改行

Included in：app.scss
*/
/* line 15, components/form.scss */
.form p {
  line-height: 1; }
/* line 18, components/form.scss */
.form__inner {
  margin-inline: auto; }
  @media screen and (min-width: 800px) {
    /* line 18, components/form.scss */
    .form__inner {
      max-width: 830px;
      min-width: auto; } }
  @media screen and (max-width: 800px) {
    /* line 18, components/form.scss */
    .form__inner {
      width: 100%; } }
  /* line 21, components/form.scss */
  .form__inner.--border-top {
    border-top: 1px dashed #4d6381; }
/* line 25, components/form.scss */
.form__note {
  color: #274b89;
  text-align: right; }
/* line 29, components/form.scss */
.form-wrapper {
  margin-inline: 50px;
  background-color: #fff; }
/* line 33, components/form.scss */
.form-item {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: .5em 1em; }
  /* line 38, components/form.scss */
  .form-item > p {
    margin-bottom: 0; }
  /* line 41, components/form.scss */
  .form-item:not(:last-child) {
    margin-bottom: 15px; }
  /* line 44, components/form.scss */
  .form-item.--confirm {
    justify-content: center;
    flex-wrap: nowrap;
    gap: 1em; }
  /* line 49, components/form.scss */
  .form-item__label, .form-item__input, .form-item__note, .form-item__error {
    width: 100%; }
  /* line 52, components/form.scss */
  .form-item__label {
    font-size: 15px; }
  /* line 55, components/form.scss */
  .form-item__note {
    margin-bottom: 0 !important;
    color: #274b89;
    font-size: 14px;
    text-align: left; }
  /* line 61, components/form.scss */
  .form-item__input, .form-item__textarea {
    width: 100%;
    padding: .5em;
    border: 1px solid #999;
    background-color: #fff;
    font-size: 14px;
    letter-spacing: 0; }
    /* line 67, components/form.scss */
    .form-item__input::placeholder, .form-item__textarea::placeholder {
      color: #999; }
  /* line 73, components/form.scss */
  .form-item__input.--name {
    flex: 0 0 120px;
    width: 120px; }
  /* line 78, components/form.scss */
  .form-item__checkbox, .form-item__radio {
    position: relative;
    display: inline-flex;
    justify-content: center;
    align-items: center;
    width: 24px;
    height: 24px;
    cursor: pointer;
    letter-spacing: 0; }
    /* line 90, components/form.scss */
    .form-item__checkbox::before, .form-item__radio::before {
      content: '';
      position: absolute;
      display: block;
      width: 24px;
      height: 24px;
      border: 1px solid #999; }
    /* line 98, components/form.scss */
    .form-item__checkbox::after, .form-item__radio::after {
      content: '';
      position: absolute;
      display: block;
      width: 24px;
      height: 24px;
      background-image: url("../img/common/checkbox-cross.svg");
      background-position: center center;
      background-repeat: no-repeat;
      background-size: cover;
      opacity: 0;
      transition: all .25s; }
    /* line 111, components/form.scss */
    .form-item__checkbox:checked::after, .form-item__radio:checked::after {
      opacity: 1; }
  /* line 115, components/form.scss */
  .form-item__textarea {
    height: 10em; }
  /* line 118, components/form.scss */
  .form-item__error {
    color: #a00;
    font-weight: 600; }
@media screen and (min-width: 800px) {
  /* line 127, components/form.scss */
  .form-item.--check {
    justify-content: center; }
  /* line 130, components/form.scss */
  .form-item.--type {
    margin-left: 154px; }
  /* line 133, components/form.scss */
  .form-item__label {
    flex: 0 0 140px; }
  /* line 136, components/form.scss */
  .form-item__note {
    display: inline-block;
    flex: 1;
    order: 3;
    line-height: 1; }
    /* line 141, components/form.scss */
    .form-item__note.--wrap {
      width: 100%;
      padding-left: 154px;
      white-space: nowrap; }
  /* line 147, components/form.scss */
  .form-item__input, .form-item__textarea {
    order: 2;
    flex: 0 0 375px; }
  /* line 151, components/form.scss */
  .form-item__error {
    order: 4; }
  /* line 155, components/form.scss */
  .form-item.--full .form-item__label {
    flex: 0 0 auto;
    width: fit-content; }
  /* line 159, components/form.scss */
  .form-item.--full .form-item__input, .form-item.--full .form-item__textarea {
    flex: 1 1 100%; }
  /* line 162, components/form.scss */
  .form-item.--full .form-item__note {
    display: block;
    order: 2;
    flex: 1;
    align-self: flex-end; }
  /* line 169, components/form.scss */
  .form-item__br {
    display: none; } }
@media screen and (max-width: 800px) {
  /* line 175, components/form.scss */
  .form-wrapper {
    margin-inline: 15px;
    padding: 15px; }
  /* line 179, components/form.scss */
  .form-item {
    align-items: center;
    gap: .5em; }
    /* line 182, components/form.scss */
    .form-item:not(:last-child) {
      margin-bottom: 30px; }
    /* line 185, components/form.scss */
    .form-item__br {
      flex: 1 1 100%;
      height: 0;
      margin-bottom: 0; }
    /* line 190, components/form.scss */
    .form-item__note {
      flex: 1 1 auto;
      margin-right: auto;
      margin-bottom: 0 !important;
      letter-spacing: 0; }
    /* line 196, components/form.scss */
    .form-item__label, .form-item__note {
      display: inline-block;
      width: auto;
      line-height: 14px; } }

/*
Whats: title
How?:  各種タイトル
Included in：app.scss
*/
/* line 8, components/title.scss */
.title-h2 {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  margin-bottom: 30px;
  text-align: center;
  font-size: 12px;
  line-height: 1;
  color: #1a1a1a;
  font-weight: 700; }
  /* line 20, components/title.scss */
  .title-h2 > span {
    display: block;
    margin-bottom: 18px;
    font-size: 50px;
    font-weight: 400;
    letter-spacing: .1em;
    color: #4d6381; }
/* line 30, components/title.scss */
.title-h3 {
  color: #4d6381;
  margin-bottom: 15px;
  font-size: 22px;
  text-align: center; }
/* line 36, components/title.scss */
.title-h4 {
  color: #009be1;
  margin-bottom: 30px;
  font-size: 22px;
  text-align: center;
  line-height: 1; }
  /* line 42, components/title.scss */
  .title-h4 > span {
    font-size: 12px;
    color: #1a1a1a; }
/* line 48, components/title.scss */
.title-flag {
  display: flex;
  align-items: center;
  margin-bottom: 15px;
  font-size: 22px;
  color: #4d6381; }
  /* line 55, components/title.scss */
  .title-flag:before {
    content: '';
    display: inline-block;
    width: 24px;
    height: 34px;
    margin-right: 10px;
    background: url("../../img/common/icon_title-flag.svg");
    background-position: left center;
    background-repeat: no-repeat;
    background-size: 24px auto; }
@media screen and (max-width: 800px) {
  /* line 69, components/title.scss */
  .title-h2 {
    font-size: clamp(12px, 2.2vw, 14px); }
    /* line 71, components/title.scss */
    .title-h2 > span {
      white-space: nowrap;
      font-size: clamp(20px, 12vw, 40px); }
  /* line 76, components/title.scss */
  .title-h3 {
    font-size: clamp(12px, 5.2vw, 18px); } }

/*
Whats: secondary-header
How?:  セカンダリ　タイトル・リードまわり
Included in：app.scss
*/
/* line 9, components/secondary-header.scss */
.secondary-header {
  text-align: center; }
  @media screen and (min-width: 800px) {
    /* line 9, components/secondary-header.scss */
    .secondary-header {
      padding: 60px 30px; } }
  @media screen and (max-width: 800px) {
    /* line 9, components/secondary-header.scss */
    .secondary-header {
      padding: 45px 15px 30px; } }
  /* line 13, components/secondary-header.scss */
  .secondary-header__title {
    padding-top: 30px;
    margin-bottom: 30px;
    text-align: center; }
  /* line 18, components/secondary-header.scss */
  .secondary-header__icon {
    height: 28px;
    width: auto; }
  /* line 22, components/secondary-header.scss */
  .secondary-header__read {
    padding-top: 15px; }
    /* line 24, components/secondary-header.scss */
    .secondary-header__read p {
      font-size: 12px;
      line-height: 2.5em;
      text-align: center;
      margin-bottom: 1em; }

/* Slider */
/* line 3, components/slick.scss */
.slick-slider {
  position: relative;
  display: block;
  box-sizing: border-box;
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -khtml-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  -ms-touch-action: pan-y;
  touch-action: pan-y;
  -webkit-tap-highlight-color: transparent; }

/* line 17, components/slick.scss */
.slick-list {
  position: relative;
  overflow: hidden;
  display: block;
  margin: 0;
  padding: 0; }
  /* line 24, components/slick.scss */
  .slick-list:focus {
    outline: none; }
  /* line 28, components/slick.scss */
  .slick-list.dragging {
    cursor: pointer;
    cursor: hand; }

/* line 33, components/slick.scss */
.slick-slider .slick-track,
.slick-slider .slick-list {
  -webkit-transform: translate3d(0, 0, 0);
  -moz-transform: translate3d(0, 0, 0);
  -ms-transform: translate3d(0, 0, 0);
  -o-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0); }

/* line 42, components/slick.scss */
.slick-track {
  position: relative;
  left: 0;
  top: 0;
  display: block;
  margin-left: auto;
  margin-right: auto; }
  /* line 50, components/slick.scss */
  .slick-track:before, .slick-track:after {
    content: "";
    display: table; }
  /* line 56, components/slick.scss */
  .slick-track:after {
    clear: both; }
  /* line 60, components/slick.scss */
  .slick-loading .slick-track {
    visibility: hidden; }

/* line 64, components/slick.scss */
.slick-slide {
  float: left;
  height: 100%;
  min-height: 1px;
  display: none; }
  /* line 68, components/slick.scss */
  [dir="rtl"] .slick-slide {
    float: right; }
  /* line 71, components/slick.scss */
  .slick-slide img {
    display: block; }
  /* line 74, components/slick.scss */
  .slick-slide.slick-loading img {
    display: none; }
  /* line 80, components/slick.scss */
  .slick-slide.dragging img {
    pointer-events: none; }
  /* line 84, components/slick.scss */
  .slick-initialized .slick-slide {
    display: block; }
  /* line 88, components/slick.scss */
  .slick-loading .slick-slide {
    visibility: hidden; }
  /* line 92, components/slick.scss */
  .slick-vertical .slick-slide {
    display: block;
    height: auto;
    border: 1px solid transparent; }

/* line 98, components/slick.scss */
.slick-arrow.slick-hidden {
  display: none; }

/* Slider */
/* line 45, components/slick-theme.scss */
.slick-loading .slick-list {
  background: #fff url("./ajax-loader.gif") center center no-repeat; }

/* Icons */
@font-face {
  font-family: "slick";
  src: url("./fonts/slick.eot");
  src: url("./fonts/slick.eot?#iefix") format("embedded-opentype"), url("./fonts/slick.woff") format("woff"), url("./fonts/slick.ttf") format("truetype"), url("./fonts/slick.svg#slick") format("svg");
  font-weight: normal;
  font-style: normal; }
/* Arrows */
/* line 63, components/slick-theme.scss */
.slick-prev,
.slick-next {
  position: absolute;
  display: block;
  height: 20px;
  width: 20px;
  line-height: 0px;
  font-size: 0px;
  cursor: pointer;
  background: transparent;
  color: transparent;
  top: 50%;
  -webkit-transform: translate(0, -50%);
  -ms-transform: translate(0, -50%);
  transform: translate(0, -50%);
  padding: 0;
  border: none;
  outline: none; }
  /* line 81, components/slick-theme.scss */
  .slick-prev:hover, .slick-prev:focus,
  .slick-next:hover,
  .slick-next:focus {
    outline: none;
    background: transparent;
    color: transparent; }
    /* line 85, components/slick-theme.scss */
    .slick-prev:hover:before, .slick-prev:focus:before,
    .slick-next:hover:before,
    .slick-next:focus:before {
      opacity: 1; }
  /* line 89, components/slick-theme.scss */
  .slick-prev.slick-disabled:before,
  .slick-next.slick-disabled:before {
    opacity: 0.25; }
  /* line 92, components/slick-theme.scss */
  .slick-prev:before,
  .slick-next:before {
    font-family: "slick";
    font-size: 20px;
    line-height: 1;
    color: white;
    opacity: 0.75;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale; }

/* line 103, components/slick-theme.scss */
.slick-prev {
  left: -25px; }
  /* line 105, components/slick-theme.scss */
  [dir="rtl"] .slick-prev {
    left: auto;
    right: -25px; }
  /* line 109, components/slick-theme.scss */
  .slick-prev:before {
    content: "←"; }
    /* line 111, components/slick-theme.scss */
    [dir="rtl"] .slick-prev:before {
      content: "→"; }

/* line 117, components/slick-theme.scss */
.slick-next {
  right: -25px; }
  /* line 119, components/slick-theme.scss */
  [dir="rtl"] .slick-next {
    left: -25px;
    right: auto; }
  /* line 123, components/slick-theme.scss */
  .slick-next:before {
    content: "→"; }
    /* line 125, components/slick-theme.scss */
    [dir="rtl"] .slick-next:before {
      content: "←"; }

/* Dots */
/* line 133, components/slick-theme.scss */
.slick-dotted.slick-slider {
  margin-bottom: 30px; }

/* line 137, components/slick-theme.scss */
.slick-dots {
  position: absolute;
  bottom: -25px;
  list-style: none;
  display: block;
  text-align: center;
  padding: 0;
  margin: 0;
  width: 100%; }
  /* line 146, components/slick-theme.scss */
  .slick-dots li {
    position: relative;
    display: inline-block;
    height: 20px;
    width: 20px;
    margin: 0 5px;
    padding: 0;
    cursor: pointer; }
    /* line 154, components/slick-theme.scss */
    .slick-dots li button {
      border: 0;
      background: transparent;
      display: block;
      height: 20px;
      width: 20px;
      outline: none;
      line-height: 0px;
      font-size: 0px;
      color: transparent;
      padding: 5px;
      cursor: pointer; }
      /* line 166, components/slick-theme.scss */
      .slick-dots li button:hover, .slick-dots li button:focus {
        outline: none; }
        /* line 168, components/slick-theme.scss */
        .slick-dots li button:hover:before, .slick-dots li button:focus:before {
          opacity: 1; }
      /* line 172, components/slick-theme.scss */
      .slick-dots li button:before {
        position: absolute;
        top: 0;
        left: 0;
        content: "•";
        width: 20px;
        height: 20px;
        font-family: "slick";
        font-size: 6px;
        line-height: 20px;
        text-align: center;
        color: black;
        opacity: 0.25;
        -webkit-font-smoothing: antialiased;
        -moz-osx-font-smoothing: grayscale; }
    /* line 189, components/slick-theme.scss */
    .slick-dots li.slick-active button:before {
      color: black;
      opacity: 0.75; }

/*
Whats: table
How?:  テーブル

・spではth、tdが改行になるように処理

Included in：app.scss
*/
/* line 10, components/table.scss */
.table {
  width: 100%;
  border-top: 1px solid #999; }
  /* line 14, components/table.scss */
  .table > tbody > tr {
    border-bottom: 1px solid #999; }
    /* line 17, components/table.scss */
    .table > tbody > tr > th, .table > tbody > tr > td {
      vertical-align: middle;
      font-weight: 600; }
    /* line 21, components/table.scss */
    .table > tbody > tr > th {
      display: inline-block;
      width: 200px;
      max-width: 200px;
      margin-right: 30px;
      padding: 20px 40px 20px 20px;
      text-align: justify;
      font-size: 20px;
      letter-spacing: 0;
      color: #4d6381;
      background-image: url("../../img/pages/company/icon_th-bg.svg");
      background-position: right 20px center;
      background-repeat: no-repeat;
      background-size: auto 15px; }
    /* line 36, components/table.scss */
    .table > tbody > tr > td {
      padding: 20px 0;
      font-size: 19px; }
  /* line 42, components/table.scss */
  .table.--bg_white {
    background-color: #fff; }
  @media screen and (max-width: 800px) {
    /* line 46, components/table.scss */
    .table > tbody {
      display: contents; }
      /* line 48, components/table.scss */
      .table > tbody > tr {
        display: block;
        border-bottom: none; }
        /* line 51, components/table.scss */
        .table > tbody > tr:first-child {
          margin-top: 15px; }
        /* line 54, components/table.scss */
        .table > tbody > tr > th, .table > tbody > tr > td {
          display: block;
          padding: 0;
          padding-left: 14px; }
        /* line 59, components/table.scss */
        .table > tbody > tr > th {
          margin-bottom: 7.5px;
          font-size: 16px;
          background-image: url("../../img/pages/company/icon_th-bg.svg");
          background-position: left center;
          background-repeat: no-repeat;
          background-size: auto 15px; }
        /* line 67, components/table.scss */
        .table > tbody > tr > td {
          margin-bottom: 15px;
          padding-bottom: 15px;
          font-size: 14px;
          line-height: 1.5;
          border-bottom: 1px solid #999; } }

/* line 1, pages/top-kv.scss */
.top-kv {
  overflow: hidden; }
  /* line 4, pages/top-kv.scss */
  .top-kv__kv {
    position: relative; }
  /* line 7, pages/top-kv.scss */
  .top-kv__logo {
    position: absolute;
    width: 256px;
    height: auto;
    left: 50%;
    top: 50%;
    z-index: 100;
    transform: translateX(-50%) translateY(-50%); }
  /* line 17, pages/top-kv.scss */
  .top-kv__slick img {
    width: 100%;
    height: auto; }
  /* line 22, pages/top-kv.scss */
  .top-kv__read {
    padding: 30px;
    text-align: center;
    font-size: 15px; }
    /* line 26, pages/top-kv.scss */
    .top-kv__read-catch {
      font-size: 22px;
      margin-bottom: 20px; }
    /* line 30, pages/top-kv.scss */
    .top-kv__read-body {
      font-size: 15px; }
  @media screen and (max-width: 800px) {
    /* line 35, pages/top-kv.scss */
    .top-kv__logo {
      width: 40vw; }
    /* line 38, pages/top-kv.scss */
    .top-kv__read {
      padding: 15px;
      text-align: center; }
      /* line 42, pages/top-kv.scss */
      .top-kv__read-catch {
        line-height: 1.2em; } }

@media screen and (min-width: 800px) {
  /* line 3, pages/top-products.scss */
  .top-products > ul {
    display: flex;
    justify-content: center;
    gap: 30px;
    margin-block: 30px; } }

@media screen and (min-width: 800px) {
  /* line 1, pages/top-service.scss */
  .top-service {
    margin-bottom: 30px;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 30px; }
    /* line 10, pages/top-service.scss */
    .top-service > div > h3, .top-service > div > p {
      text-align: left; }
    /* line 14, pages/top-service.scss */
    .top-service > img {
      width: 550px;
      height: auto; } }

@media screen and (max-width: 800px) {
  /* line 3, pages/service-about.scss */
  .service-about > p {
    text-align: justify;
    letter-spacing: .1em; } }

/* line 1, pages/service-purpose.scss */
.service-purpose {
  margin-top: 30px;
  padding-top: 30px;
  border-top: 1px solid #1a1a1a; }
  /* line 5, pages/service-purpose.scss */
  .service-purpose > ul {
    display: inline-block;
    margin-bottom: 30px; }
    /* line 9, pages/service-purpose.scss */
    .service-purpose > ul > li {
      display: inline-block;
      padding-left: 55px;
      background-image: url("../../img/pages/service/icon_list-check.svg");
      background-position: left center;
      background-repeat: no-repeat;
      background-size: 35px auto;
      margin-bottom: 18px; }
      /* line 18, pages/service-purpose.scss */
      .service-purpose > ul > li > p {
        width: 640px;
        max-width: 640px;
        margin-bottom: 0;
        padding: .5em 1em;
        background-color: #fff;
        font-size: 18px;
        line-height: 1;
        text-align: left; }
  @media screen and (max-width: 800px) {
    /* line 33, pages/service-purpose.scss */
    .service-purpose > ul > li {
      padding-left: 36px;
      background-size: 26px auto; }
      /* line 37, pages/service-purpose.scss */
      .service-purpose > ul > li > p {
        font-size: 15px;
        line-height: 1.2em;
        width: 100%;
        max-width: 100%; }
    /* line 45, pages/service-purpose.scss */
    .service-purpose > img {
      width: 100%;
      height: auto; } }

/* line 2, pages/service-flow.scss */
.service-flow > ol {
  counter-reset: number 0;
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  gap: 25px; }
  /* line 10, pages/service-flow.scss */
  .service-flow > ol > li {
    text-align: left;
    background-repeat: no-repeat; }
    /* line 14, pages/service-flow.scss */
    .service-flow > ol > li:not(:first-child) {
      padding-left: 45px;
      background-image: url("../../img/pages/service/flow-arrow.svg");
      background-position: left center;
      background-size: 20px auto; }
    /* line 20, pages/service-flow.scss */
    .service-flow > ol > li::before {
      counter-increment: number 1;
      content: counter(number,decimal-leading-zero);
      display: block;
      vertical-align: baseline;
      font-size: 16px;
      font-weight: 800;
      line-height: 1.2;
      color: #009be1; }
@media screen and (min-width: 800px) {
  /* line 1, pages/service-flow.scss */
  .service-flow {
    width: 850px;
    min-width: 850px;
    margin-inline: auto;
    margin-bottom: 40px; }
    /* line 41, pages/service-flow.scss */
    .service-flow > ol > li {
      display: block; }
      /* line 44, pages/service-flow.scss */
      .service-flow > ol > li:nth-child(6) {
        margin-left: auto; } }
@media screen and (max-width: 800px) {
  /* line 1, pages/service-flow.scss */
  .service-flow {
    padding: 0 15px; }
    /* line 52, pages/service-flow.scss */
    .service-flow > ol {
      gap: 30px 15px;
      margin-bottom: 30px; }
      /* line 56, pages/service-flow.scss */
      .service-flow > ol > li {
        min-width: 33%;
        /*
        &:not(:last-child){
          padding-bottom: 35px;
          margin-bottom: 15px;
          background-image: url("../../img/pages/service/flow-arrow_sp.svg");
          background-position: center bottom;
          background-size: auto 20px;
        }*/ }
        /* line 59, pages/service-flow.scss */
        .service-flow > ol > li:not(:first-child) {
          padding-left: 35px; }
        /* line 62, pages/service-flow.scss */
        .service-flow > ol > li:nth-child(4n-1) {
          margin-left: auto; } }

/* line 1, pages/service-merit.scss */
.service-merit {
  border-top: 1px solid #1a1a1a;
  border-bottom: 1px solid #1a1a1a; }
  /* line 5, pages/service-merit.scss */
  .service-merit > h4 {
    display: flex;
    align-items: center;
    gap: 5px;
    font-size: 22px; }
    /* line 11, pages/service-merit.scss */
    .service-merit > h4:after {
      display: inline-block;
      content: '';
      width: 30px;
      height: 47px;
      align-items: center;
      background-image: url("../../img/pages/service/howto-merit.svg");
      background-position: center center;
      background-repeat: no-repeat;
      background-size: 30px auto; }
  /* line 23, pages/service-merit.scss */
  .service-merit > ul {
    list-style: disc; }
    /* line 25, pages/service-merit.scss */
    .service-merit > ul > li {
      text-align: left;
      font-size: 15px;
      line-height: 2em; }
  @media screen and (min-width: 800px) {
    /* line 1, pages/service-merit.scss */
    .service-merit {
      display: flex;
      width: 850px;
      justify-content: center;
      gap: 60px;
      margin-inline: auto;
      padding: 40px; } }
  @media screen and (max-width: 800px) {
    /* line 1, pages/service-merit.scss */
    .service-merit {
      padding: 15px; }
      /* line 44, pages/service-merit.scss */
      .service-merit h4 {
        justify-content: center;
        margin-bottom: 15px; }
      /* line 48, pages/service-merit.scss */
      .service-merit > ul {
        margin-left: 1em; }
        /* line 50, pages/service-merit.scss */
        .service-merit > ul > li {
          margin-bottom: 10px;
          text-align: justify;
          font-size: 15px;
          line-height: 1.2em;
          font-size: 14px; } }

/* line 2, pages/works-about.scss */
.works-about > p {
  text-align: left;
  margin-left: 35px;
  margin-bottom: 20px; }
/* line 8, pages/works-about.scss */
.works-about > ul {
  display: flex;
  justify-content: space-between;
  margin-bottom: 30px; }
  /* line 14, pages/works-about.scss */
  .works-about > ul > li > img {
    margin-bottom: 10px; }
  /* line 17, pages/works-about.scss */
  .works-about > ul > li > p {
    display: flex;
    justify-content: center;
    align-items: center; }
    /* line 22, pages/works-about.scss */
    .works-about > ul > li > p:before {
      content: '';
      display: inline-block;
      width: 16px;
      height: 21px;
      margin-right: 10px;
      background-image: url("../../img/pages/works/icon_pin.svg");
      background-position: left center;
      background-repeat: no-repeat;
      background-size: 16px auto; }
/* line 36, pages/works-about.scss */
.works-about__others {
  max-width: 840px;
  margin-inline: auto;
  padding: 15px 30px;
  text-align: justify;
  border: 1px solid #1a1a1a; }
  /* line 42, pages/works-about.scss */
  .works-about__others > h4 {
    margin-bottom: .5em; }
  /* line 45, pages/works-about.scss */
  .works-about__others > p {
    margin-bottom: 0; }
@media screen and (max-width: 800px) {
  /* line 50, pages/works-about.scss */
  .works-about > p {
    margin-left: 0;
    text-align: left;
    letter-spacing: .1em; }
  /* line 55, pages/works-about.scss */
  .works-about > ul {
    display: block; }
    /* line 57, pages/works-about.scss */
    .works-about > ul > li {
      margin-bottom: 15px; }
      /* line 58, pages/works-about.scss */
      .works-about > ul > li > img {
        margin-bottom: 2px; }
  /* line 64, pages/works-about.scss */
  .works-about__others {
    padding: 15px; } }

/* line 2, pages/works-example.scss */
.works-example > p {
  text-align: left;
  margin-left: 35px;
  margin-bottom: 20px; }
/* line 8, pages/works-example.scss */
.works-example > ul {
  display: flex;
  justify-content: center;
  gap: 50px; }
  /* line 14, pages/works-example.scss */
  .works-example > ul > li > img {
    margin-bottom: 10px; }
  /* line 17, pages/works-example.scss */
  .works-example > ul > li > p {
    display: flex;
    justify-content: flex-start;
    align-items: center; }
    /* line 22, pages/works-example.scss */
    .works-example > ul > li > p:before {
      content: '';
      display: inline-block;
      width: 15px;
      height: 15px;
      margin-right: 10px;
      background-image: url("../../img/pages/works/icon_gear.svg");
      background-position: left center;
      background-repeat: no-repeat;
      background-size: 15px auto; }
@media screen and (max-width: 800px) {
  /* line 37, pages/works-example.scss */
  .works-example > p {
    margin-left: 0;
    text-align: left;
    letter-spacing: .1em; }
  /* line 42, pages/works-example.scss */
  .works-example > ul {
    width: 350px;
    margin-inline: auto;
    display: block; }
    /* line 46, pages/works-example.scss */
    .works-example > ul > li {
      margin-bottom: 15px; }
      /* line 47, pages/works-example.scss */
      .works-example > ul > li > img {
        margin-bottom: 2px; } }

@media screen and (min-width: 800px) {
  /* line 1, pages/company-concept.scss */
  .company-concept {
    padding: 60px 30px; } }
@media screen and (max-width: 800px) {
  /* line 1, pages/company-concept.scss */
  .company-concept {
    padding: 45px 15px 30px; } }
/* line 3, pages/company-concept.scss */
.company-concept P {
  text-align: center; }
@media screen and (max-width: 800px) {
  /* line 7, pages/company-concept.scss */
  .company-concept p {
    font-size: 13px;
    text-align: justify; } }

/* line 1, pages/company-about.scss */
.company-about {
  background-color: #fff;
  padding: 30px; }
  @media screen and (min-width: 800px) {
    /* line 6, pages/company-about.scss */
    .company-about .table {
      max-width: 800px;
      margin-inline: auto; } }
  @media screen and (max-width: 800px) {
    /* line 1, pages/company-about.scss */
    .company-about {
      padding: 15px; } }

/* line 1, pages/company-access.scss */
.company-access {
  padding: 60px;
  text-align: center; }
  /* line 4, pages/company-access.scss */
  .company-access > img {
    width: 42px;
    height: auto;
    margin-bottom: 30px; }
  /* line 10, pages/company-access.scss */
  .company-access__map {
    background-color: #999;
    width: 100%;
    height: 555px; }
  @media screen and (max-width: 800px) {
    /* line 1, pages/company-access.scss */
    .company-access {
      padding: 15px 0; }
      /* line 19, pages/company-access.scss */
      .company-access__inner {
        padding: 15px 0; }
      /* line 22, pages/company-access.scss */
      .company-access__map {
        width: clamp(100%, 100%, 100%);
        height: 55vw; } }

/* line 1, pages/company-recruit.scss */
.company-recruit {
  text-align: center; }
  /* line 3, pages/company-recruit.scss */
  .company-recruit__contact {
    margin-top: 30px; }
    /* line 5, pages/company-recruit.scss */
    .company-recruit__contact > a {
      color: #4d6381; }
      /* line 7, pages/company-recruit.scss */
      .company-recruit__contact > a:hover {
        color: #009be1; }
      /* line 10, pages/company-recruit.scss */
      .company-recruit__contact > a > img {
        width: 50px;
        height: 50px; }
  /* line 16, pages/company-recruit.scss */
  .company-recruit__message {
    color: #4d6381;
    font-size: .9rem;
    u-mb: 1em; }

/* line 1, pages/privacypolicy.scss */
.privacypolicy {
  padding: 30px;
  background-color: #fff; }
  /* line 2, pages/privacypolicy.scss */
  .privacypolicy * {
    color: #1a1a1a !important; }
  /* line 9, pages/privacypolicy.scss */
  .privacypolicy > dl > dt, .privacypolicy > dl > dd {
    color: #1a1a1a;
    padding-left: 40px; }
  /* line 13, pages/privacypolicy.scss */
  .privacypolicy > dl > dt {
    color: #4d6381 !important;
    font-size: 20px;
    margin-bottom: 15px;
    padding-bottom: 15px;
    border-bottom: 1px solid #4d6381;
    background-image: url("../../img/pages/company/icon_th-bg.svg");
    background-position: top 8px left 20px;
    background-repeat: no-repeat;
    background-size: auto 15px; }
  /* line 24, pages/privacypolicy.scss */
  .privacypolicy > dl > dd {
    margin-bottom: 30px;
    font-size: 15px; }
  @media screen and (max-width: 800px) {
    /* line 1, pages/privacypolicy.scss */
    .privacypolicy {
      padding: 15px; }
      /* line 33, pages/privacypolicy.scss */
      .privacypolicy > dl > dt, .privacypolicy > dl > dd {
        color: #1a1a1a;
        padding-left: 16px; }
      /* line 37, pages/privacypolicy.scss */
      .privacypolicy > dl > dt {
        margin-bottom: 7.5px;
        padding-bottom: 7.5px;
        color: #4d6381 !important;
        font-size: 16px;
        background-position: top 4px left 4px; }
      /* line 44, pages/privacypolicy.scss */
      .privacypolicy > dl > dd {
        margin-bottom: 30px;
        font-size: 14px; } }

/* line 21, trumps/_trumps.scss */
.u-ma0 {
  margin: 0 !important; }

/* line 26, trumps/_trumps.scss */
.u-mt0 {
  margin-top: 0 !important; }

/* line 31, trumps/_trumps.scss */
.u-mr0 {
  margin-right: 0 !important; }

/* line 36, trumps/_trumps.scss */
.u-mb0 {
  margin-bottom: 0 !important; }

/* line 41, trumps/_trumps.scss */
.u-ml0 {
  margin-left: 0 !important; }

/* line 46, trumps/_trumps.scss */
.u-my0 {
  margin-top: 0 !important;
  margin-bottom: 0 !important; }

/* line 52, trumps/_trumps.scss */
.u-mx0 {
  margin-right: 0 !important;
  margin-left: 0 !important; }

/* line 58, trumps/_trumps.scss */
.u-pa0 {
  padding: 0 !important; }

/* line 63, trumps/_trumps.scss */
.u-pt0 {
  padding-top: 0 !important; }

/* line 68, trumps/_trumps.scss */
.u-pr0 {
  padding-right: 0 !important; }

/* line 73, trumps/_trumps.scss */
.u-pb0 {
  padding-bottom: 0 !important; }

/* line 78, trumps/_trumps.scss */
.u-pl0 {
  padding-left: 0 !important; }

/* line 83, trumps/_trumps.scss */
.u-py0 {
  padding-top: 0 !important;
  padding-bottom: 0 !important; }

/* line 89, trumps/_trumps.scss */
.u-px0 {
  padding-right: 0 !important;
  padding-left: 0 !important; }

/* line 21, trumps/_trumps.scss */
.u-mas {
  margin: 10px !important; }

/* line 26, trumps/_trumps.scss */
.u-mts {
  margin-top: 10px !important; }

/* line 31, trumps/_trumps.scss */
.u-mrs {
  margin-right: 10px !important; }

/* line 36, trumps/_trumps.scss */
.u-mbs {
  margin-bottom: 10px !important; }

/* line 41, trumps/_trumps.scss */
.u-mls {
  margin-left: 10px !important; }

/* line 46, trumps/_trumps.scss */
.u-mys {
  margin-top: 10px !important;
  margin-bottom: 10px !important; }

/* line 52, trumps/_trumps.scss */
.u-mxs {
  margin-right: 10px !important;
  margin-left: 10px !important; }

/* line 58, trumps/_trumps.scss */
.u-pas {
  padding: 10px !important; }

/* line 63, trumps/_trumps.scss */
.u-pts {
  padding-top: 10px !important; }

/* line 68, trumps/_trumps.scss */
.u-prs {
  padding-right: 10px !important; }

/* line 73, trumps/_trumps.scss */
.u-pbs {
  padding-bottom: 10px !important; }

/* line 78, trumps/_trumps.scss */
.u-pls {
  padding-left: 10px !important; }

/* line 83, trumps/_trumps.scss */
.u-pys {
  padding-top: 10px !important;
  padding-bottom: 10px !important; }

/* line 89, trumps/_trumps.scss */
.u-pxs {
  padding-right: 10px !important;
  padding-left: 10px !important; }

/* line 21, trumps/_trumps.scss */
.u-mam {
  margin: 20px !important; }

/* line 26, trumps/_trumps.scss */
.u-mtm {
  margin-top: 20px !important; }

/* line 31, trumps/_trumps.scss */
.u-mrm {
  margin-right: 20px !important; }

/* line 36, trumps/_trumps.scss */
.u-mbm {
  margin-bottom: 20px !important; }

/* line 41, trumps/_trumps.scss */
.u-mlm {
  margin-left: 20px !important; }

/* line 46, trumps/_trumps.scss */
.u-mym {
  margin-top: 20px !important;
  margin-bottom: 20px !important; }

/* line 52, trumps/_trumps.scss */
.u-mxm {
  margin-right: 20px !important;
  margin-left: 20px !important; }

/* line 58, trumps/_trumps.scss */
.u-pam {
  padding: 20px !important; }

/* line 63, trumps/_trumps.scss */
.u-ptm {
  padding-top: 20px !important; }

/* line 68, trumps/_trumps.scss */
.u-prm {
  padding-right: 20px !important; }

/* line 73, trumps/_trumps.scss */
.u-pbm {
  padding-bottom: 20px !important; }

/* line 78, trumps/_trumps.scss */
.u-plm {
  padding-left: 20px !important; }

/* line 83, trumps/_trumps.scss */
.u-pym {
  padding-top: 20px !important;
  padding-bottom: 20px !important; }

/* line 89, trumps/_trumps.scss */
.u-pxm {
  padding-right: 20px !important;
  padding-left: 20px !important; }

/* line 21, trumps/_trumps.scss */
.u-mal {
  margin: 40px !important; }

/* line 26, trumps/_trumps.scss */
.u-mtl {
  margin-top: 40px !important; }

/* line 31, trumps/_trumps.scss */
.u-mrl {
  margin-right: 40px !important; }

/* line 36, trumps/_trumps.scss */
.u-mbl {
  margin-bottom: 40px !important; }

/* line 41, trumps/_trumps.scss */
.u-mll {
  margin-left: 40px !important; }

/* line 46, trumps/_trumps.scss */
.u-myl {
  margin-top: 40px !important;
  margin-bottom: 40px !important; }

/* line 52, trumps/_trumps.scss */
.u-mxl {
  margin-right: 40px !important;
  margin-left: 40px !important; }

/* line 58, trumps/_trumps.scss */
.u-pal {
  padding: 40px !important; }

/* line 63, trumps/_trumps.scss */
.u-ptl {
  padding-top: 40px !important; }

/* line 68, trumps/_trumps.scss */
.u-prl {
  padding-right: 40px !important; }

/* line 73, trumps/_trumps.scss */
.u-pbl {
  padding-bottom: 40px !important; }

/* line 78, trumps/_trumps.scss */
.u-pll {
  padding-left: 40px !important; }

/* line 83, trumps/_trumps.scss */
.u-pyl {
  padding-top: 40px !important;
  padding-bottom: 40px !important; }

/* line 89, trumps/_trumps.scss */
.u-pxl {
  padding-right: 40px !important;
  padding-left: 40px !important; }

/* line 21, trumps/_trumps.scss */
.u-mall {
  margin: 60px !important; }

/* line 26, trumps/_trumps.scss */
.u-mtll {
  margin-top: 60px !important; }

/* line 31, trumps/_trumps.scss */
.u-mrll {
  margin-right: 60px !important; }

/* line 36, trumps/_trumps.scss */
.u-mbll {
  margin-bottom: 60px !important; }

/* line 41, trumps/_trumps.scss */
.u-mlll {
  margin-left: 60px !important; }

/* line 46, trumps/_trumps.scss */
.u-myll {
  margin-top: 60px !important;
  margin-bottom: 60px !important; }

/* line 52, trumps/_trumps.scss */
.u-mxll {
  margin-right: 60px !important;
  margin-left: 60px !important; }

/* line 58, trumps/_trumps.scss */
.u-pall {
  padding: 60px !important; }

/* line 63, trumps/_trumps.scss */
.u-ptll {
  padding-top: 60px !important; }

/* line 68, trumps/_trumps.scss */
.u-prll {
  padding-right: 60px !important; }

/* line 73, trumps/_trumps.scss */
.u-pbll {
  padding-bottom: 60px !important; }

/* line 78, trumps/_trumps.scss */
.u-plll {
  padding-left: 60px !important; }

/* line 83, trumps/_trumps.scss */
.u-pyll {
  padding-top: 60px !important;
  padding-bottom: 60px !important; }

/* line 89, trumps/_trumps.scss */
.u-pxll {
  padding-right: 60px !important;
  padding-left: 60px !important; }

/* line 98, trumps/_trumps.scss */
.u-tl {
  text-align: left !important; }

/* line 102, trumps/_trumps.scss */
.u-tc {
  text-align: center !important; }

/* line 106, trumps/_trumps.scss */
.u-tr {
  text-align: right !important; }

/* line 113, trumps/_trumps.scss */
.u-flex {
  flex: 1 !important; }

/* line 119, trumps/_trumps.scss */
.u-fss {
  font-size: 13px !important; }
  @media screen and (max-width: 800px) {
    /* line 119, trumps/_trumps.scss */
    .u-fss {
      font-size: 3.2vw !important; } }

/* line 125, trumps/_trumps.scss */
.u-fsm {
  font-size: 16px !important; }
  @media screen and (max-width: 800px) {
    /* line 125, trumps/_trumps.scss */
    .u-fsm {
      font-size: 3.8vw !important; } }

/* line 131, trumps/_trumps.scss */
.u-fsl {
  font-size: 18px !important; }
  @media screen and (max-width: 800px) {
    /* line 131, trumps/_trumps.scss */
    .u-fsl {
      font-size: 4.4vw !important; } }

/* line 137, trumps/_trumps.scss */
.u-fsll {
  font-size: 22px !important; }
  @media screen and (max-width: 800px) {
    /* line 137, trumps/_trumps.scss */
    .u-fsll {
      font-size: 5vw !important; } }

/* line 146, trumps/_trumps.scss */
.u-fwb {
  font-weight: 600; }

/* line 153, trumps/_trumps.scss */
.u-fc-red {
  color: #a00; }

/* line 159, trumps/_trumps.scss */
.u-nowrap {
  white-space: nowrap; }

/* line 167, trumps/_trumps.scss */
.u-nowrap {
  white-space: nowrap; }

@media screen and (max-width: 800px) {
  /* line 173, trumps/_trumps.scss */
  .u-noSP {
    display: none; } }

@media screen and (min-width: 800px) {
  /* line 178, trumps/_trumps.scss */
  .u-noPC {
    display: none; } }

/* line 188, trumps/_trumps.scss */
#payjp_checkout_box input[type="button"] {
  display: inline-block;
  font-weight: 400;
  color: #212529;
  text-align: center;
  vertical-align: middle;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  background-color: transparent;
  border: 1px solid transparent;
  padding: 0.375rem 0.75rem;
  font-size: 1rem;
  line-height: 1.5;
  border-radius: 0.25rem;
  -webkit-transition: color 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
  transition: color 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out; }

/* line 208, trumps/_trumps.scss */
.text-center {
  text-align: center; }

/*# sourceMappingURL=style.css.map */
