@charset "UTF-8";
:root {
  /* COLORS */
  --buyer: #f06fab;
  --supplier: #5ba8ca;
  --yellow: #fdf224;
  --brand-primary: #0062a7;
  --brand-lightblue: #f5f8fa;
  --brand-rightlue: #0091f7;
  --base-black: #000000;
  --base-grey1: #999999;
  --base-orange: #fbb81d;
  --base-red: #ee1c09;
  --base-lightblue2: #e6f2fa;
  --base-kon: #0400a9;
  --base-blueglay2: #eceff1;
  --base-grey2: #cccccc;
  --base-darkblue: #003e69;
  --link-link: #ee8828;
  /* SHADOWS */
  --drobshadow1: 0 2px 8px 0 rgba(0 24 39 / 0.2);
  --dropshadow2: 0 3px 8px 0 rgba(0 24 39 / 0.12);
  --dropshadow3: 2px 2px 3px 0 rgba(0 24 39 / 0.3);
}

.grad1 {
  background: radial-gradient(164.97% 65.13% at 50% 50%, #fff 13.63%, #e4f6fe 48.97%, #e4e9ff 67.43%, #d8fcff 70.59%, #f5fafd 88.5%, #fff 99.42%);
  background-size: cover;
  background-attachment: fixed;
}

.grad2 {
  background: linear-gradient(90deg, #86fde8 0%, #acb6e5 100%);
}

.drop-shadow1 {
  box-shadow: 0px 0px 12px 0px rgba(0, 0, 0, 0.15);
}
@media only screen and (min-width: 768px) {
  .drop-shadow1 {
    box-shadow: 0px 0px 18px 0px rgba(0, 0, 0, 0.15);
  }
}

.drop-shadow2 {
  box-shadow: 0px 0px 14px 10px rgba(216, 226, 231, 0.2);
}
@media only screen and (min-width: 768px) {
  .drop-shadow2 {
    box-shadow: 0px 0px 20px 20px rgba(216, 226, 231, 0.2);
  }
}

.drop-shadow3 {
  box-shadow: 0px 0px 14px 0px rgba(0, 0, 0, 0.06);
}
@media only screen and (min-width: 768px) {
  .drop-shadow3 {
    box-shadow: 0px 0px 20px 0px rgba(0, 0, 0, 0.06);
  }
}

.reset-link-style:link, .reset-link-style:visited {
  color: var(--wp--preset--color--site-text);
  text-decoration: none;
}

.reset-list-style {
  list-style: none;
  padding-left: 0;
}
.reset-list-style li {
  margin-top: 0;
}
.reset-list-style li:not(:first-of-type) {
  margin-top: 0;
}

.icon-arrow1, .link-arrow-right::after {
  content: "";
  width: 9px;
  height: 10px;
  background-color: #cccccc;
  -webkit-mask-image: url(./assets/images/common/icon-arrow1.svg);
  mask-image: url(./assets/images/common/icon-arrow1.svg);
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-position: center;
  mask-position: center;
  -webkit-mask-size: 100%;
  mask-size: 100%;
  display: inline-block;
  transform: rotate(-90deg);
  transition: all 0.3s ease 0s;
}

.icon-arrow2 {
  content: "";
  width: 8px;
  height: 100%;
  background-color: #b5b5b5;
  -webkit-mask-image: url(./assets/images/common/icon-arrow2.svg);
  mask-image: url(./assets/images/common/icon-arrow2.svg);
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-position: center;
  mask-position: center;
  -webkit-mask-size: 100%;
  mask-size: 100%;
  transition: all 0.3s ease 0s;
}

.icon-blank {
  content: "";
  width: 14px;
  height: 14px;
  background-color: #acb6e5;
  -webkit-mask-image: url(./assets/images/common/icon-blank.svg);
  mask-image: url(./assets/images/common/icon-blank.svg);
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-position: center;
  mask-position: center;
  -webkit-mask-size: 100%;
  mask-size: 100%;
  display: inline-block;
  transition: all 0.3s ease 0s;
}

.icon-download, .link-download::after {
  content: "";
  width: 12px;
  height: 15px;
  background-color: #acb6e5;
  -webkit-mask-image: url(./assets/images/common/icon-download.svg);
  mask-image: url(./assets/images/common/icon-download.svg);
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-position: center;
  mask-position: center;
  -webkit-mask-size: 100%;
  mask-size: 100%;
  display: inline-block;
  transition: all 0.3s ease 0s;
}

/* === 必要最小限のリセット === */
*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

:root {
  interpolate-size: allow-keywords;
}

html,
body {
  height: 100%;
}

body {
  font-size: 1rem;
  font-variant-numeric: tabular-nums;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  font-family: var(--wp--preset--font-family--noto-sans-jp), sans-serif;
}
img {
  max-width: 100%;
  height: auto;
  display: block;
}

button {
  background: transparent;
  border: none;
  cursor: pointer;
  outline: none;
}

a:not([href^="tel:"]) {
  transition: all 0.15s;
}
a:not([href^="tel:"]):link, a:not([href^="tel:"]):visited {
  color: var(--wp--preset--color--brand-brightblue);
  text-decoration: underline;
}
a:not([href^="tel:"]):hover, a:not([href^="tel:"]):active {
  opacity: 0.8;
}

figure {
  line-height: 1;
}

body,
p,
span,
div {
  overflow-wrap: break-word;
  /* 同上 */
}

sup {
  margin: 0 0.25em;
  color: var(--wp--preset--color--brand-primary);
}
sup a::before {
  content: "※";
  font-size: 90%;
}

@media only screen and (min-width: 768px) {
  .is-mobile {
    display: none;
  }
}

.is-desktop {
  display: none;
}
@media only screen and (min-width: 768px) {
  .is-desktop {
    display: block;
  }
}

[id] {
  scroll-margin-top: 100px;
}

.cf-turnstile {
  display: none !important;
}

/* ----------------------------------------------------------------
  デフォルトのブレークポイント（600px）での処理を変更
---------------------------------------------------------------- */
.wp-block-navigation__responsive-container-open:not(.always-shown) {
  display: flex;
}
@media only screen and (min-width: 768px) {
  .wp-block-navigation__responsive-container-open:not(.always-shown) {
    display: none;
  }
}

.wp-block-navigation__responsive-container:not(.hidden-by-default):not(.is-menu-open) {
  display: none;
}
@media only screen and (min-width: 768px) {
  .wp-block-navigation__responsive-container:not(.hidden-by-default):not(.is-menu-open) {
    display: block;
  }
}

/* ----------------------------------------------------------------
  header
---------------------------------------------------------------- */
.site-header {
  display: flex;
  align-items: center;
  padding-left: 16px;
  padding-right: 16px;
  width: 100%;
  height: 60px;
  background-color: rgba(255, 255, 255, 0.85);
  -webkit-backdrop-filter: blur(24px) brightness(1.5);
  backdrop-filter: blur(24px) brightness(1.5);
  box-shadow: 0 1px 0 0 rgba(0, 0, 0, 0.08);
  position: fixed;
  left: 0;
  top: 0;
  z-index: 10;
}
@media only screen and (min-width: 768px) {
  .site-header {
    padding-left: 0;
    padding-right: 0;
  }
}
.site-header .inner {
  height: 60px;
  gap: 0;
  position: relative;
}
@media only screen and (min-width: 768px) {
  .site-header .inner {
    width: 83.33333333%;
    margin-left: auto;
    margin-right: auto;
    justify-content: center;
  }
}
.site-header .header-logo {
  width: 51px;
  flex-shrink: 0;
  flex-grow: 0;
}
@media only screen and (min-width: 768px) {
  .site-header .header-logo {
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
  }
}
.site-header .main-nav-wrapper.wp-block-navigation {
  width: auto;
}
@media only screen and (min-width: 768px) {
  .site-header .main-nav-wrapper.wp-block-navigation {
    justify-content: space-between;
    gap: 0;
    width: 66.66666667%;
  }
}
@media only screen and (min-width: 768px) and (min-width: 1025px) {
  .site-header .main-nav-wrapper.wp-block-navigation {
    padding-left: 3rem;
    padding-right: 3rem;
  }
}
@media only screen and (min-width: 768px) and (min-width: 1025px) and (min-width: 1440px) {
  .site-header .main-nav-wrapper.wp-block-navigation {
    width: 50%;
  }
}

.wp-block-navigation__responsive-container-open {
  width: 40px;
  height: 40px;
  position: fixed;
  right: 16px;
  top: 10px;
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
}
.wp-block-navigation__responsive-container-open svg {
  display: none;
}

.wp-block-navigation__responsive-container-close {
  width: 40px;
  height: 40px;
  position: fixed;
  right: 16px;
  top: 10px;
  pointer-events: auto;
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
}
.wp-block-navigation__responsive-container-close svg {
  display: none;
}

.has-modal-open .wp-block-navigation__responsive-container-open {
  display: none;
}

.wp-block-navigation:not(.has-background) .wp-block-navigation__responsive-container.is-menu-open {
  width: 100%;
  height: 100vh;
  z-index: -1;
}

.wp-block-navigation__responsive-close .wp-block-navigation__responsive-dialog {
  margin-top: 0;
  background-color: transparent;
  height: auto;
}
.wp-block-navigation__responsive-close .wp-block-navigation__responsive-dialog .wp-block-navigation__responsive-container-content {
  padding: 25px 25px;
  background-color: #f7f8f9;
  display: block;
  width: 100%;
  height: calc(100vh - 60px);
  position: fixed;
  left: 0;
  top: 60px;
  overflow: scroll;
  -ms-overflow-style: none;
  /* IE/Edge */
  scrollbar-width: none;
  /* Firefox */
}
@media only screen and (min-width: 768px) {
  .wp-block-navigation__responsive-close .wp-block-navigation__responsive-dialog .wp-block-navigation__responsive-container-content {
    padding: 0;
    display: flex;
    width: auto;
    height: 60px;
    position: relative;
    left: auto;
    top: auto;
    overflow: visible;
  }
}
.wp-block-navigation__responsive-close .wp-block-navigation__responsive-dialog .wp-block-navigation__responsive-container-content::-webkit-scrollbar {
  display: none;
  /* Chrome/Safari */
}
.wp-block-navigation__responsive-close .wp-block-navigation__responsive-dialog .wp-block-navigation__responsive-container-content .wp-block-navigation__container {
  padding: 10px 20px;
  background-color: #fff !important;
  display: flex;
  flex-direction: column;
  align-self: stretch;
  gap: 0;
  border-radius: 10px;
  box-shadow: 0 2px 8px 0 rgba(0, 24, 39, 0.2);
}
@media only screen and (min-width: 768px) {
  .wp-block-navigation__responsive-close .wp-block-navigation__responsive-dialog .wp-block-navigation__responsive-container-content .wp-block-navigation__container {
    padding: 0;
    border-radius: 0;
    box-shadow: none;
    flex-wrap: nowrap;
    flex-direction: row;
    align-items: center;
    gap: 0;
  }
}
.wp-block-navigation__responsive-close .wp-block-navigation__responsive-dialog .wp-block-navigation__responsive-container-content .wp-block-navigation__container .wp-block-navigation-item {
  width: 100%;
  padding: 0;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  gap: 5px;
  position: relative;
}
@media only screen and (min-width: 768px) {
  .wp-block-navigation__responsive-close .wp-block-navigation__responsive-dialog .wp-block-navigation__responsive-container-content .wp-block-navigation__container .wp-block-navigation-item {
    width: auto;
    min-height: auto;
  }
}
.wp-block-navigation__responsive-close .wp-block-navigation__responsive-dialog .wp-block-navigation__responsive-container-content .wp-block-navigation__container .wp-block-navigation-item:not(:last-of-type) {
  border-bottom: 1px solid rgba(0, 0, 0, 0.15);
}
@media only screen and (min-width: 768px) {
  .wp-block-navigation__responsive-close .wp-block-navigation__responsive-dialog .wp-block-navigation__responsive-container-content .wp-block-navigation__container .wp-block-navigation-item:not(:last-of-type) {
    border-bottom: none;
  }
}
@media only screen and (min-width: 768px) {
  .wp-block-navigation__responsive-close .wp-block-navigation__responsive-dialog .wp-block-navigation__responsive-container-content .wp-block-navigation__container .wp-block-navigation-item.has-child {
    flex-direction: row;
    align-items: center;
    gap: 8px;
  }
}
.wp-block-navigation__responsive-close .wp-block-navigation__responsive-dialog .wp-block-navigation__responsive-container-content .wp-block-navigation__container .wp-block-navigation-item.has-child .wp-block-navigation__submenu-icon {
  display: block;
  margin: 0;
  aspect-ratio: 1/1;
  width: 24px;
  height: 24px;
  border: 1px solid rgba(0, 0, 0, 0.2);
  border-radius: 4px;
  position: absolute;
  right: 5px;
  top: 15px;
  background-color: #000;
  -webkit-mask-image: url(../assets/images/common/icon-arrow1.svg);
  mask-image: url(../assets/images/common/icon-arrow1.svg);
  -webkit-mask-size: 12px;
  mask-size: 12px;
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-position: center;
  mask-position: center;
  transform: rotate(180deg);
  transition: all 0.05s ease-out;
}
@media only screen and (min-width: 768px) {
  .wp-block-navigation__responsive-close .wp-block-navigation__responsive-dialog .wp-block-navigation__responsive-container-content .wp-block-navigation__container .wp-block-navigation-item.has-child .wp-block-navigation__submenu-icon {
    width: 12px;
    height: 6px;
    border: none;
    position: relative;
    right: auto;
    top: 1px;
  }
}
.wp-block-navigation__responsive-close .wp-block-navigation__responsive-dialog .wp-block-navigation__responsive-container-content .wp-block-navigation__container .wp-block-navigation-item.has-child .wp-block-navigation__submenu-icon svg {
  display: none;
}
.wp-block-navigation__responsive-close .wp-block-navigation__responsive-dialog .wp-block-navigation__responsive-container-content .wp-block-navigation__container .wp-block-navigation-item.has-child .wp-block-navigation__submenu-icon.is-visible {
  transform: translateY(0);
}
.wp-block-navigation__responsive-close .wp-block-navigation__responsive-dialog .wp-block-navigation__responsive-container-content .wp-block-navigation__container .wp-block-navigation-item.has-child .wp-block-navigation__submenu-icon.is-visible svg {
  transform: rotate(0);
}
.wp-block-navigation__responsive-close .wp-block-navigation__responsive-dialog .wp-block-navigation__responsive-container-content .wp-block-navigation__container .wp-block-navigation-item.has-child .wp-block-navigation__submenu-container {
  padding: 5px 1em;
  width: 100%;
  background-color: var(--Brand-LightBlue, #f5f8fa) !important;
  gap: 0;
}
@media only screen and (min-width: 768px) {
  .wp-block-navigation__responsive-close .wp-block-navigation__responsive-dialog .wp-block-navigation__responsive-container-content .wp-block-navigation__container .wp-block-navigation-item.has-child .wp-block-navigation__submenu-container {
    padding: 0 20px 5px;
    width: auto;
    white-space: nowrap;
    background-color: #003e69 !important;
    border: none;
    font-size: 1rem;
  }
}
@media only screen and (min-width: 768px) {
  .wp-block-navigation__responsive-close .wp-block-navigation__responsive-dialog .wp-block-navigation__responsive-container-content .wp-block-navigation__container .wp-block-navigation-item.has-child .wp-block-navigation__submenu-container .wp-block-navigation-item {
    padding-left: 25px;
    padding-right: 5px;
    flex-direction: row-reverse;
    align-items: center;
    gap: 10px;
  }
  .wp-block-navigation__responsive-close .wp-block-navigation__responsive-dialog .wp-block-navigation__responsive-container-content .wp-block-navigation__container .wp-block-navigation-item.has-child .wp-block-navigation__submenu-container .wp-block-navigation-item:not(:last-of-type) {
    border-bottom: 1px solid rgba(255, 255, 255, 0.15);
  }
  .wp-block-navigation__responsive-close .wp-block-navigation__responsive-dialog .wp-block-navigation__responsive-container-content .wp-block-navigation__container .wp-block-navigation-item.has-child .wp-block-navigation__submenu-container .wp-block-navigation-item::after {
    content: "";
    width: 12px;
    height: 6px;
    border: none;
    position: relative;
    right: auto;
    top: 1px;
    background-color: #fff;
    -webkit-mask-image: url(../assets/images/common/icon-arrow1.svg);
    mask-image: url(../assets/images/common/icon-arrow1.svg);
    -webkit-mask-size: 12px;
    mask-size: 12px;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    -webkit-mask-position: center;
    mask-position: center;
    transition: all 0.05s ease-out;
    position: absolute;
    left: 5px;
    top: 50%;
    transform: translateY(-50%) rotate(90deg);
  }
  .wp-block-navigation__responsive-close .wp-block-navigation__responsive-dialog .wp-block-navigation__responsive-container-content .wp-block-navigation__container .wp-block-navigation-item.has-child .wp-block-navigation__submenu-container .wp-block-navigation-item.has-child::after {
    content: none;
  }
  .wp-block-navigation__responsive-close .wp-block-navigation__responsive-dialog .wp-block-navigation__responsive-container-content .wp-block-navigation__container .wp-block-navigation-item.has-child .wp-block-navigation__submenu-container .wp-block-navigation-item.has-child .wp-block-navigation__submenu-icon {
    background-color: #fff;
    position: absolute;
    left: 5px;
    top: 23px;
    transform: rotate(180deg);
  }
  .wp-block-navigation__responsive-close .wp-block-navigation__responsive-dialog .wp-block-navigation__responsive-container-content .wp-block-navigation__container .wp-block-navigation-item.has-child .wp-block-navigation__submenu-container .wp-block-navigation-item .wp-block-navigation-item__content {
    text-shadow: none;
  }
  .wp-block-navigation__responsive-close .wp-block-navigation__responsive-dialog .wp-block-navigation__responsive-container-content .wp-block-navigation__container .wp-block-navigation-item.has-child .wp-block-navigation__submenu-container .wp-block-navigation-item .wp-block-navigation-item__content:link, .wp-block-navigation__responsive-close .wp-block-navigation__responsive-dialog .wp-block-navigation__responsive-container-content .wp-block-navigation__container .wp-block-navigation-item.has-child .wp-block-navigation__submenu-container .wp-block-navigation-item .wp-block-navigation-item__content:visited {
    opacity: 1;
    text-decoration: none;
    color: #fff;
  }
  .wp-block-navigation__responsive-close .wp-block-navigation__responsive-dialog .wp-block-navigation__responsive-container-content .wp-block-navigation__container .wp-block-navigation-item.has-child .wp-block-navigation__submenu-container .wp-block-navigation-item .wp-block-navigation-item__content:hover, .wp-block-navigation__responsive-close .wp-block-navigation__responsive-dialog .wp-block-navigation__responsive-container-content .wp-block-navigation__container .wp-block-navigation-item.has-child .wp-block-navigation__submenu-container .wp-block-navigation-item .wp-block-navigation-item__content:active {
    opacity: 0.5;
  }
}
.wp-block-navigation__responsive-close .wp-block-navigation__responsive-dialog .wp-block-navigation__responsive-container-content .wp-block-navigation__container .wp-block-navigation-item.has-child .wp-block-navigation__submenu-container .wp-block-navigation__submenu-container {
  padding-right: 0;
  border-top: 1px solid rgba(0, 0, 0, 0.15);
}
@media only screen and (min-width: 768px) {
  .wp-block-navigation__responsive-close .wp-block-navigation__responsive-dialog .wp-block-navigation__responsive-container-content .wp-block-navigation__container .wp-block-navigation-item.has-child .wp-block-navigation__submenu-container .wp-block-navigation__submenu-container {
    padding-right: 20px;
    background-color: #074e81 !important;
    position: absolute;
    left: 70%;
    top: 0;
  }
}
.wp-block-navigation__responsive-close .wp-block-navigation__responsive-dialog .wp-block-navigation__responsive-container-content .wp-block-navigation__container .wp-block-navigation-item.has-child.is-open > .wp-block-navigation-item__content {
  font-weight: 700;
}
@media only screen and (min-width: 768px) {
  .wp-block-navigation__responsive-close .wp-block-navigation__responsive-dialog .wp-block-navigation__responsive-container-content .wp-block-navigation__container .wp-block-navigation-item.has-child.is-open > .wp-block-navigation-item__content {
    font-weight: 400;
  }
  .wp-block-navigation__responsive-close .wp-block-navigation__responsive-dialog .wp-block-navigation__responsive-container-content .wp-block-navigation__container .wp-block-navigation-item.has-child.is-open .wp-block-navigation__submenu-container .wp-block-navigation-item {
    flex-direction: column;
    align-items: flex-start;
  }
}
.wp-block-navigation__responsive-close .wp-block-navigation__responsive-dialog .wp-block-navigation__responsive-container-content .wp-block-navigation__container .wp-block-navigation-item .wp-block-navigation-item__content {
  min-height: 50px;
  padding: 1em 0;
  line-height: 1.3;
}
.wp-block-navigation__responsive-close .wp-block-navigation__responsive-dialog .wp-block-navigation__responsive-container-content .wp-block-navigation__container .wp-block-navigation-item .wp-block-navigation-item__content:focus {
  outline: none;
}
.wp-block-navigation__responsive-close .wp-block-navigation__responsive-dialog .wp-block-navigation__responsive-container-content .wp-block-navigation__container .wp-block-navigation-item .wp-block-navigation-item__content:link, .wp-block-navigation__responsive-close .wp-block-navigation__responsive-dialog .wp-block-navigation__responsive-container-content .wp-block-navigation__container .wp-block-navigation-item .wp-block-navigation-item__content:visited {
  text-decoration: none;
}
.wp-block-navigation__responsive-close .wp-block-navigation__responsive-dialog .wp-block-navigation__responsive-container-content .wp-block-navigation__container .wp-block-navigation-item .wp-block-navigation-item__content:hover, .wp-block-navigation__responsive-close .wp-block-navigation__responsive-dialog .wp-block-navigation__responsive-container-content .wp-block-navigation__container .wp-block-navigation-item .wp-block-navigation-item__content:active {
  opacity: 1;
  color: var(--wp--preset--color--brand-primary);
}
@media only screen and (min-width: 768px) {
  .wp-block-navigation__responsive-close .wp-block-navigation__responsive-dialog .wp-block-navigation__responsive-container-content .wp-block-navigation__container .wp-block-navigation-item .wp-block-navigation-item__content {
    display: block;
    width: 100%;
    text-shadow: 0 2px 8px rgba(0, 0, 0, 0.16);
  }
  .wp-block-navigation__responsive-close .wp-block-navigation__responsive-dialog .wp-block-navigation__responsive-container-content .wp-block-navigation__container .wp-block-navigation-item .wp-block-navigation-item__content:hover, .wp-block-navigation__responsive-close .wp-block-navigation__responsive-dialog .wp-block-navigation__responsive-container-content .wp-block-navigation__container .wp-block-navigation-item .wp-block-navigation-item__content:active {
    color: var(--wp--preset--color--brand-primary);
  }
}
.wp-block-navigation__responsive-close .wp-block-navigation__responsive-dialog .wp-block-navigation__responsive-container-content .wp-block-navigation__container .wp-block-navigation-item.link-contact {
  padding-top: 10px;
  align-items: center;
}
@media only screen and (min-width: 768px) {
  .wp-block-navigation__responsive-close .wp-block-navigation__responsive-dialog .wp-block-navigation__responsive-container-content .wp-block-navigation__container .wp-block-navigation-item.link-contact {
    padding-top: 0;
  }
}
.wp-block-navigation__responsive-close .wp-block-navigation__responsive-dialog .wp-block-navigation__responsive-container-content .wp-block-navigation__container .wp-block-navigation-item.link-contact .wp-block-navigation-item__content {
  padding: 0.625rem 1.25rem;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.5rem;
  background-color: var(--wp--preset--color--brand-attention);
  border-radius: 4px;
  font-size: 1rem;
  line-height: 1.3;
  color: #fff;
  position: relative;
  transition: all 0.15s;
}
@media only screen and (min-width: 768px) {
  .wp-block-navigation__responsive-close .wp-block-navigation__responsive-dialog .wp-block-navigation__responsive-container-content .wp-block-navigation__container .wp-block-navigation-item.link-contact .wp-block-navigation-item__content {
    padding: 22px 2.4em 24px;
    font-size: 1.875rem;
  }
}
.wp-block-navigation__responsive-close .wp-block-navigation__responsive-dialog .wp-block-navigation__responsive-container-content .wp-block-navigation__container .wp-block-navigation-item.link-contact .wp-block-navigation-item__content:hover, .wp-block-navigation__responsive-close .wp-block-navigation__responsive-dialog .wp-block-navigation__responsive-container-content .wp-block-navigation__container .wp-block-navigation-item.link-contact .wp-block-navigation-item__content:active {
  opacity: 0.8;
  text-decoration: none;
}
@media only screen and (min-width: 768px) {
  .wp-block-navigation__responsive-close .wp-block-navigation__responsive-dialog .wp-block-navigation__responsive-container-content .wp-block-navigation__container .wp-block-navigation-item.link-contact .wp-block-navigation-item__content {
    padding: 1em 0;
    display: block;
    background-color: transparent;
    font-size: 1rem;
    color: var(--wp--preset--color--site-text);
  }
  .wp-block-navigation__responsive-close .wp-block-navigation__responsive-dialog .wp-block-navigation__responsive-container-content .wp-block-navigation__container .wp-block-navigation-item.link-contact .wp-block-navigation-item__content:hover, .wp-block-navigation__responsive-close .wp-block-navigation__responsive-dialog .wp-block-navigation__responsive-container-content .wp-block-navigation__container .wp-block-navigation-item.link-contact .wp-block-navigation-item__content:active {
    opacity: 1;
    color: var(--wp--preset--color--brand-primary);
  }
}

.button-menu {
  width: 40px;
  height: 40px;
  z-index: 9999;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  position: relative;
}
.button-menu .line {
  display: block;
  width: 20px;
  height: 2px;
  background-color: #000;
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  transition: all 0.15s ease-out;
}
.button-menu .line::before, .button-menu .line::after {
  content: "";
  width: 100%;
  height: 2px;
  background-color: #000;
  position: absolute;
  left: 0;
  transition: all 0.15s ease-out;
}
.button-menu .line::before {
  bottom: 7px;
}
.button-menu .line::after {
  bottom: -7px;
}
.button-menu.is-open .line {
  background-color: transparent;
}
.button-menu.is-open .line::before {
  bottom: 0;
  transform: rotate(-45deg);
}
.button-menu.is-open .line::after {
  bottom: 0;
  transform: rotate(45deg);
}

/* メニューが開くとき */
@-webkit-keyframes overlay-menu__fade-in-animation {
  from {
    opacity: 0;
    transform: translateY(0);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}
@keyframes overlay-menu__fade-in-animation {
  from {
    opacity: 0;
    transform: translateY(0);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}
/* メニューが閉じるとき */
@-webkit-keyframes overlay-menu__fade-out-animation {
  from {
    opacity: 1;
    transform: translateX(0);
  }
  to {
    opacity: 0;
    transform: translateY(0);
  }
}
@keyframes overlay-menu__fade-out-animation {
  from {
    opacity: 1;
    transform: translateX(0);
  }
  to {
    opacity: 0;
    transform: translateY(0);
  }
}
/* ----------------------------------------------------------------
  footer
---------------------------------------------------------------- */
.site-footer {
  padding: 25px 0 10px;
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
  font-size: 0.9375rem;
}
.site-footer a:link, .site-footer a:visited {
  color: var(--wp--preset--color--site-text);
  text-decoration: none;
}
@media only screen and (min-width: 1025px) {
  .site-footer {
    padding: 45px 30px;
    grid-template-columns: -webkit-max-content 1fr -webkit-max-content;
    grid-template-columns: -webkit-max-content -webkit-max-content auto;
    grid-template-columns: max-content max-content auto;
    grid-template-rows: 1fr 1fr;
    gap: 0 2em;
  }
}
@media only screen and (min-width: 1025px) and (min-width: 1440px) {
  .site-footer {
    padding-left: 120px;
    padding-right: 120px;
  }
}
.site-footer .corp-name {
  margin-bottom: 16px;
  font-size: 1.1875rem;
  font-weight: 700;
}
@media only screen and (min-width: 1025px) {
  .site-footer .corp-name {
    grid-column: 1/2;
    grid-row: 1/3;
    margin-bottom: 0;
    font-size: 1rem;
  }
}
.site-footer .office-info {
  margin-bottom: 25px;
  gap: 1em;
}
@media only screen and (min-width: 1025px) {
  .site-footer .office-info {
    grid-column: 2/3;
    grid-row: 1/3;
    margin-bottom: 0;
  }
}
.site-footer .office-info .office-info__item {
  width: 100%;
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.1em;
}
@media only screen and (min-width: 1025px) {
  .site-footer .office-info .office-info__item {
    grid-template-columns: -webkit-max-content auto -webkit-max-content;
    grid-template-columns: max-content auto max-content;
    gap: 1.5em;
  }
}
.site-footer .office-info .office-info__item p {
  margin-top: 0;
  text-align: left;
  line-height: 1.4;
}
.site-footer .office-info .office-info__item .office-info__item__name {
  font-weight: 700;
  white-space: nowrap;
}
.site-footer .office-info .office-info__item .office-info__item__name::before {
  content: "";
  width: 10px;
  height: 10px;
  background-color: var(--wp--preset--color--brand-primary);
  display: inline-block;
  margin-right: 5px;
}
@media only screen and (min-width: 1025px) {
  .site-footer .office-info .office-info__item .office-info__item__name {
    min-width: 6em;
  }
}
.site-footer .office-info .office-info__item .office-info__item__tel {
  white-space: nowrap;
}
.site-footer .footer-nav {
  margin-bottom: 25px;
  display: flex;
  justify-content: center;
  gap: 2em;
}
@media only screen and (min-width: 1025px) {
  .site-footer .footer-nav {
    grid-column: 3/4;
    grid-row: 1/2;
    margin-bottom: 0;
    flex-direction: column;
    justify-content: flex-start;
    gap: 1em;
  }
}
@media only screen and (min-width: 1025px) and (min-width: 1280px) {
  .site-footer .footer-nav {
    flex-direction: row;
    justify-content: flex-end;
    gap: 2em;
  }
}
.site-footer .footer-nav p {
  margin-top: 0;
  font-size: 0.8125rem;
}
@media only screen and (min-width: 1025px) {
  .site-footer .footer-nav p {
    text-align: right;
  }
}
.site-footer .footer-nav a:link, .site-footer .footer-nav a:visited {
  text-decoration: underline;
}
.site-footer .footer-nav a:hover, .site-footer .footer-nav a:active {
  opacity: 0.8;
}
.site-footer .copyright {
  text-align: center;
}
@media only screen and (min-width: 1025px) {
  .site-footer .copyright {
    grid-column: 3/4;
    grid-row: 2/3;
    align-self: end;
    text-align: right;
  }
}

/* ----------------------------------------------------------------
  layout
---------------------------------------------------------------- */
.wp-site-blocks {
  margin-top: 60px;
  padding-inline: clamp(12px, 4.27vw, 32px);
}
@media only screen and (min-width: 768px) {
  .wp-site-blocks {
    margin-top: 60px;
  }
}

/* ----------------------------------------------------------------
  ブロック単位
---------------------------------------------------------------- */
.alignfull {
  margin-inline: calc(clamp(12px, 4.27vw, 32px) * -1);
  width: auto;
}

.wp-block-post-content {
  margin-top: 0;
}

.page-header {
  padding: 25px 0;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  justify-content: center;
  gap: 20px;
}
@media only screen and (min-width: 768px) {
  .page-header {
    padding: 45px 0 55px;
    min-height: 212px;
    flex-direction: column-reverse;
    gap: 16px;
  }
}
.page-header .page-title {
  margin-top: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 12px;
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 1.3;
  text-align: center;
}
.page-header .page-title::after {
  content: "";
  display: block;
  width: 42px;
  height: 4px;
  background-color: var(--wp--preset--color--brand-primary);
}
@media only screen and (min-width: 768px) {
  .page-header .page-title {
    gap: 18px;
    font-size: 2.25rem;
  }
  .page-header .page-title::after {
    height: 5px;
  }
}
.page-header .page-catch-copy {
  margin-top: 0;
  background-color: var(--wp--preset--color--brand-primary);
  font-size: 0.875rem;
  line-height: 1.4;
  text-align: center;
  color: #fff;
  padding: 5px;
}
@media only screen and (min-width: 768px) {
  .page-header .page-catch-copy {
    font-size: 1rem;
    background-color: transparent;
    padding: 0;
    color: var(--wp--preset--color--site-text);
  }
}

/* ----------------------------------------------------------------
  CTA
---------------------------------------------------------------- */
.cta {
  padding: 25px clamp(12px, 4.27vw, 32px);
  margin-top: 40px;
  background-color: var(--wp--preset--color--brand-primary);
}
.cta .inner {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
@media only screen and (min-width: 768px) {
  .cta {
    padding-top: 45px;
    padding-bottom: 50px;
    margin-top: 100px;
  }
  .cta .inner {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 40px 30px;
  }
}

.cta__heading {
  margin-bottom: 1.5em;
}
@media only screen and (min-width: 768px) {
  .cta__heading {
    margin-bottom: 0;
  }
}
.cta__heading .wp-block-heading {
  margin-bottom: 9px;
  font-size: 1.5rem;
  color: #fff;
}
@media only screen and (min-width: 768px) {
  .cta__heading .wp-block-heading {
    margin-bottom: 0;
    font-size: 2rem;
  }
}

.cta__contents {
  background-color: #fff;
  padding: 25px 20px;
  align-items: stretch;
  gap: 0;
}
@media only screen and (min-width: 768px) {
  .cta__contents {
    margin-top: 0;
    width: 100%;
    border-radius: 6px;
  }
}
.cta__contents .wp-block-heading {
  font-size: 1.25rem;
  margin-bottom: 1rem;
  text-align: center;
}
.cta__contents .wp-block-buttons {
  width: 100%;
}
.cta__contents .wp-block-button {
  margin-bottom: 1rem;
  width: 100%;
  max-width: 380px;
}
@media only screen and (min-width: 768px) {
  .cta__contents .wp-block-button {
    max-width: 340px;
  }
}
.cta__contents .wp-block-button .wp-block-button__link {
  min-height: 3.0625rem;
  background-color: #fff;
  border-radius: 999px;
  border: 1px solid var(--wp--preset--color--brand-primary);
  font-weight: 700;
  line-height: 1;
  color: var(--wp--preset--color--brand-primary);
}
.cta__contents .wp-block-button .wp-block-button__link:link, .cta__contents .wp-block-button .wp-block-button__link:visited {
  text-decoration: none;
  color: var(--wp--preset--color--brand-primary);
}
.cta__contents .wp-block-button .wp-block-button__link:hover, .cta__contents .wp-block-button .wp-block-button__link:active {
  background-color: var(--wp--preset--color--brand-primary);
  color: #fff;
  opacity: 1;
}
.cta__contents .wp-block-button .wp-block-button__link:hover::before, .cta__contents .wp-block-button .wp-block-button__link:active::before {
  background-color: #fff;
}
@media only screen and (min-width: 768px) {
  .cta__contents .wp-block-button .wp-block-button__link {
    padding: 0;
  }
}
.cta__contents .wp-block-button .wp-block-button__link::before {
  content: "";
  background-color: var(--wp--preset--color--brand-primary);
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-position: center;
  mask-position: center;
  -webkit-mask-size: 100%;
  mask-size: 100%;
  position: relative;
}
.cta__contents .button-tel .wp-block-button__link {
  font-family: "Roboto Condensed", "Noto Sans JP", sans-serif;
  font-size: 1.5625rem;
}
@media only screen and (min-width: 768px) {
  .cta__contents .button-tel .wp-block-button__link {
    font-size: 1.8125rem;
    padding-top: 0.1rem;
  }
}
.cta__contents .button-tel .wp-block-button__link::before {
  width: 1.08em;
  height: 1.08em;
  -webkit-mask-image: url(../assets/images/common/icon-tel.svg);
  mask-image: url(../assets/images/common/icon-tel.svg);
  top: -0.05em;
}
@media only screen and (min-width: 768px) {
  .cta__contents .button-tel .wp-block-button__link::before {
    width: 1.2068965517em;
    height: 1.2068965517em;
  }
}
.cta__contents .button-inquiry .wp-block-button__link {
  font-size: 1.25rem;
}
@media only screen and (min-width: 768px) {
  .cta__contents .button-inquiry .wp-block-button__link {
    font-size: 1.5rem;
    padding-bottom: 0.1rem;
  }
}
.cta__contents .button-inquiry .wp-block-button__link::before {
  width: 0.95em;
  height: 0.75em;
  -webkit-mask-image: url(../assets/images/common/icon-mail.svg);
  mask-image: url(../assets/images/common/icon-mail.svg);
  top: 0.05em;
}
@media only screen and (min-width: 768px) {
  .cta__contents .button-inquiry .wp-block-button__link::before {
    width: 1em;
    height: 0.7916666667em;
  }
}
.cta__contents p {
  text-align: center;
}

.cta__text-uketsuke {
  padding: 8px 0 6px;
  display: flex;
  align-items: center;
}
.cta__text-uketsuke p {
  font-size: 0.9375rem;
  font-weight: 700;
  line-height: 1;
}
.cta__text-uketsuke p strong {
  font-size: 1.125rem;
}

/* ----------------------------------------------------------------
  基本タイトル
---------------------------------------------------------------- */
h1.wp-block-heading:not(.no-default-style) {
  padding-left: 20px;
  padding-bottom: 0.1em;
  font-size: 1.625rem;
  font-weight: 700;
  line-height: 1.5;
  color: var(--wp--preset--color--brand-primary);
  position: relative;
}
@media only screen and (min-width: 768px) {
  h1.wp-block-heading:not(.no-default-style) {
    padding-left: 34px;
    font-size: 2.25rem;
  }
}
h1.wp-block-heading:not(.no-default-style)::before {
  content: "";
  width: 6px;
  height: 100%;
  background-color: var(--wp--preset--color--brand-primary);
  position: absolute;
  left: 0;
  top: 0;
}
@media only screen and (min-width: 768px) {
  h1.wp-block-heading:not(.no-default-style)::before {
    width: 10px;
  }
}

h2.wp-block-heading:not(.no-default-style) {
  padding-left: 20px;
  padding-bottom: 0.1em;
  font-size: 1.375rem;
  font-weight: 700;
  line-height: 1.5;
  color: var(--wp--preset--color--brand-primary);
  position: relative;
}
@media only screen and (min-width: 768px) {
  h2.wp-block-heading:not(.no-default-style) {
    padding-left: 23px;
    font-size: 1.75rem;
  }
}
h2.wp-block-heading:not(.no-default-style)::before {
  content: "";
  width: 7px;
  height: 100%;
  background-color: var(--wp--preset--color--brand-primary);
  position: absolute;
  left: 0;
  top: 0;
}

/* ----------------------------------------------------------------
  記事タイトル
---------------------------------------------------------------- */
.single-main .wp-block-post-title {
  padding-bottom: 1.25em;
  margin-top: 0.5em;
  margin-bottom: 1.25em;
  font-size: 1.5rem;
  line-height: 1.6;
  border-bottom: 1px solid #707070;
}
@media only screen and (min-width: 768px) {
  .single-main .wp-block-post-title {
    margin-top: 1em;
    font-size: 2.375rem;
  }
}

/* ----------------------------------------------------------------
  クラス付きタイトル
---------------------------------------------------------------- */
.title1 {
  padding-left: 32px;
  font-size: 1.125rem;
  line-height: 1.5;
  position: relative;
}
@media only screen and (min-width: 768px) {
  .title1 {
    padding-left: 40px;
    font-size: 1.5rem;
    line-height: 1.7;
  }
}
.title1 strong {
  font-weight: 700;
  color: #ee1c09;
}
.title1::before {
  content: "";
  width: 22px;
  height: 100%;
  background-color: #0091f7;
  -webkit-mask-image: url(../assets/images/common/icon-check2.svg);
  mask-image: url(../assets/images/common/icon-check2.svg);
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-position: center top 0.2em;
  mask-position: center top 0.2em;
  -webkit-mask-size: 100%;
  mask-size: 100%;
  position: absolute;
  left: 0;
  top: 0;
}
@media only screen and (min-width: 768px) {
  .title1::before {
    width: 30px;
    -webkit-mask-position: center top 0.2em;
    mask-position: center top 0.2em;
  }
}

.bg-heading1 {
  padding: 4px 16px 8px;
  background: var(--brand-primary, #0062a7);
  color: #fff;
  font-size: 1.25rem;
}
@media only screen and (min-width: 768px) {
  .bg-heading1 {
    font-size: 1.625rem;
  }
}

/* ----------------------------------------------------------------
  ブロック
---------------------------------------------------------------- */
.wp-block-footnotes {
  list-style: none;
  /* デフォルトの番号を消す */
  counter-reset: custom-counter;
  /* カウンターをリセット */
  padding: 1em 2em 1em 3em;
  border: 1px solid #cccccc;
  font-size: 95%;
}
@media only screen and (min-width: 768px) {
  .wp-block-footnotes {
    padding: 2em 2em 2em 3.5em;
    font-size: 85%;
  }
}
.wp-block-footnotes li {
  counter-increment: custom-counter;
  /* 各リスト項目でカウンターを増加 */
  scroll-margin-top: 30vh;
  padding-left: 1em;
  line-height: 1.8;
}
.wp-block-footnotes li::marker {
  content: "※" counter(custom-counter);
  /* "※" + 数字 */
}

/* ----------------------------------------------------------------
  テキストスタイル
---------------------------------------------------------------- */
.text-annotation {
  font-size: 0.75rem !important;
  line-height: 1.5;
  color: #999999;
}

@media only screen and (min-width: 768px) {
  .page-intro {
    font-size: 1.5625rem;
    text-align: center;
  }
}
.page-intro br {
  display: none;
}
@media only screen and (min-width: 768px) {
  .page-intro br {
    display: block;
  }
}

.wp-block-post-date {
  font-family: "Roboto Condensed", "Noto Sans JP", sans-serif;
  font-size: 0.9375rem;
  font-weight: 600;
  color: var(--wp--preset--color--brand-primary);
  letter-spacing: 0.1em;
  line-height: 1;
}
@media only screen and (min-width: 768px) {
  .wp-block-post-date {
    font-size: 1.75rem;
  }
}

/* ----------------------------------------------------------------
    リンクタイプ
  ---------------------------------------------------------------- */
a[target=_blank]::after {
  content: "";
  display: inline-block;
  width: 1.125em;
  height: 0.875em;
  background-color: #cccccc;
  -webkit-mask-image: url(../assets/images/common/icon-blank.svg);
  mask-image: url(../assets/images/common/icon-blank.svg);
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-position: center;
  mask-position: center;
  -webkit-mask-size: 100%;
  mask-size: 100%;
  margin: 0 5px;
}

.link-tel:hover, .link-tel:focus {
  outline: none;
  text-decoration: none;
}

.link-arrow-right {
  color: var(--wp--preset--color--site-text);
}
.link-arrow-right::after {
  margin-left: 5px;
}
.link-arrow-right:link, .link-arrow-right:visited {
  text-decoration: none;
}

.link-download {
  display: inline-flex;
  align-items: center;
  gap: 2px;
  color: var(--wp--preset--color--site-text);
}
.link-download::after {
  margin-left: 5px;
}
.link-download:link, .link-download:visited {
  text-decoration: none;
}

/* ----------------------------------------------------------------
    ボタン wrapper
  ---------------------------------------------------------------- */
.wp-block-buttons {
  flex-direction: column;
  align-items: stretch;
  gap: 2em;
}
@media only screen and (min-width: 768px) {
  .wp-block-buttons {
    flex-direction: row;
    justify-content: center;
  }
}

/* ----------------------------------------------------------------
    ボタン 個別
  ---------------------------------------------------------------- */
.wp-block-button .wp-block-button__link {
  padding: 0.625rem 1.25rem;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.5rem;
  background-color: var(--wp--preset--color--brand-attention);
  border-radius: 4px;
  font-size: 1rem;
  font-weight: 700;
  line-height: 1.3;
  position: relative;
  transition: all 0.15s;
}
.wp-block-button .wp-block-button__link:link, .wp-block-button .wp-block-button__link:visited {
  text-decoration: none;
  color: #fff;
}
.wp-block-button .wp-block-button__link[target=_blank]::after {
  content: "";
  width: 1.125em;
  height: 0.875em;
  background-color: #fff;
  -webkit-mask-image: url(../assets/images/common/icon-blank.svg);
  mask-image: url(../assets/images/common/icon-blank.svg);
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-position: center;
  mask-position: center;
  -webkit-mask-size: 100%;
  mask-size: 100%;
  margin: 0;
}
.wp-block-button.button1 .wp-block-button__link {
  padding: 0.7em 1.8em;
  background-color: #fff;
  border: 1px solid var(--color-gray-700, #757575);
  font-weight: 400;
  color: var(--Base-black, #000);
  width: 100%;
}
@media only screen and (min-width: 768px) {
  .wp-block-button.button1 .wp-block-button__link {
    font-size: 1.125rem;
  }
}
.wp-block-button.button1 .wp-block-button__link[target=_blank]::after {
  background-color: var(--brand-primary, #0062a7);
}
.wp-block-button.button1 .wp-block-button__link:link, .wp-block-button.button1 .wp-block-button__link:visited {
  background-color: #fff;
}
.wp-block-button.button1 .wp-block-button__link:hover, .wp-block-button.button1 .wp-block-button__link:active {
  opacity: 1;
  background-color: var(--brand-primary, #0062a7);
  color: #fff;
}
.wp-block-button.button1 .wp-block-button__link:hover[target=_blank]::after, .wp-block-button.button1 .wp-block-button__link:active[target=_blank]::after {
  background-color: #ffffff;
}

/* ----------------------------------------------------------------
  ベーススタイル
---------------------------------------------------------------- */
.wp-block-list {
  padding-left: 1.5em;
}
.wp-block-list li {
  margin-bottom: 0.5em;
  line-height: 1.5;
}
.wp-block-list li::marker {
  color: #cccccc;
}

/* ----------------------------------------------------------------
  チェックマークリスト
---------------------------------------------------------------- */
.list-check_mark {
  padding-left: 0;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 10px;
  align-self: stretch;
}
@media only screen and (min-width: 768px) {
  .list-check_mark {
    flex-direction: row;
    flex-wrap: wrap;
    gap: 20px;
  }
}
.list-check_mark li {
  margin-bottom: 0;
  padding: 5px 23px 7px 20px;
  display: flex;
  align-items: center;
  gap: 10px;
  align-self: stretch;
  border-radius: 999px;
  background-color: var(--Brand-BrightBlue, #0091f7);
  font-size: 1.125rem;
  line-height: 1.5;
  color: #fff;
}
.list-check_mark li::before {
  flex-shrink: 0;
  flex-grow: 0;
  content: "";
  width: 13px;
  height: 10px;
  background-color: #fdf224;
  -webkit-mask-image: url(../assets/images/common/icon-check.svg);
  mask-image: url(../assets/images/common/icon-check.svg);
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-position: center;
  mask-position: center;
  -webkit-mask-size: 100%;
  mask-size: 100%;
}
.list-check_mark.list-check_mark--02 li {
  background-color: var(--wp--preset--color--brand-primary);
}
@media only screen and (min-width: 768px) {
  .list-check_mark.list-check_mark--03 {
    margin-inline: auto;
    flex-direction: column;
    gap: 18px;
  }
}
.list-check_mark.list-check_mark--03 li {
  padding: 8px 16px;
  background-color: var(--wp--preset--color--brand-primary);
  border-radius: 8px;
  gap: 12px;
}
@media only screen and (min-width: 768px) {
  .list-check_mark.list-check_mark--03 li {
    padding: 16px 26px 16px 20px;
    border-radius: 12px;
    gap: 20px;
    font-size: 1.375rem;
  }
}
.list-check_mark.list-check_mark--03 li::before {
  width: 20px;
  height: 20px;
  background-color: transparent;
  background-image: url(../assets/images/common/icon-check-box.png);
  background-repeat: no-repeat;
  background-position: center;
  background-size: 100%;
  -webkit-mask-image: none;
  mask-image: none;
}
@media only screen and (min-width: 768px) {
  .list-check_mark.list-check_mark--03 li::before {
    width: 30px;
    height: 30px;
  }
}

/* ----------------------------------------------------------------
  アイコン付きブロックリスト
---------------------------------------------------------------- */
.list-icon-block, .list-icon-block-2 {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
}
@media only screen and (min-width: 768px) {
  .list-icon-block, .list-icon-block-2 {
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
  }
}
.list-icon-block .item, .list-icon-block-2 .item {
  margin-top: 0;
  padding: 14px 10px;
  display: grid;
  grid-template-columns: clamp(55px, 17.33vw, 65px) auto;
  align-items: center;
  gap: 5px 20px;
  border-radius: 10px;
  border: 4px solid var(--base-gray7, #efefef);
  background: var(--white, #fff);
}
@media only screen and (min-width: 768px) {
  .list-icon-block .item, .list-icon-block-2 .item {
    grid-template-columns: clamp(75px, 7.64vw, 110px) auto;
    padding: 20px 24px;
    gap: 5px 32px;
  }
}
.list-icon-block .item .item-title, .list-icon-block-2 .item .item-title {
  grid-column: 2/3;
  grid-row: 1/2;
  align-self: end;
  font-size: 1.125rem;
  font-weight: 700;
  line-height: 1.5;
}
@media only screen and (min-width: 768px) {
  .list-icon-block .item .item-title, .list-icon-block-2 .item .item-title {
    font-size: 1.25rem;
  }
}
.list-icon-block .item .item-text, .list-icon-block-2 .item .item-text {
  grid-column: 2/3;
  grid-row: 2/3;
  align-self: start;
  margin-top: 0;
  font-size: 0.875rem;
  line-height: 1.5;
}
@media only screen and (min-width: 768px) {
  .list-icon-block .item .item-text, .list-icon-block-2 .item .item-text {
    font-size: 1rem;
  }
}
.list-icon-block .item .item-image, .list-icon-block-2 .item .item-image {
  margin-top: 0;
  grid-column: 1/2;
  grid-row: 1/3;
  aspect-ratio: 1/1;
  align-self: center;
  overflow: hidden;
}
.list-icon-block .item .item-image img, .list-icon-block-2 .item .item-image img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
@media only screen and (min-width: 768px) {
  .list-icon-block-2 {
    grid-template-columns: 1fr;
  }
}
.list-icon-block-2 .item {
  padding: 14px 10px 14px 14px;
  gap: 5px 15px;
}
@media only screen and (min-width: 768px) {
  .list-icon-block-2 .item {
    width: 100%;
    grid-template-columns: 124px auto;
    padding: 20px 24px;
    gap: 5px 32px;
  }
}
@media only screen and (min-width: 768px) {
  .list-icon-block-2 .item .item-title {
    font-size: 1.5rem;
  }
}
.list-icon-block-2 .item .item-image {
  aspect-ratio: 124/99;
}

/* ----------------------------------------------------------------
  ポイントリスト
---------------------------------------------------------------- */
@media only screen and (min-width: 768px) {
  .list-point {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 24px;
  }
}

.block-point-item {
  box-shadow: 0 3px 8px 0 rgba(0, 24, 39, 0.12);
  border-radius: 10px;
  background-color: #fff;
  overflow: hidden;
}
@media only screen and (min-width: 768px) {
  .block-point-item {
    margin-top: 0;
    border-radius: 14px;
  }
}
.block-point-item .item-title {
  padding: 16px 18px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 8px;
  background-color: var(--wp--preset--color--brand-primary);
}
@media only screen and (min-width: 768px) {
  .block-point-item .item-title {
    padding: 16px 20px;
  }
}
.block-point-item .item-title p {
  padding: 4px 12px 6px;
  border-radius: 999px;
  background: var(--Yellow, #fdf224);
  font-size: 0.8125rem;
  font-weight: 700;
  line-height: 1;
  color: var(--wp--preset--color--brand-primary);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 2px;
}
@media only screen and (min-width: 768px) {
  .block-point-item .item-title p {
    padding: 5px 16px 7px;
    font-size: 1rem;
  }
}
.block-point-item .item-title .wp-block-heading {
  margin-top: 0;
  font-size: 1.125rem;
  line-height: 1.5;
  color: #fff;
}
@media only screen and (min-width: 768px) {
  .block-point-item .item-title .wp-block-heading {
    font-size: 1.3125rem;
  }
}
.block-point-item .item-text {
  margin-top: 0;
  padding: 14px 16px 16px;
}
@media only screen and (min-width: 768px) {
  .block-point-item .item-text {
    padding: 12px 16px 16px;
  }
}
.block-point-item .item-text p {
  margin-top: 0;
}
@media only screen and (min-width: 768px) {
  .block-point-item .item-text p {
    font-size: 1.125rem;
  }
}

/* ----------------------------------------------------------------
  フローリスト
---------------------------------------------------------------- */
.list-flow {
  display: grid;
  grid-template-columns: 1fr;
  gap: 5px;
}
@media only screen and (min-width: 768px) {
  .list-flow {
    gap: 8px;
  }
}
.list-flow .item {
  margin-top: 0;
  padding: 14px;
  display: grid;
  grid-template-columns: clamp(75px, 10.07vw, 145px) auto;
  align-items: center;
  gap: 5px 16px;
  width: 100%;
  border: 4px solid var(--base-gray7, #efefef);
  background: var(--white, #fff);
}
@media only screen and (min-width: 768px) {
  .list-flow .item {
    padding: 16px;
    gap: 5px 32px;
    border-width: 5px;
  }
}
.list-flow .item .item-title {
  grid-column: 2/3;
  grid-row: 1/2;
  align-self: end;
  font-size: 1.125rem;
  font-weight: 700;
  line-height: 1.5;
}
@media only screen and (min-width: 768px) {
  .list-flow .item .item-title {
    font-size: 1.5rem;
  }
}
.list-flow .item .item-text {
  grid-column: 2/3;
  grid-row: 2/3;
  align-self: start;
  margin-top: 0;
  font-size: 0.875rem;
  line-height: 1.5;
}
@media only screen and (min-width: 768px) {
  .list-flow .item .item-text {
    font-size: 1rem;
  }
}
.list-flow .item .item-image {
  margin-top: 0;
  grid-column: 1/2;
  grid-row: 1/3;
  aspect-ratio: 1/1;
  align-self: center;
  overflow: hidden;
}
.list-flow .item .item-image img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
.list-flow .separate-image {
  margin-top: 0;
  width: 100%;
  height: 15px;
}
@media only screen and (min-width: 768px) {
  .list-flow .separate-image {
    height: 23px;
  }
}
.list-flow .separate-image figure {
  width: 100%;
  height: 100%;
}
.list-flow .separate-image figure img {
  margin-inline: auto;
  width: auto;
  height: 100%;
  -o-object-fit: contain;
  object-fit: contain;
}

/* ----------------------------------------------------------------
  記事リスト
---------------------------------------------------------------- */
.list-post {
  border-top: 1px dashed #9fa0a0;
}
.list-post .wp-block-post {
  padding-bottom: 12px;
  margin-top: 16px;
  border-bottom: 1px dashed #9fa0a0;
}
@media only screen and (min-width: 768px) {
  .list-post .wp-block-post {
    padding-bottom: 50px;
    margin-top: 40px;
    display: flex;
    gap: 127px;
  }
}
.list-post .wp-block-post .wp-block-post-date {
  font-size: 0.8125rem;
  font-weight: 400;
}
@media only screen and (min-width: 768px) {
  .list-post .wp-block-post .wp-block-post-date {
    font-size: 1.5625rem;
    line-height: 1.6;
  }
}
.list-post .wp-block-post .wp-block-post-title {
  margin-top: 0.5em;
  font-size: 0.75rem;
  font-weight: 400;
}
@media only screen and (min-width: 768px) {
  .list-post .wp-block-post .wp-block-post-title {
    margin-top: 0;
    font-size: 1.5625rem;
    line-height: 1.6;
  }
}
.list-post .wp-block-post .wp-block-post-title a:link, .list-post .wp-block-post .wp-block-post-title a:visited {
  color: var(--wp--preset--color--site-text);
}

/* ----------------------------------------------------------------
  ページネーション
---------------------------------------------------------------- */
.wp-block-query-pagination {
  margin-top: 50px;
  justify-content: center;
  gap: 1.5em;
  font-size: 0.875rem;
  line-height: 1;
  color: #2a2a2a;
}
@media only screen and (min-width: 768px) {
  .wp-block-query-pagination {
    margin-top: 100px;
    font-size: 1.5625rem;
  }
}
.wp-block-query-pagination .wp-block-query-pagination-numbers {
  display: flex;
  align-items: center;
  gap: 0;
  font-family: "Roboto Condensed", "Noto Sans JP", sans-serif;
}
.wp-block-query-pagination .wp-block-query-pagination-numbers .page-numbers:not(:last-child):after {
  content: "/";
  font-size: 80%;
  margin: 0 1.5em;
}
/* ----------------------------------------------------------------
    テーブルタイプ
  ---------------------------------------------------------------- */
.wp-block-table table {
  border-top: 1px solid #707070;
}
.wp-block-table table th,
.wp-block-table table td {
  padding: 2em 1em;
  border: none;
  border-bottom: 1px solid #707070;
  line-height: 1.8;
}
@media only screen and (min-width: 768px) {
  .wp-block-table table th,
.wp-block-table table td {
    padding: 2em;
    font-size: 1.5625rem;
  }
}
.wp-block-table table tr td:first-of-type {
  width: 35%;
  background-color: #e8f6f9;
  text-align: center;
  color: var(--wp--preset--color--brand-primary);
}
@media only screen and (min-width: 768px) {
  .wp-block-table table tr td:first-of-type {
    padding: 2em 1em;
  }
}
.wp-block-table.table-type1 table th,
.wp-block-table.table-type1 table td {
  padding: 1em;
}
@media only screen and (min-width: 768px) {
  .wp-block-table.table-type1 table th,
.wp-block-table.table-type1 table td {
    padding: 1em 1.5em;
    font-size: 1rem;
  }
}
.wp-block-table.table-type1 table tr td:first-of-type {
  width: auto;
  text-align: left;
  background-color: #f5f5f5;
  color: var(--wp--preset--color--site-text);
}
@media only screen and (min-width: 768px) {
  .wp-block-table.table-type1 table tr td:first-of-type {
    padding: 1em 1.5em;
  }
}

/* ----------------------------------------------------------------
  ページメインビジュアル
---------------------------------------------------------------- */
.page-mv {
  margin-top: 0;
  margin-bottom: 30px;
  position: relative;
}
@media only screen and (min-width: 768px) {
  .page-mv {
    margin-bottom: 60px;
  }
}
.page-mv:has(.item-data) {
  border: 2px solid var(--wp--preset--color--brand-primary);
}
.page-mv:has(.item-data) .wp-block-image {
  aspect-ratio: 343/230;
}
@media only screen and (min-width: 768px) {
  .page-mv:has(.item-data) .wp-block-image {
    aspect-ratio: 1000/390;
  }
}
.page-mv .item-images {
  margin-top: 0;
}
.page-mv .wp-block-image {
  aspect-ratio: 343/149;
  overflow: hidden;
}
@media only screen and (min-width: 768px) {
  .page-mv .wp-block-image {
    aspect-ratio: 1000/435;
  }
}
.page-mv .wp-block-image img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
.page-mv .item-data {
  margin-top: 0;
  padding: 16px;
  background-color: var(--wp--preset--color--brand-primary);
  color: #fff;
}
@media only screen and (min-width: 768px) {
  .page-mv .item-data {
    padding: 20px 32px;
    font-size: 1.25rem;
  }
}
.page-mv .item-data .wp-block-image {
  aspect-ratio: unset;
}
.page-mv .item-data p {
  color: #fff;
  text-align: left;
  font-weight: 700;
}
.page-mv .item-data p:first-of-type {
  margin-top: 0;
}

.page-mv--boofy-next-navinity .item-images .wp-block-image img {
  -o-object-fit: contain;
  object-fit: contain;
}

.page-mv--factory-one .item-images {
  position: relative;
}
.page-mv--factory-one .wp-block-image.img-factory_one {
  aspect-ratio: unset;
  position: absolute;
  right: 5px;
  bottom: 5px;
}

.page-mv--buhin-hyo-editor-option .item-data {
  display: grid;
  grid-template-columns: min(90px, 24vw) 1fr;
  gap: 16px;
  align-items: center;
}
@media only screen and (min-width: 768px) {
  .page-mv--buhin-hyo-editor-option .item-data {
    gap: 20px;
    grid-template-columns: 130px 1fr;
  }
}

.page-mv--and-security-plus .item-images .wp-block-image img {
  -o-object-fit: contain;
  object-fit: contain;
}
.page-mv--and-security-plus .item-data {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
}
@media only screen and (min-width: 768px) {
  .page-mv--and-security-plus .item-data {
    grid-template-columns: 1fr min(200px, 15.28vw);
    grid-auto-rows: repeat(3, auto);
    gap: 10px 15px;
  }
}
.page-mv--and-security-plus .item-data p {
  margin-top: 0;
}
.page-mv--and-security-plus .item-data .p-block-heading {
  font-size: 1.375rem;
}
@media only screen and (min-width: 768px) {
  .page-mv--and-security-plus .item-data .p-block-heading {
    grid-column: 1/2;
    font-size: 1.75rem;
  }
}
.page-mv--and-security-plus .item-data .text-attention {
  margin-top: 0;
  font-size: 0.75rem;
  font-weight: 400;
}
@media only screen and (min-width: 768px) {
  .page-mv--and-security-plus .item-data .text-attention {
    grid-column: 1/2;
    grid-row: 3/4;
  }
}
.page-mv--and-security-plus .item-data .img-bois_security {
  margin-top: 5px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
}
@media only screen and (min-width: 768px) {
  .page-mv--and-security-plus .item-data .img-bois_security {
    grid-column: 2/3;
    grid-row: 1/4;
    align-self: start;
    margin-top: 0;
    flex-direction: column;
    align-items: center;
    gap: 5px;
  }
}
.page-mv--and-security-plus .item-data .img-bois_security .wp-block-image {
  aspect-ratio: unset;
  width: 71px;
}
@media only screen and (min-width: 768px) {
  .page-mv--and-security-plus .item-data .img-bois_security .wp-block-image {
    width: min(119px, 8.26vw);
  }
}
.page-mv--and-security-plus .item-data .img-bois_security p {
  margin-top: 0;
  font-size: 0.625rem;
  font-weight: 400;
}
@media only screen and (min-width: 768px) {
  .page-mv--and-security-plus .item-data .img-bois_security p {
    text-align: center;
  }
}

/* ----------------------------------------------------------------
  セクショングループ
---------------------------------------------------------------- */
.contents-section {
  margin-block: 30px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.contents-section > * {
  margin-top: 0;
}
@media only screen and (min-width: 768px) {
  .contents-section {
    margin-block: 60px;
    gap: 30px;
  }
}

/* ----------------------------------------------------------------
  ブロックグループ
---------------------------------------------------------------- */
.list-block-group:first-of-type {
  margin-top: 0;
}

.list-block-group2 {
  margin-top: 0;
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
}
@media only screen and (min-width: 768px) {
  .list-block-group2 {
    grid-template-columns: repeat(2, 1fr);
    gap: 40px;
  }
}
.list-block-group2 > * {
  margin-top: 0;
}

.block1 {
  padding-bottom: 16px;
  margin-top: 0;
  width: 100%;
  display: grid;
  gap: 12px;
  border-radius: 4px;
  border: 1px solid var(--Base-Grey2, #ccc);
  background: var(--white, #fff);
}
@media only screen and (min-width: 768px) {
  .block1 {
    padding: 20px 25px 20px 20px;
    gap: 4px 20px;
    grid-template-columns: min(230px, 15.97vw) auto -webkit-max-content;
    grid-template-columns: min(230px, 15.97vw) auto max-content;
    align-items: center;
  }
}
.block1 .item-image {
  aspect-ratio: 343/130;
  overflow: hidden;
}
@media only screen and (min-width: 768px) {
  .block1 .item-image {
    align-self: center;
    aspect-ratio: 230/142;
  }
}
.block1 .item-image a {
  display: block;
  aspect-ratio: 343/130;
  overflow: hidden;
  text-align: center;
}
@media only screen and (min-width: 768px) {
  .block1 .item-image a {
    align-self: center;
    aspect-ratio: 230/142;
  }
}
.block1 .item-image img {
  margin-inline: auto;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
.block1 .item-image.item-image--type2 img {
  width: auto;
  height: 100%;
}
@media only screen and (min-width: 768px) {
  .block1 .item-image.item-image--type2 img {
    width: 100%;
    height: 100%;
  }
}
.block1 .item-meta {
  margin-top: 0;
  padding-left: 16px;
  padding-right: 16px;
}
@media only screen and (min-width: 768px) {
  .block1 .item-meta {
    padding-left: 0;
    padding-right: 0;
    font-size: clamp(1.25rem, 1.67vw, 1.5rem);
    text-align: left;
  }
}
.block1 .item-name {
  font-size: 1.375rem;
  font-weight: 700;
  line-height: 1.4;
  color: var(--wp--preset--color--brand-primary);
  text-align: center;
}
@media only screen and (min-width: 768px) {
  .block1 .item-name {
    font-size: clamp(1.25rem, 1.67vw, 1.5rem);
    text-align: left;
  }
}
.block1 .item-name a:link, .block1 .item-name a:visited {
  color: var(--wp--preset--color--brand-primary);
  text-decoration: none;
}
.block1 .item-text {
  margin-top: 4px;
  font-size: 0.875rem;
  line-height: 1.5;
  text-align: left;
}
@media only screen and (min-width: 768px) {
  .block1 .item-text {
    font-size: 1rem;
    line-height: 1.7;
  }
}
.block1 .wp-block-buttons {
  margin-top: 0;
  padding-left: 16px;
  padding-right: 16px;
}
@media only screen and (min-width: 768px) {
  .block1 .wp-block-buttons {
    padding-left: 0;
    padding-right: 0;
  }
}

.block2 {
  padding: 16px;
  background: var(--Brand-LightBlue, #f5f8fa);
  border-radius: 10px;
}
@media only screen and (min-width: 768px) {
  .block2 {
    border-radius: 20px;
    padding: 30px;
  }
}

.block3 {
  padding-bottom: 20px;
  gap: 0;
  border-radius: 8px;
  border: 1px solid var(--wp--preset--color--brand-primary);
  background: #fff;
  overflow: hidden;
}
.block3 .item-title {
  display: flex;
  padding: 15px 10px;
  justify-content: center;
  align-items: center;
  width: 100%;
  background-color: var(--wp--preset--color--brand-primary);
  font-size: 1.25rem;
  font-weight: 700;
  line-height: 1.4;
  color: #fff;
}
@media only screen and (min-width: 768px) {
  .block3 .item-title {
    padding: 16px 25px;
    font-size: 1.625rem;
    text-align: center;
  }
}
.block3 .item-image {
  margin-top: 0;
  aspect-ratio: 343/121;
  width: 100%;
  overflow: hidden;
}
@media only screen and (min-width: 768px) {
  .block3 .item-image {
    aspect-ratio: 48/17;
  }
}
.block3 .item-image img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
.block3 .item-text {
  margin-top: 0;
  padding: 10px 15px 0;
  font-size: 0.875rem;
  line-height: 1.5;
}
@media only screen and (min-width: 768px) {
  .block3 .item-text {
    padding: 16px 25px 0;
    font-size: 1rem;
    line-height: 1.7;
  }
}
.block3 .wp-block-buttons {
  margin-top: 10px;
  width: 100%;
  justify-content: center;
}
@media only screen and (min-width: 768px) {
  .block3 .wp-block-buttons {
    margin-top: 16px;
  }
}

.more-link-block {
  margin-top: 40px;
  padding: 40px 25px;
  background-color: #f5f8fa;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
}
@media only screen and (min-width: 768px) {
  .more-link-block {
    margin-top: 60px;
    padding: 70px 25px;
    flex-direction: row;
    justify-content: center;
    gap: 30px;
  }
}
.more-link-block p {
  font-size: 1.25rem;
  font-weight: 500;
  text-align: center;
}
.more-link-block .wp-block-buttons {
  margin-top: 0;
}

.block-check-box-item {
  box-shadow: 0 3px 8px 0 rgba(0, 24, 39, 0.12);
  border-radius: 10px;
  background-color: #fff;
  overflow: hidden;
}
@media only screen and (min-width: 768px) {
  .block-check-box-item {
    border-radius: 14px;
  }
}
.block-check-box-item .item-title {
  display: flex;
  padding: 8px 12px 10px 6px;
  justify-content: center;
  align-items: baseline;
  gap: 0;
  align-self: stretch;
  background-color: var(--wp--preset--color--brand-primary);
  font-size: 0.8125rem;
  font-weight: 700;
  line-height: 1.4;
  color: #fff;
}
@media only screen and (min-width: 768px) {
  .block-check-box-item .item-title {
    padding: 10px 12px 12px 6px;
    font-size: 1.125rem;
  }
}
.block-check-box-item .item-title strong {
  margin-right: 0.1em;
  font-size: 192%;
}
@media only screen and (min-width: 768px) {
  .block-check-box-item .item-title strong {
    font-size: 167%;
  }
}
.block-check-box-item .item-title::before {
  content: "";
  width: 25px;
  height: 22px;
  margin-right: 8px;
  background-color: #fdf224;
  -webkit-mask-image: url(../assets/images/common/icon-check2.svg);
  mask-image: url(../assets/images/common/icon-check2.svg);
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-position: center;
  mask-position: center;
  -webkit-mask-size: 100%;
  mask-size: 100%;
}
@media only screen and (min-width: 768px) {
  .block-check-box-item .item-title::before {
    width: 32px;
    height: 28px;
  }
}
.block-check-box-item .item-text {
  margin-top: 0;
  padding: 10px 16px 15px 16px;
  font-size: 0.875rem;
  line-height: 1.5;
}
@media only screen and (min-width: 768px) {
  .block-check-box-item .item-text {
    padding: 16px 24px 20px 24px;
    font-size: 1rem;
    line-height: 1.7;
  }
}

.block-separate {
  padding: 10px;
  background-color: #fff;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.block-separate > * {
  margin-top: 0;
}
@media only screen and (min-width: 768px) {
  .block-separate {
    padding: min(40px, 2.78vw) min(50px, 3.47vw);
    flex-direction: row;
    gap: min(30px, 2.08vw);
  }
}

/* ----------------------------------------------------------------
  背景色付きボックス
---------------------------------------------------------------- */
.block-with-image-bg-light-blue, .block-with-image-bg-light-blue-light {
  padding: 24px 32px;
  border-radius: 16px;
  background-color: var(--wp--preset--color--brand-lightblue);
  flex-direction: column;
  gap: 30px;
}
@media only screen and (min-width: 640px) {
  .block-with-image-bg-light-blue, .block-with-image-bg-light-blue-light {
    padding: 32px 40px;
    flex-direction: row;
    gap: 40px;
  }
}
.block-with-image-bg-light-blue .item-data p, .block-with-image-bg-light-blue-light .item-data p {
  font-size: 1.25rem;
  font-weight: 700;
}
@media only screen and (min-width: 640px) {
  .block-with-image-bg-light-blue .item-data p, .block-with-image-bg-light-blue-light .item-data p {
    font-size: 1.5rem;
  }
}
.block-with-image-bg-light-blue .item-image, .block-with-image-bg-light-blue-light .item-image {
  width: 100%;
}
@media only screen and (min-width: 640px) {
  .block-with-image-bg-light-blue .item-image, .block-with-image-bg-light-blue-light .item-image {
    width: auto;
  }
}
.block-with-image-bg-light-blue .item-image img, .block-with-image-bg-light-blue-light .item-image img {
  margin-inline: auto;
}
@media only screen and (min-width: 640px) {
  .block-with-image-bg-light-blue .item-image img, .block-with-image-bg-light-blue-light .item-image img {
    width: 18vw;
    max-width: 220px;
  }
}

.block-with-image-bg-light-blue-light .item-data p {
  font-size: 1rem;
  font-weight: 400;
}

/* ----------------------------------------------------------------
  ボーダーボックス
---------------------------------------------------------------- */
.border-box-1 {
  border-radius: 10px;
  border: 4px solid var(--base-gray7, #efefef);
  padding: 20px;
  display: flex;
  flex-direction: column;
  gap: 0;
}
@media only screen and (min-width: 768px) {
  .border-box-1 {
    padding: 40px;
    flex-direction: row;
    gap: 40px;
  }
}
.border-box-1 .item-image {
  margin-top: 16px;
  width: 55%;
  max-width: 220px;
  margin-inline: auto;
}
@media only screen and (min-width: 768px) {
  .border-box-1 .item-image {
    margin: 0;
    width: 100%;
    max-width: 180px;
  }
}
@media only screen and (min-width: 768px) {
  .border-box-1 .item-data {
    margin-top: 0;
  }
}
.border-box-1 .item-data .item-title {
  font-size: 1.375rem;
  line-height: 1.5;
}
@media only screen and (min-width: 768px) {
  .border-box-1 .item-data .item-title {
    font-size: 2rem;
  }
}
.border-box-1 .item-data .item-catch-copy {
  font-size: 1rem;
}
@media only screen and (min-width: 768px) {
  .border-box-1 .item-data .item-catch-copy {
    font-size: 1.25rem;
  }
}
.border-box-1 .item-data .item-text {
  font-size: 0.75rem;
}
@media only screen and (min-width: 768px) {
  .border-box-1 .item-data .item-text {
    font-size: 0.875rem;
  }
}
.border-box-1 .item-data .wp-block-buttons {
  margin-top: 20px;
  gap: 1em;
}
@media only screen and (min-width: 768px) {
  .border-box-1 .item-data .wp-block-buttons {
    margin-top: 30px;
    flex-direction: column;
    align-items: flex-start;
  }
}
@media only screen and (min-width: 768px) {
  .border-box-1 .item-data .wp-block-buttons .button1 .wp-block-button__link {
    font-size: 1.125rem;
  }
}

/* ----------------------------------------------------------------
  home
---------------------------------------------------------------- */
.mv {
  margin-left: -30px;
  margin-right: -30px;
  margin-bottom: 60px;
  min-height: unset;
  background-color: #f4c636;
  overflow: hidden;
  position: relative;
}
@media only screen and (min-width: 768px) {
  .mv {
    margin-bottom: 150px;
  }
}
@media only screen and (min-width: 768px) and (min-width: 1280px) {
  .mv {
    margin-left: 0;
    margin-right: 0;
  }
}
.mv .wp-block-image {
  margin-top: 0 !important;
}
@media only screen and (min-width: 768px) {
  .mv .wp-block-image {
    margin-top: min(100px, 5vw) !important;
  }
}
@media only screen and (min-width: 768px) and (min-width: 1280px) {
  .mv .wp-block-image {
    margin-top: 0 !important;
  }
}
@media only screen and (min-width: 768px) {
  .mv .img-mobile {
    display: none;
  }
}
.mv .img-desktop {
  display: none;
}
@media only screen and (min-width: 768px) {
  .mv .img-desktop {
    display: block;
    max-width: 2400px;
    margin: 0 auto;
  }
}
.mv .img-scroll {
  width: 64px;
  position: absolute;
  left: calc(50% - 32px);
  bottom: 0;
}
@media only screen and (min-width: 768px) {
  .mv .img-scroll {
    left: 13vw;
  }
}
@media only screen and (min-width: 768px) and (min-width: 1280px) {
  .mv .img-scroll {
    width: 121px;
  }
}

/* ----------------------------------------------------------------
  SIサービス
---------------------------------------------------------------- */
.img-si-2-1 img {
  margin-inline: auto;
  width: 100%;
  max-width: 530px;
}

/* ----------------------------------------------------------------
  公共／自治体ソリューション
---------------------------------------------------------------- */
.solution1-intro {
  display: flex;
  flex-direction: column;
  background: var(--brand-lightblue, #f5f8fa);
  padding: 20px;
}
@media only screen and (min-width: 768px) {
  .solution1-intro {
    padding: 32px;
    align-items: center;
  }
}
.solution1-intro h3 {
  font-size: 1.375rem;
}
@media only screen and (min-width: 768px) {
  .solution1-intro h3 {
    font-size: 1.75rem;
    text-align: center;
  }
}
.solution1-intro .text1 {
  font-weight: 700;
  font-size: 1.125rem;
}
@media only screen and (min-width: 768px) {
  .solution1-intro .text1 {
    margin-top: -10px;
    font-size: 1.375rem;
  }
}
@media only screen and (min-width: 768px) {
  .solution1-intro .list-check_mark {
    justify-content: center;
  }
}

@media only screen and (min-width: 768px) {
  .system-list {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 32px;
  }
}

.link-list-wrapper {
  background: var(--color-gray-300, #efefef);
  padding-bottom: 20px;
}
@media only screen and (min-width: 768px) {
  .link-list-wrapper {
    margin-top: 0;
    padding-bottom: 32px;
  }
}
.link-list-wrapper h3 {
  display: flex;
  padding: 4px 10px 6px;
  justify-content: center;
  font-size: 1.25rem;
  color: #fff;
}
@media only screen and (min-width: 768px) {
  .link-list-wrapper h3 {
    font-size: 1.625rem;
  }
}
.link-list-wrapper .link-list {
  display: flex;
  flex-direction: column;
  gap: 0;
  margin: 20px 20px 0;
  padding: 10px 16px 16px;
  border-radius: 12px;
  border: 2px solid var(--color-gray-900, #313131);
  background: #fff;
}
@media only screen and (min-width: 768px) {
  .link-list-wrapper .link-list {
    margin: 32px 32px 0;
    padding: 12px 24px 24px;
  }
}
.link-list-wrapper .link-list .item-link-list {
  margin-top: 0;
  padding: 6px 2px;
  border-bottom: 1px dashed var(--color-gray-600, #bbb);
}
@media only screen and (min-width: 768px) {
  .link-list-wrapper .link-list .item-link-list {
    padding: 8px 2px;
  }
}
.link-list-wrapper .link-list .item-link-list p {
  display: flex;
  align-items: center;
  font-size: 1.125rem;
  font-weight: 700;
}
@media only screen and (min-width: 768px) {
  .link-list-wrapper .link-list .item-link-list p {
    font-size: 1.25rem;
  }
}
.link-list-wrapper .link-list .item-link-list ul {
  margin-top: 6px;
}
.link-list-wrapper .link-list .item-link-list ul li {
  margin-bottom: 4px;
}
.link-list-wrapper.list-tosyo-system h3 {
  background: #ad2e58;
}
.link-list-wrapper.naibu-joho-system h3 {
  background: #2f3da8;
}
@media only screen and (min-width: 768px) {
  .link-list-wrapper.kobetu-kyotsu-system {
    grid-column: 1/-1;
  }
  .link-list-wrapper.kobetu-kyotsu-system .link-list {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 0 44px;
  }
}
.link-list-wrapper.kobetu-kyotsu-system h3 {
  background: #30b0b0;
}

.solution2 h3:first-of-type {
  font-size: 1.375rem;
}
@media only screen and (min-width: 768px) {
  .solution2 h3:first-of-type {
    font-size: 1.75rem;
  }
}

.is-style-tosyokan {
  margin: 16px 0;
  aspect-ratio: 253/67;
  width: 100%;
  height: 50px;
  border: none;
  background-image: url(../assets/images/bg-solution-toshokan.png);
  background-size: auto 100%;
  background-position: left center;
  background-repeat: repeat-x;
}
@media only screen and (min-width: 768px) {
  .is-style-tosyokan {
    height: 67px;
  }
}

/* ----------------------------------------------------------------
  企業ソリューション
---------------------------------------------------------------- */
.intro-enterprise-solutions {
  margin-bottom: 20px;
}
@media only screen and (min-width: 768px) {
  .intro-enterprise-solutions {
    display: grid;
    grid-template-columns: 354px auto;
    gap: 30px;
  }
}
.intro-enterprise-solutions .list-check_mark {
  gap: 6px;
  padding: 16px 24px;
  border-radius: 5px;
  background-color: var(--wp--preset--color--brand-primary);
}
@media only screen and (min-width: 768px) {
  .intro-enterprise-solutions .list-check_mark {
    flex-direction: column;
    flex-wrap: nowrap;
    align-self: flex-start;
    padding: 20px 30px;
  }
}
.intro-enterprise-solutions .list-check_mark li {
  padding: 0;
  border-radius: 0;
}
@media only screen and (min-width: 768px) {
  .intro-enterprise-solutions p {
    margin-top: 0;
    font-size: 1.25rem;
  }
}

/* ----------------------------------------------------------------
  Factory One
---------------------------------------------------------------- */
.three-strong {
  padding-top: 30px;
}
@media only screen and (min-width: 768px) {
  .three-strong {
    padding-top: 50px;
  }
}
.three-strong .img-text {
  width: 96%;
  max-width: 700px;
  margin-inline: auto;
}
.three-strong .list-three-strong {
  margin-top: 20px;
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
}
@media only screen and (min-width: 768px) {
  .three-strong .list-three-strong {
    margin-top: 45px;
    grid-template-columns: repeat(auto-fill, minmax(290px, 1fr));
    gap: 25px;
  }
}
.three-strong .list-three-strong .block-check-box-item {
  margin-top: 0;
}

.block-factory-one-data {
  background-color: #e6f2fa;
}
.block-factory-one-data .is-hscroll .img-factory-one-scroll-img01 {
  width: 700px;
}
.block-factory-one-data .is-hscroll .img-factory-one-scroll-img01 img {
  width: 100%;
}
.block-factory-one-data .is-hscroll .img-factory-one-scroll-img02 {
  width: 750px;
}
.block-factory-one-data .is-hscroll .img-factory-one-scroll-img02 img {
  width: 100%;
}

@media only screen and (min-width: 768px) {
  .txt-img-factory-one-scroll-separate {
    max-width: 680px;
    margin-inline: auto;
  }
}

/* ----------------------------------------------------------------
  部品表エディタ
---------------------------------------------------------------- */
.sec-beo1 {
  gap: 0;
}
.sec-beo1 > * {
  margin-top: 0;
}

.img-block1-leading {
  margin-inline: auto;
  aspect-ratio: 343/87;
  width: 90%;
  background-image: url("../assets/images/buhin-hyo-editor-option/img-beo-block1-1-s.png");
  background-repeat: no-repeat;
  background-position: center;
  background-size: 100%;
}
@media only screen and (min-width: 768px) {
  .img-block1-leading {
    aspect-ratio: 736/103;
    background-image: url("../assets/images/buhin-hyo-editor-option/img-beo-block1-1-l.png");
    max-width: 736px;
  }
}

.buhin-hyo-editor-option-block1 {
  margin-top: 0;
}
@media only screen and (min-width: 768px) {
  .buhin-hyo-editor-option-block1 {
    padding: 50px 60px;
  }
}

.img-block1-2 {
  margin: 0 auto 20px;
  aspect-ratio: 698/314;
  width: 89.5043731778%;
  background-image: url("../assets/images/buhin-hyo-editor-option/img-beo-block1-2.png");
  background-repeat: no-repeat;
  background-position: center;
  background-size: 100%;
}
@media only screen and (min-width: 768px) {
  .img-block1-2 {
    margin-bottom: 40px;
    width: 69.8%;
    max-width: 698px;
  }
}

@media only screen and (min-width: 768px) {
  .list-check_mark--03.list-beo-block1 {
    margin-top: 40px;
  }
}
@media only screen and (min-width: 768px) and (min-width: 1025px) {
  .list-check_mark--03.list-beo-block1 {
    flex-direction: row;
    flex-wrap: nowrap;
  }
}
@media only screen and (min-width: 1025px) {
  .list-check_mark--03.list-beo-block1 li {
    font-size: 1.25rem;
  }
}
.list-check_mark--03.list-beo-block1 li::before {
  content: none;
}

.list-beo-kinou .wp-block-heading {
  font-size: 1.1875rem;
}
@media only screen and (min-width: 768px) {
  .list-beo-kinou .wp-block-heading {
    margin-top: 30px;
    font-size: 1.5625rem;
  }
}
.list-beo-kinou .wp-block-list {
  margin-top: 5px;
}
@media only screen and (min-width: 768px) {
  .list-beo-kinou .wp-block-list {
    margin-top: 12px;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 0 4em;
  }
  .list-beo-kinou .wp-block-list li {
    font-size: 1.125rem;
  }
}

.beo-block3-1 {
  position: relative;
}
@media only screen and (min-width: 768px) {
  .beo-block3-1 {
    margin-bottom: 30px;
  }
}
@media only screen and (min-width: 768px) {
  .beo-block3-1 .wp-block-image {
    margin-left: auto;
    width: min(777px, 82.66%);
  }
}
@media only screen and (min-width: 768px) and (min-width: 1025px) {
  .beo-block3-1 .wp-block-image {
    margin-inline: auto;
  }
}
@media only screen and (min-width: 768px) {
  .beo-block3-1 .list-beo-block1 {
    width: 70%;
    position: absolute;
    left: 0;
    bottom: 0;
  }
}
@media only screen and (min-width: 768px) and (min-width: 1025px) {
  .beo-block3-1 .list-beo-block1 {
    width: 56%;
  }
}
.beo-block3-1 .list-beo-block1 li {
  font-size: 1rem;
}

/* ----------------------------------------------------------------
  ＆セキュリティ+
---------------------------------------------------------------- */
.sec-asp-1 .block2 {
  padding-top: 30px;
}
@media only screen and (min-width: 768px) {
  .sec-asp-1 .block2 {
    padding-top: 60px;
  }
}
.sec-asp-1 .block2 .block-tit {
  margin-inline: auto;
  max-width: 652px;
}
.sec-asp-1 .block2 .list-okomarigoto {
  margin-top: 20px;
}
@media only screen and (min-width: 768px) {
  .sec-asp-1 .block2 .list-okomarigoto {
    margin-top: 40px;
  }
}

.block-okomarigoto-item {
  box-shadow: 0 3px 8px 0 rgba(0, 24, 39, 0.12);
  border-radius: 10px;
  background-color: #fff;
  overflow: hidden;
}
@media only screen and (min-width: 768px) {
  .block-okomarigoto-item {
    margin-top: 20px;
    border-radius: 14px;
  }
}
.block-okomarigoto-item .item-title {
  padding: 16px 18px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 8px;
  align-self: stretch;
  background-color: var(--wp--preset--color--brand-primary);
}
@media only screen and (min-width: 768px) {
  .block-okomarigoto-item .item-title {
    padding: 16px 20px;
    flex-direction: row;
    align-items: center;
    justify-content: flex-start;
    gap: 20px;
  }
}
.block-okomarigoto-item .item-title p {
  padding: 2px;
  width: 100%;
  border-radius: 999px;
  background: var(--Yellow, #fdf224);
  font-size: 0.8125rem;
  font-weight: 700;
  line-height: 1;
  color: var(--wp--preset--color--brand-primary);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
}
@media only screen and (min-width: 768px) {
  .block-okomarigoto-item .item-title p {
    padding: 5px 16px;
    width: auto;
    min-width: 160px;
    font-size: 1.125rem;
    white-space: nowrap;
  }
}
.block-okomarigoto-item .item-title p strong {
  position: relative;
  font-family: "Roboto Condensed", "Noto Sans JP", sans-serif;
  font-size: 153.8461538462%;
}
@media only screen and (min-width: 768px) {
  .block-okomarigoto-item .item-title p strong {
    margin-top: 0.05em;
    font-size: 155.5555555556%;
  }
}
.block-okomarigoto-item .item-title .wp-block-heading {
  margin-top: 0;
  font-size: 1.25rem;
  line-height: 1.5;
  color: #fff;
}
@media only screen and (min-width: 768px) {
  .block-okomarigoto-item .item-title .wp-block-heading {
    font-size: 1.5rem;
  }
}
.block-okomarigoto-item .item-text {
  margin-top: 0;
  padding: 16px 18px;
  display: flex;
  flex-direction: column;
  gap: 0;
}
@media only screen and (min-width: 768px) {
  .block-okomarigoto-item .item-text {
    padding: 20px 40px 20px 200px;
    justify-content: flex-start;
    position: relative;
  }
}
.block-okomarigoto-item .item-text:before {
  content: "";
  width: 100%;
  height: 32px;
  background-color: transparent;
  background-image: url(../assets/images/and-security-plus/asp-block1-kaiketsu-s.png);
  background-repeat: no-repeat;
  background-position: center;
  background-size: auto 100%;
}
@media only screen and (min-width: 768px) {
  .block-okomarigoto-item .item-text:before {
    width: 105px;
    height: 53px;
    background-image: url(../assets/images/and-security-plus/asp-block1-kaiketsu-l.png);
    position: absolute;
    left: 44px;
    top: 50%;
    transform: translateY(-50%);
  }
}
.block-okomarigoto-item .item-text .wp-block-heading {
  margin-top: 10px;
  font-size: 1.375rem;
  font-weight: 700;
  line-height: 1.5;
  color: #ee1c09;
  text-align: center;
}
@media only screen and (min-width: 768px) {
  .block-okomarigoto-item .item-text .wp-block-heading {
    margin-top: 0;
    font-size: 1.5rem;
    text-align: left;
  }
}
.block-okomarigoto-item .item-text p {
  margin-top: 8px;
  font-size: 1rem;
  line-height: 1.5;
}
@media only screen and (min-width: 768px) {
  .block-okomarigoto-item .item-text p {
    margin-top: 10px;
    font-size: 1.25rem;
  }
}
.block-okomarigoto-item .item-text .wp-block-list {
  margin-top: 12px;
  font-size: 0.875rem;
}
@media only screen and (min-width: 768px) {
  .block-okomarigoto-item .item-text .wp-block-list {
    margin-top: 10px;
    font-size: 1rem;
  }
}

.img-bois-scroll-img01 img,
.img-bois-scroll-img02 img {
  width: 700px !important;
}
@media only screen and (min-width: 768px) {
  .img-bois-scroll-img01 img,
.img-bois-scroll-img02 img {
    width: 100% !important;
  }
}

/* ----------------------------------------------------------------
  Boofy patriot 2
---------------------------------------------------------------- */
.block-auto-logoff {
  display: grid;
  grid-template-columns: 1fr;
  gap: 20px;
}
@media only screen and (min-width: 768px) {
  .block-auto-logoff {
    grid-template-columns: 1fr 23px 1fr;
    gap: 32px;
  }
}
.block-auto-logoff .item-data {
  margin-top: 0;
}
.block-auto-logoff .item-data figure img {
  width: 100%;
}
.block-auto-logoff .item-data p {
  margin-top: 0;
}
.block-auto-logoff .img-separate {
  margin-top: 0;
  height: 20px;
  position: relative;
}
@media only screen and (min-width: 768px) {
  .block-auto-logoff .img-separate {
    width: 23px;
    height: 100%;
  }
}
.block-auto-logoff .img-separate img {
  aspect-ratio: 23/62;
  width: 20px;
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%) rotate(90deg);
}
@media only screen and (min-width: 768px) {
  .block-auto-logoff .img-separate img {
    width: 62px;
    transform: translate(-50%, -50%) rotate(0);
  }
}

/* ----------------------------------------------------------------
  Boofy Office-AD
---------------------------------------------------------------- */
@media only screen and (min-width: 768px) {
  .page-mv-boofy-office-ad {
    display: grid;
    grid-template-columns: 1fr clamp(300px, 30.69vw, 442px);
    gap: 32px;
  }
}
@media only screen and (min-width: 768px) and (min-width: 1025px) {
  .page-mv-boofy-office-ad {
    grid-template-columns: 1fr 442px;
    gap: 40px;
  }
}
.page-mv-boofy-office-ad .item-image {
  aspect-ratio: 343/230;
  overflow: hidden;
}
@media only screen and (min-width: 768px) {
  .page-mv-boofy-office-ad .item-image {
    order: 2;
    aspect-ratio: 443/675;
  }
}
.page-mv-boofy-office-ad .item-image img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
@media only screen and (min-width: 768px) {
  .page-mv-boofy-office-ad .item-data-wrapper {
    order: 1;
    margin-top: 0;
  }
}
.page-mv-boofy-office-ad .item-data-wrapper .item-intro {
  gap: 10px;
}
@media only screen and (min-width: 768px) {
  .page-mv-boofy-office-ad .item-data-wrapper .item-intro {
    gap: 16px;
  }
}
.page-mv-boofy-office-ad .item-data-wrapper .item-intro .logo-boofy-office-ad {
  width: 140px;
}
@media only screen and (min-width: 768px) {
  .page-mv-boofy-office-ad .item-data-wrapper .item-intro .logo-boofy-office-ad {
    width: 160px;
  }
}
.page-mv-boofy-office-ad .item-data-wrapper .item-intro h3 {
  font-size: 1.25rem;
}
@media only screen and (min-width: 768px) {
  .page-mv-boofy-office-ad .item-data-wrapper .item-intro h3 {
    margin-top: -10px;
    font-size: 2rem;
  }
}
@media only screen and (min-width: 768px) {
  .page-mv-boofy-office-ad .item-data-wrapper .item-intro .item-text-intro {
    font-size: 1.125rem;
  }
}
.page-mv-boofy-office-ad .item-data-wrapper .item-data {
  padding-top: 16px;
  border-top: 1px solid var(--color-gray-400, #dfdfdf);
}
@media only screen and (min-width: 768px) {
  .page-mv-boofy-office-ad .item-data-wrapper .item-data {
    margin-top: 32px;
    padding-top: 32px;
    gap: 32px;
  }
}
.page-mv-boofy-office-ad .item-data-wrapper .item-data .is-data-block {
  width: 100%;
  gap: 10px;
}
@media only screen and (min-width: 768px) {
  .page-mv-boofy-office-ad .item-data-wrapper .item-data .is-data-block {
    gap: 16px;
  }
}
.page-mv-boofy-office-ad .item-data-wrapper .item-data .is-data-block .is-label {
  display: flex;
  padding: 4px 8px 6px;
  justify-content: center;
  align-items: center;
  gap: 10px;
  background: var(--brand-primary, #0062a7);
  font-size: 0.9375rem;
  color: #fff;
  line-height: 1;
}
@media only screen and (min-width: 768px) {
  .page-mv-boofy-office-ad .item-data-wrapper .item-data .is-data-block .is-label {
    padding: 6px 12px 8px;
    font-size: 1.125rem;
  }
}
.page-mv-boofy-office-ad .item-data-wrapper .item-data .is-data-block .is-data-num-blocks {
  margin-top: -10px;
  display: flex;
  flex-direction: column;
  width: 100%;
}
@media only screen and (min-width: 1025px) {
  .page-mv-boofy-office-ad .item-data-wrapper .item-data .is-data-block .is-data-num-blocks {
    margin-top: 0;
    flex-direction: row;
    gap: var(--space-700, 40px);
  }
}
.page-mv-boofy-office-ad .item-data-wrapper .item-data .is-data-block .is-data-num-blocks .is-data-num {
  margin-left: auto;
}
@media only screen and (min-width: 1025px) {
  .page-mv-boofy-office-ad .item-data-wrapper .item-data .is-data-block .is-data-num-blocks .is-data-num {
    margin-top: 0;
    margin-left: 0;
  }
}
.page-mv-boofy-office-ad .item-data-wrapper .item-data .is-data-block .is-data-num-blocks .is-data-num .is-data-num__label {
  font-weight: 700;
  line-height: 1;
}
@media only screen and (min-width: 768px) {
  .page-mv-boofy-office-ad .item-data-wrapper .item-data .is-data-block .is-data-num-blocks .is-data-num .is-data-num__label {
    font-size: 1.125rem;
    white-space: nowrap;
  }
}
.page-mv-boofy-office-ad .item-data-wrapper .item-data .is-data-block .is-data-num-blocks .is-data-num .is-data-num__num {
  color: var(--link-link, #ee8828);
  font-size: 40px;
  font-weight: 700;
  line-height: 1;
  letter-spacing: -0.8px;
}
@media only screen and (min-width: 768px) {
  .page-mv-boofy-office-ad .item-data-wrapper .item-data .is-data-block .is-data-num-blocks .is-data-num .is-data-num__num {
    font-size: 3.625rem;
  }
}

.block-option {
  border: 1px solid var(--brand-primary, #0062a7);
  padding: 20px;
  gap: 16px;
}
@media only screen and (min-width: 768px) {
  .block-option {
    margin-bottom: -12px;
    padding: 16px 40px;
    display: grid;
    grid-template-columns: 250px 1fr;
    gap: 40px;
  }
}
.block-option .item-title {
  font-size: 1.125rem;
  font-weight: 700;
  line-height: 1;
  color: var(--wp--preset--color--brand-primary);
  gap: 12px;
}
@media only screen and (min-width: 768px) {
  .block-option .item-title {
    font-size: 1.5rem;
  }
}
@media only screen and (min-width: 768px) {
  .block-option .wp-block-list {
    margin-top: 0;
  }
}

/* ----------------------------------------------------------------
  お問い合わせ
---------------------------------------------------------------- */
.single-main {
  /* ----------------------------------------------------------------
    このページ
  ---------------------------------------------------------------- */
}
.single-main .entry-content + .wp-block-buttons {
  margin-top: 60px;
}
@media only screen and (min-width: 768px) {
  .single-main .entry-content + .wp-block-buttons {
    margin-top: 200px;
  }
}

/* 横スク土台（Groupに is-hscroll を付ける） */
.is-hscroll {
  position: relative;
  /* ← ヒントの重なり安定用 */
  display: flex;
  flex-wrap: nowrap;
  gap: 1rem;
  overflow-x: auto;
  -ms-scroll-snap-type: x mandatory;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
}
@media only screen and (min-width: 768px) {
  .is-hscroll {
    overflow-x: hidden;
  }
}

/* スナップ */
.is-hscroll > * {
  flex: 0 0 auto;
  scroll-snap-align: start;
}

/* 画像を縮ませない＆溢れさせる */
.is-hscroll .wp-block-image {
  min-width: 120vw;
}
@media only screen and (min-width: 768px) {
  .is-hscroll .wp-block-image {
    min-width: unset !important;
    max-width: 100% !important;
    width: 100% !important;
    overflow: hidden;
  }
}

.is-hscroll .wp-block-image img {
  max-width: none;
  width: auto;
  height: auto;
  display: block;
}
@media only screen and (min-width: 768px) {
  .is-hscroll .wp-block-image img {
    max-width: 100%;
    width: 100%;
    height: auto;
  }
}

/* 右端フェード（溢れてる時だけ） */
.is-hscroll.is-scrollable::before {
  content: "";
  position: -webkit-sticky;
  position: sticky;
  right: 0;
  align-self: stretch;
  width: 48px;
  pointer-events: none;
  background: linear-gradient(to right, transparent, rgba(0, 0, 0, 0.12));
  z-index: 1;
}

/* スマホだけヒント表示 */
@media (max-width: 767px) {
  .is-hscroll.is-scrollable:not(.has-scrolled)::after {
    content: "";
    aspect-ratio: 180/110;
    width: 55%;
    position: absolute;
    left: calc(50% + 16px);
    top: 50%;
    transform: translate(-50%, -50%);
    border-radius: 10px;
    background-color: rgba(0, 0, 0, 0.66);
    background-image: url("../assets/images/common/icon-scrollable.png");
    background-size: 75%;
    background-repeat: no-repeat;
    background-position: center center;
    z-index: 2;
    pointer-events: none;
    white-space: nowrap;
  }
}
/* -----------------------------------------
// リセット
// ---------------------------------------*/
input[type=text],
input[type=password],
textarea,
select {
  outline: none;
}

input[type=text]::-ms-clear,
input[type=password]::-ms-reveal {
  display: none;
}

input[type=button],
input[type=text],
input[type=email],
input[type=url],
input[type=tel],
input[type=submit],
textarea {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  border-radius: 0;
}

:placeholder-shown {
  color: #aaa !important;
  font-weight: inherit !important;
}

/* Google Chrome, Safari, Opera 15+, Android, iOS */
::-webkit-input-placeholder {
  color: #aaa !important;
  font-weight: inherit !important;
}

/* Firefox 18- */
:-moz-placeholder {
  color: #aaa !important;
  font-weight: inherit !important;
  opacity: 1;
}

/* Firefox 19+ */
::-moz-placeholder {
  color: #aaa !important;
  font-weight: inherit !important;
  opacity: 1;
}

/* -----------------------------------------
// 基本設定
// ---------------------------------------*/
form {
  padding: 0;
  margin: 0;
}

input:is([type=submit],
[type=back],
[type=email],
[type=number],
[type=password],
[type=search],
[type=tel],
[type=text],
[type=url],
[type=date]),
select,
textarea {
  display: block;
  box-sizing: border-box;
  width: 100%;
  max-width: 100%;
  padding: 0.6em 1em;
  background-color: #f1f1f1;
  border: 1px solid #f1f1f1;
  border-radius: 4px;
}
input:is([type=submit],
[type=back],
[type=email],
[type=number],
[type=password],
[type=search],
[type=tel],
[type=text],
[type=url],
[type=date]):focus,
select:focus,
textarea:focus {
  outline: none;
  background-color: #f2f7ff;
}

textarea {
  height: 10em;
}
@media only screen and (min-width: 768px) {
  textarea {
    height: 12em;
  }
}

/* -----------------------------------------
// ここから
// ---------------------------------------*/
.form-contents {
  margin-top: 60px;
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
}
.form-contents * {
  font-size: 1rem;
  line-height: 1.5;
}
.form-contents .form-item {
  padding: 0;
  display: grid;
  grid-template-columns: 1fr;
  gap: 8px;
  position: relative;
}
@media only screen and (min-width: 768px) {
  .form-contents .form-item {
    grid-template-columns: 242px 1fr;
    gap: 30px;
    align-items: stretch;
  }
}
.form-contents .item-label {
  font-size: 0.9375rem;
  font-weight: 700;
  position: relative;
}
@media only screen and (min-width: 768px) {
  .form-contents .item-label {
    margin-top: 10px;
  }
}
.form-contents .item-label label {
  display: flex;
  align-items: center;
  gap: 8px;
}
.form-contents .item-label label .req,
.form-contents .item-label label .opt {
  padding: 1px 5px 3px;
  border-radius: 3px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 70%;
  font-weight: 700;
}
.form-contents .item-label label .req {
  background-color: #ee1c09;
  color: #fff;
}
.form-contents .item-label label .opt {
  color: var(--wp--preset--color--site-text);
}
.form-contents .item-label .notes {
  margin-top: 8px;
  display: block;
  font-size: 0.75rem;
  font-weight: 400;
  line-height: 1.75;
}
.form-contents .item-input:has(.input-block) {
  display: flex;
  flex-direction: column;
  gap: 15px;
}
@media only screen and (min-width: 768px) {
  .form-contents .item-input:has(.input-block) {
    flex-direction: row;
    gap: 40px;
  }
}
.form-contents .item-input .notes {
  margin-top: 8px;
  display: block;
  font-size: 0.6875rem;
  font-weight: 400;
  line-height: 1.6;
}
@media only screen and (min-width: 768px) {
  .form-contents .item-input .notes {
    margin-top: 10px;
  }
}
.form-contents .item-input.item-tel {
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
}
.form-contents .item-input.item-tel .input-block {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  gap: 10px;
}
.form-contents .item-input.item-tel .input-block:not(:last-of-type)::after {
  content: "-";
}
@media only screen and (min-width: 768px) {
  .form-contents .xxshort {
    width: 163px;
  }
  .form-contents .xshort {
    width: 180px;
  }
  .form-contents .short {
    width: 256px;
  }
  .form-contents .middle {
    width: 50%;
  }
  .form-contents .long {
    width: 80%;
  }
  .form-contents .max {
    width: 100%;
  }
}
.form-contents .wpcf7-radio,
.form-contents .wpcf7-checkbox {
  margin-top: 5px;
  display: flex;
  flex-direction: column;
  gap: 1em;
}
.form-contents .wpcf7-radio .wpcf7-list-item,
.form-contents .wpcf7-checkbox .wpcf7-list-item {
  margin: 0;
}
@media only screen and (min-width: 768px) {
  .form-contents .wpcf7-radio .wpcf7-list-item,
.form-contents .wpcf7-checkbox .wpcf7-list-item {
    flex-basis: calc(50% - 20px);
  }
}
.form-contents .wpcf7-radio .wpcf7-list-item label,
.form-contents .wpcf7-checkbox .wpcf7-list-item label {
  cursor: pointer;
}
.form-contents .wpcf7-radio .wpcf7-list-item label input,
.form-contents .wpcf7-checkbox .wpcf7-list-item label input {
  display: none;
}
.form-contents .wpcf7-radio .wpcf7-list-item label .wpcf7-list-item-label,
.form-contents .wpcf7-checkbox .wpcf7-list-item label .wpcf7-list-item-label {
  display: flex;
  align-items: flex-start;
  padding-left: 26px;
  line-height: 2;
  position: relative;
}
.form-contents .wpcf7-radio .wpcf7-list-item label .wpcf7-list-item-label::before,
.form-contents .wpcf7-checkbox .wpcf7-list-item label .wpcf7-list-item-label::before {
  content: "";
  width: 15px;
  height: 15px;
  background-color: #fff;
  border: 1px solid #cccccc;
  border-radius: 4px;
  position: absolute;
  top: 0.5em;
  left: 0;
}
.form-contents .wpcf7-radio .wpcf7-list-item label .wpcf7-list-item-label::before {
  border-radius: 50%;
}
.form-contents .wpcf7-radio .wpcf7-list-item label input:checked + .wpcf7-list-item-label::after {
  content: "";
  width: 9px;
  height: 9px;
  background-color: var(--wp--preset--color--brand-brightblue);
  border-radius: 50%;
  position: absolute;
  top: calc(0.5em + 3px);
  left: 3px;
}
.form-contents .wpcf7-checkbox .wpcf7-list-item label input:checked + .wpcf7-list-item-label::before {
  background-color: #ee1c09;
  border-color: #ee1c09;
}
.form-contents .wpcf7-checkbox .wpcf7-list-item label input:checked + .wpcf7-list-item-label::after {
  content: "";
  width: 20px;
  height: 20px;
  background-color: #fff;
  -webkit-mask-image: url(./assets/images/common/icon-checkmark.png);
  mask-image: url(./assets/images/common/icon-checkmark.png);
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-position: center;
  mask-position: center;
  -webkit-mask-size: 13px 10px;
  mask-size: 13px 10px;
  position: absolute;
  left: 0;
  top: 6px;
}
.form-contents .wpcf7-checkbox.wpcf7-exclusive-checkbox .wpcf7-list-item label .wpcf7-list-item-label::before {
  border-radius: 50%;
}
.form-contents .wpcf7-checkbox.wpcf7-exclusive-checkbox .wpcf7-list-item label input:checked + .wpcf7-list-item-label::before {
  background-color: #fff;
  border-color: var(--wp--preset--color--brand-brightblue);
}
.form-contents .wpcf7-checkbox.wpcf7-exclusive-checkbox .wpcf7-list-item label input:checked + .wpcf7-list-item-label::after {
  width: 9px;
  height: 9px;
  background-color: var(--wp--preset--color--brand-brightblue);
  -webkit-mask-image: none;
  mask-image: none;
  border-radius: 50%;
  position: absolute;
  top: calc(0.5em + 3px);
  left: 3px;
}
.form-contents select {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  position: relative;
}
.form-contents select-ms-expand {
  display: none;
}
.form-contents .custom-select {
  position: relative;
  z-index: 1;
}
@media only screen and (min-width: 768px) {
  .form-contents .custom-select {
    max-width: -webkit-max-content;
    max-width: -moz-max-content;
    max-width: max-content;
  }
}
.form-contents .custom-select select {
  padding: 0.4em 45px 0.4em 0.8em;
  padding-right: 45px;
  border: 1px solid #000;
  background-color: #fff;
}
.form-contents .custom-select::before {
  content: "";
  width: 45px;
  height: 39px;
  background-image: url(../assets/images/common/icon-arrow-selectbox.png);
  background-repeat: no-repeat;
  background-position: right 16px center;
  background-size: 14px;
  position: absolute;
  right: 0;
  top: 0;
  z-index: 1;
  pointer-events: none;
  cursor: pointer;
}
.form-contents .checked-open-item {
  display: none;
  margin: 15px 0 0 35px;
}

.agree-area {
  margin-top: 40px;
}
.agree-area .item-input {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 10px;
}
.agree-area .item-input .wpcf7-list-item {
  margin-left: 0;
}
.agree-area .wpcf7-not-valid-tip {
  width: 200px;
  position: absolute;
}

.form-btn-wrap {
  margin-top: 30px;
  display: flex;
  justify-content: center;
}
@media only screen and (min-width: 768px) {
  .form-btn-wrap {
    gap: 40px;
  }
}
.form-btn-wrap .button-from {
  cursor: pointer;
  padding: 0.625rem 1.25rem;
  width: auto;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.5rem;
  background-color: var(--wp--preset--color--brand-attention);
  border-radius: 4px;
  font-size: 1rem;
  font-weight: 700;
  line-height: 1.3;
  color: #fff;
  position: relative;
  transition: all 0.15s;
}
.form-btn-wrap .button-from:hover {
  opacity: 0.8;
}

.wpcf7-response-output {
  margin: 30px 0 0 !important;
  padding: 0.5em 1em !important;
  text-align: center !important;
}
@media only screen and (min-width: 768px) {
  .wpcf7-response-output {
    margin-top: 40px !important;
  }
}

.wpcf7-spinner {
  position: absolute;
  bottom: -30px;
}

.google-recaptcha {
  font-size: 1rem;
  color: #777;
  text-align: center;
}

.grecaptcha-badge {
  visibility: hidden;
}

@media only screen and (min-width: 768px) {
  .contact-confirm .item {
    padding: 30px min(2.2vw, 30px) 32px;
  }
}
@media only screen and (min-width: 768px) {
  .contact-confirm .item__label:not(.align-top) {
    margin-top: 0;
  }
}
.contact-confirm .button-wrapper {
  margin-top: 60px !important;
}

/* ------------------------------------
//  Breadcrumb NavXT 設定
// ----------------------------------*/
.breadcrumbs {
  padding: 6px 6px 8px;
  background-color: var(--wp--preset--color--brand-primary);
  font-size: 0.75rem;
  line-height: 1;
  color: #fff;
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  gap: 4px;
  overflow: hidden;
}
@media only screen and (min-width: 768px) {
  .breadcrumbs {
    padding: 10px 8.3333% 12px;
    font-size: 0.875rem;
    gap: 8px;
  }
}
.breadcrumbs span {
  white-space: nowrap;
}
.breadcrumbs span a:link, .breadcrumbs span a:visited {
  color: #fff;
  text-decoration: none;
}
.breadcrumbs span a:hover, .breadcrumbs span a:active {
  opacity: 1;
}
.breadcrumbs span.separator {
  font-size: 0.625rem;
}