@charset "utf-8";
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100;400;700&family=Roboto:wght@100;400;700&family=M+PLUS+Rounded+1c:wght@100;400;700&display=swap");

/**
 * ++++++++++++++++++++ ---------- ++++++++++++++++++++ ---------- *
**/
html {
  font-size: 3.125vw; /* 10px見当 */
}
@media screen and (min-width: 374px) {
  html {
    font-size: 2.673796791vw;
  }
}
@media screen and (min-width: 576px) {
  html {
    font-size: 1.736111111vw;
  }
}
@media screen and (min-width: 768px) {
  html {
    font-size: 1.3020833333vw;
  }
}
@media screen and (min-width: 992px) {
  html {
    font-size: 1.008064576vw;
  }
  a[href^="tel:"] {
    pointer-events: none;
  }
}
@media screen and (min-width: 1200px) {
  html {
    font-size: 10px;
  }
}
body {
  background-color: #fff;
  color: var(--text-color);
  font-family: "Roboto", "Noto Sans JP", sans-serif;
  font-weight: normal;
  font-weight: 400;
  word-wrap: break-word;
  overflow-wrap: break-word;
  position: relative;
}
.container {
  background-color: #fff;
  font-size: 1.2em;
  line-height: 1.77;
  /* max-width: var(--content-max-width); */
  width: 100%;
  min-width: 1%;
  max-height: 100%;
  margin: 0 auto;
  position: relative;
  z-index: 1;
  overflow: hidden;
}
@media screen and (min-width: 374px) {
}
@media screen and (min-width: 576px) {
  .container {
    font-size: 1.4em;
  }
}
@media screen and (min-width: 768px) {
  .container {
    font-size: 1.5em;
  }
}
@media screen and (min-width: 992px) {
  .container {
    font-size: 1.6em;
  }
}
@media screen and (min-width: 1024px) {
}
.container-inner {
  display: flex;
  flex-direction: column;
  width: 100%;
  min-height: 100vh;
  position: relative;
  overflow: hidden;
}
h1,
h2,
h3,
h4,
h5,
h6 {
  font-size: 1em;
  font-style: normal;
  font-weight: bold;
  font-weight: 700;
  line-height: 1.33;
  margin: 0;
  padding: 0;

  margin-block-start: 0;
  margin-block-end: 0;
}
header,
main,
footer,
nav {
  width: 100%;
  min-width: 1%;
  margin: 0 auto;
  z-index: 1;
}
footer {
  margin-top: auto;
}
main,
footer .site-footer,
.breadcrumb {
  width: 100%;
  max-width: var(--content-max-width);
  margin: 0 auto;
}
ul.list {
  padding: 0 0 0 2em;
}
ul.list > li {
  line-height: 1.5;
  margin: 0 0 .17em;
  padding: 0;
}
em {
  color: #575757;
  font-size: 1em;
  font-style: normal;
  font-weight: bold;
  font-weight: 700;
}
strong {
  color: var(--blue-dark-contents);
  font-size: 1em;
  font-style: normal;
  font-weight: bold;
  font-weight: 700;
}
.fz-large {
  font-size: 1.07em;
}
.fz-larger {
  font-size: 1.13em;
}
.fz-small {
  font-size: .87em;
}
.fz-smaller {
  font-size: .83em;
}
[class$="-note"],
[class*="-note "] {
  font-size: .93em;
}
label {
  display: block;
}
input[type="text"],
input[type="password"],
input[type="date"],
input[type="datetime"],
input[type="email"],
input[type="number"],
input[type="search"],
input[type="tel"],
input[type="time"],
input[type="url"],
input[type="submit"],
input[type="reset"],
textarea,
select,
button {
  background-color: var(--gray-light-xx);
  border: transparent 2px solid;
  border-radius: 4px;
  /* font-size: 1.1em; */
  font-size: 1.33334em; /* 16px */
  width: 100%;
  padding: .4em .5em;
}
@media screen and (min-width: 576px) {
  input[type="text"],
  input[type="password"],
  input[type="date"],
  input[type="datetime"],
  input[type="email"],
  input[type="number"],
  input[type="search"],
  input[type="tel"],
  input[type="time"],
  input[type="url"],
  input[type="submit"],
  input[type="reset"],
  textarea,
  select,
  button {
    font-size: 1.1em;
    padding: .6em .5em;
  }
}
input[type="submit"] {
  background-color: var(--pink-light-contents);
  color: #fff;
  letter-spacing: .06em;
  transition: color .23s ease, background-color .3s ease;
}
input[type="submit"].is-inactive {
  background-color: var(--gray-light-xx);
  color: rgba(69, 69, 69, .4);
  transition: color .23s ease, background-color .3s ease;
}
a,
button,
input,
label,
textarea {
  cursor: pointer;
}
input.is-inactive {
  cursor: not-allowed;
}
/* nav */
nav li {
  position: relative;
}
nav li::before {
  position: absolute;
}
ul.style-none,
ol.style-none,
ul.cell,
ol.cell,
ul.check-list,
ul.contact,
ul.field,
ul.symbol-list,
ol.symbol-list,
ul.item,
ul.menu,
ul.nav,
ul.submenu {
  list-style-type: none;
  margin: 0;
  padding: 0;
}
ul.style-none > li,
ol.style-none > li,
ul.cell > li,
ol.cell > li,
ul.check-list > li,
ul.contact > li,
ul.field > li,
ul.symbol-list > li,
ol.symbol-list > li,
ul.item > li,
ul.menu > li,
ul.nav > li,
ul.submenu > li {
  margin: 0;
  padding: 0;
}
ul > li > p,
ol > li > p {
  margin: 0;
}
ul {
  margin: 0;
}
ol {
  padding-inline-start: 0;
}
th {
  font-weight: inherit;
}
dd {
  margin-inline-start: 0;
}
table {
  border-spacing: 0;
}
img {
  width: 100%;
  height: auto;
  min-height: 1%;
}
figure {
  margin: 0;
}
a {
  color: var(--text-color);
  text-decoration: none;
}
a:hover,
a.hover {
  text-decoration: none;
}
.link-text {
  position: relative;
}
.link-text::after {
  background-color: var(--text-color);
  content: "";
  display: block;
  width: 0;
  height: 1px;
  position: absolute;
  bottom: -.1em;
  left: 0;
  transition: width .23s ease;
}
.link-text.yellow::after {
  background-color: var(--yellow);
  height: .375em;
  bottom: 26%;
  z-index: -1;
}
.link-text:hover::after {
  width: 99%;
}
.link-text.link_underline::after {
  width: 99%;
}
.link-text.link_underline:hover::after {
  animation: link_underline .23s ease 0s ;
}
@keyframes link_underline {
  0% {
    width: 0;
  }
  50% {
    width: 20%;
  }
  100% {
    width: 99%;
  }
}
a:hover .label,
a .label,
a:hover .label-inner,
a .label-inner {
  text-decoration: none;
}
footer .link-text::after {
  background-color: #fff;
}
.link-inner {
  width: 100%;
}
.header-inner,
.main-inner,
.footer-inner {
  min-height: 1%;
  padding: 0 1em;
  position: relative;
}
.header {
  margin: 1em 0;
}
p {
  margin: 0;
}
.greeting-page p.text-text,
.profile-page p.text-text {
  margin: 1em 0;
}
.tagline p {
  margin: 0;
}
.article {
  margin: 7em auto;
}
.article:first-of-type,
.article.entry-card:first-of-type {
  margin: 4em auto;
}
.article-heading,
.heading-inner,
.item-heading,
.item-subtitle-ele,
.item-heading-ele,
ul.item-list-type > li > span:first-of-type {
  position: relative;
}
.item-heading-ele {
  font-weight: normal;
}
ul.item.item-list-type > li {
  padding-left: 1.5em;
}
.item-list-type > li > span:first-of-type:before {
  background-color: #000;
  border-radius: 50%;
  content: "";
  width: .375em;
  height: .375em;
  position: absolute;
  top: 38%;
  left: -1em;
}
.home .item-subtitle-ele {
  font-size: 1.3em;
  text-align: center;
  display: block;
}
body:not(.single) .article-heading > .heading-inner {
  font-size: 1.6em;
  text-align: center;
  display: inline-block;
  margin-bottom: 1.5em;
  position: relative;
  z-index: 1;
}
article .article-heading {
  text-align: center;
}
article .heading-inner::before,
article .heading-inner::after,
article .article-heading::before,
article .article-heading::after,
.souzoku-page .page-heading.blue::before,
.souzoku-page .page-heading.blue::after,
.yellow-triangle::before,
.yellow-triangle::after {
  content: "";
  position: absolute;
}
/* 共通の装飾など */
body:not(.single) .article-heading > .heading-inner::before {
  background-color: var(--yellow);
  width: 112%;
  height: 42%;
  bottom: -.2em;
  left: -6%;
  z-index: -1;
}
.article-heading > .heading-inner.heading-icon::after,
body:not(.single) .article-heading::before {
  background-image: url(../img/icon/logo.svg);
  background-repeat: no-repeat;
  background-size: 100%;
  width: 1.6em;
  height: 1.6em;
  top: -2.5em;
  left: calc(50% - .8em);
  z-index: 0;
}
.heading-underline::before,
.heading-underline::after {
  background-color: var(--yellow);
  content: "";
  width: 115%;
  height: .2em;
  position: absolute;
  bottom: -.3em;
  left: -1.5em;
}
.heading-underline::after {
  background-color: var(--blue-dark-contents);
  width: 55%;
}
body:not(.single) .article.profile-page .article-heading::before,
.article.profile-page .page-contents .text-box .heading-inner::before {
  display: none;
}
.article-heading > .heading-inner.heading-icon::after {
  top: -.2em;
  left: -2em;
}
/* others */
.text-center {
  text-align: center;
  display: block;
  margin: 0 auto 1.5em;
}
.text-inline {
  display: inline-block;
}
.text-block,
span.text-block {
  display: block;
}
.text-small {
  font-size: .9em;
  line-height: 1.3;
}
.text-bold {
  font-weight: bold;
}
.text-underline {
  text-decoration: underline;

  text-underline-offset: .25em;
}
.text-underline.wavy {
  text-decoration: underline wavy;
  text-decoration-style: wavy;
}
.text-vertical {
  line-height: 1.1;
  text-align: center;
  width: 2.9em; /* 1文字＋padding左右0.75em */
  position: relative;
}
.text-red {
  color: var(--darkorange-dark-xx);
}
.text-orange {
  color: var(--orange);
}
.text-yellow {
  color: var(--yellow);
}
.text-blue {
  color: var(--blue-dark-xx);
}
.text-bluedark {
  color: var(--blue-dark-contents);
}
.text-green {
  color: var(--green-contents);
}
.text-red-span {
  background-color: var(--darkorange-dark-xx);
  border-radius: .2em;
  color: #fff;
  padding: .4em .5em;
}
.letter-one-space {
  padding-left: 1em;
}
.symbol-space {
  padding: 0 .2em;
}
.quotation-space {
  padding: 0 .1em 0 .2em;
}
.quotation-open {
  margin-left: -.5em;
  padding-right: .1em;
}
.quotation-close {
  margin-right: -.5em;
  padding-left: .1em;
}
.annotation-space {
  padding-right: .3em;
}
.yellow-point {
  display: block;
  position: relative;
}
.yellow-point::before {
  background-color: var(--yellow);
  border-radius: 50%;
  content: "";
  width: .7em;
  height: .7em;
  position: absolute;
  top: .5em;
  left: 0;
}
.contact-inner,
.item {
  display: flex;
  flex-flow: column;
  justify-content: space-between;
}
.text-box-outline,
.text-box-nooutline {
  border: var(--text-color) .8px solid;
  border-radius: .3em;
  position: relative;
}
.text-box-outline.orange {
  border: var(--orange) 2px solid;
}
.text-box-outline.green {
  border: var(--green-contents) 2px solid;
}
.text-box-outline.blue {
  border: var(--blue-dark-contents) 1px solid;
}
.text-box-nooutline {
  background-color: var(--yellow-light-xxx);
  border: none;
}
.text-box-nooutline.green {
  background-color: var(--green-contents-light-x);
}
.text-text.green > span.item-annotation {
  background-color: var(--green-contents);
}
.text-text.blue > span.item-annotation {
  background-color: var(--blue);
}
.text-box-nooutline.orange {
  background-color: var(--orange-light);
}
.text-box-nooutline.blue {
  background-color: var(--blue-dark-contents);
  color: #fff;
}
.display_pc {
  display: none;
}
.display_sp {
  display: inherit;
}
@media screen and (min-width: 576px) {
  .display_pc {
    display: inherit;
  }
  .display_sp {
    display: none !important;
  }
}
@media screen and (min-width: 768px) {
  .article {
    margin: 9em auto;
  }
  body:not(.single) .article-heading > .heading-inner {
    margin-bottom: 2.5em;
  }
  .home .article:first-of-type {
    margin: 9em auto;
  }
  body:not(.home) .article:first-of-type {
    margin: 2em auto 4em;
  }
  body.tag .main-inner > .article:first-of-type {
    margin-top: 4em;
  }
  .site-header .header-inner,
  .contact-inner,
  .item {
    flex-flow: inherit;
  }
  #news .item {
    flex-flow: column;
  }
}
@media screen and (min-width: 1024px) {
}
.item.row {
  flex-flow: row;
}
.item.column {
  flex-flow: column;
}
.yellow-line,
.yellow-line > span,
.yellow-line > strong,
.article-contents {
  position: relative;
  z-index: 1;
  overflow: hidden;
}
.yellow-line::before {
  background-color: var(--yellow);
  content: "";
  width: 102%;
  height: 70%;
  position: absolute;
  bottom: .2em;
  left: -1%;
  z-index: -1;
}
.article-contents::before,
.article-contents::after {
  content: "";
  width: 100%;
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: -1;
}
.article-contents.no-contents::before,
.article-contents.no-contents::after,
#blog .article-contents.no-contents::before,
#blog .article-contents.no-contents::after {
  border: none;
  width: 0;
}
.item li.item-inner {
  margin: 0 0 2em;
  position: relative;
}
.home .date-and-label.text-block,
.link-block {
  display: flex;
  margin: 1em 0;
}
.date-and-label {
  margin: 1em 0;
}
.date-and-label.text-block .text-inner {
  background-color: #fff;
  justify-content: flex-start;
}
.label,
.label-inner,
.label-inner .date,
.label-inner .date span {
  margin: auto 0 ;
  vertical-align: middle;
}
.label > .label-inner > a,
.label > .label-inner > span {
  color: #fff;
  display: block;
  padding: .1em 1em;
}
.label > .label-inner {
  background-color: var(--black-light-x);
  border-radius: 5px;
  color: #fff;
  font-size: .9em;
}
.label.media > .label-inner {
  background-color: var(--blue-dark);
}
.label.site-news > .label-inner,
.label.city-news > .label-inner,
.label.greeting > .label-inner,
.label.yuigon > .label-inner,
.label.souzoku-touki > .label-inner {
  background-color: var(--darkorange-dark);
}
.label.free-consultation > .label-inner {
  background-color: var(--blue-dark-contents);
}
.label.partner > .label-inner {
  background-color: var(--blue-dark-xxx);
}
.label.service-ninchi > .label-inner,
.label.service-yuigon > .label-inner {
  background-color: var(--green-contents);
}
.read-more > .read-more-inner {
  font-size: 1em;
  font-weight: 600;
  text-align: center;
  margin: 0 auto;
}
.read-more-btn a {
  border: var(--text-color) 1.5px solid;
  border-radius: 4px;
  display: inline-block;
  padding: .4em .8em;
  transition: background-color .3s ease;
}
.read-more-btn a:hover {
  background-color: var(--yellow-light);
  text-decoration: none;
  transition: background-color .3s ease;
}
/* ==============
  body
=============== */
/* header */
header .item li.item-inner {
  line-height: 1.2;
  justify-content: flex-end;
  width: 100%;
  margin: auto;
}
.site-header .heading-inner a .site-img,
.header .tel a > span,
.line a > span {
  display: block;
  width: 3.5em;
  min-width: 42px;
  height: auto;
}
header .item-inner.small-phpne {
  font-size: 1em;
}
.site-header .header-inner {
  display: flex;
  flex-flow: wrap;
  padding: 0;
}
.site-header .heading-inner a .site-img {
  width: 2.8em;
  min-width: 1%;
  margin: auto .5em auto 0;
}
.site-heading {
  line-height: 1.77;
  margin: 0 0 1em;
}
.header-inner .contact-heading,
.header-inner .item-inner {
  margin: auto 0;
}
header .heading-inner {
  font-size: .75em;
}
.site-contact .contact-body {
  margin: auto 0;
}
.site-contact {
  width: 100%;
  position: relative;
}
.site-contact-inner {
  display: flex;
  justify-content: space-between;
  padding: .5em 0 1em;
}
.site-contact-inner .contact-body:first-of-type > .text-block {
  background-color: var(--blue-dark-contents);
  line-height: 1.2;
  text-align: center;
  min-width: 7em;
  padding: .5em;
}
.site-contact-inner .contact-body:first-of-type > .text-block a {
  color: #fff;
}
.site-contact-inner .contact-text a > span,
.site-contact-inner .phone-text,
.site-contact-inner .small-phone-text {
  font-size: 1em;
}
.site-contact-inner .small-phone-text {
  margin: 0 0 auto 0;
}
.site-heading .heading-inner .site-text,
.footer-heading .heading-inner .site-text {
  font-size: 1.4em;
  line-height: 1.3;
  margin: auto 0;
}
.site-heading .heading-link {
  display: flex;
}
header .site-contact-inner .heading-inner {
  font-size: .8em;
}
.site-contact-heading {
  margin: auto 1em auto 0;
}
header .contact-body .tel,
header .contact-body .line,
.line {
  margin: auto 1.5em;
}
header .phone-text {
  letter-spacing: .01em;
  min-width: 9em;
}
@media screen and (min-width: 576px) {
  .site-header .heading-inner a .site-img,
  .header .tel a > span,
  .line a > span {
    width: 3em;
    min-width: 42px;
  }
  .site-contact-inner .contact-body:first-of-type > .text-block {
    min-width: 6em;
  }
  .site-contact-inner .contact-text a > span,
  .site-contact-inner .small-phone-text {
    font-size: .857em;
  }
  .site-contact-inner .phone-text + .small-phone-text {
    min-width: 10.5em;
  }
  .date-and-label {
    margin: 0 0 1em 0;
  }
  header .contact-body .item-inner.tel {
    margin: auto 1.5em;
  }
}
@media screen and (min-width: 768px) {
  .site-contact {
    width: auto;
  }
  .site-header .heading-inner a .site-img,
  .header .tel a > span,
  .line a > span {
    width: 2.5em;
    min-width: 36px;
  }
  .site-contact-inner {
    padding: 0;
  }
  .site-contact-inner .contact-text a > span,
  .site-contact-inner .small-phone-text {
    font-size: .8em;
  }
  .site-contact-inner .contact-body:first-of-type {
    margin: auto 0 auto auto;
  }
  .site-heading {
    width: 30%;
    margin: auto 0;
  }
  header .site-contact {
    width: 70%;
    margin: auto 0;
  }
  header .contact-body .item-inner.tel {
    margin: auto 1.375em ;
  }
}
@media screen and (min-width: 992px) {
  .site-header .header-inner {
    padding: 0 1em;
  }
  .site-contact-inner {
    justify-content: flex-end;
  }
  .site-header .heading-inner a .site-img,
  .header .tel a > span,
  .line a > span {
    width: 2em;
    min-width: 40px;
  }
  .site-contact-inner .phone-text {
    font-size: 1.2em;
  }
  .site-contact-inner .contact-text a > span,
  .site-contact-inner .small-phone-text {
    font-size: 1em;
  }
  .site-contact-inner .contact-body:first-of-type > .text-block {
    min-width: 7em;
  }
}
/* visual */
.visual ul {
  list-style-type: none;

  padding-inline-start: 0;
  margin-block-start: 0;
  margin-block-end: 0;
}
/* ------slide------ */
.home .visual .block-inner {
  height: 25em;
}
.visual .slide {
  display: block;
  position: relative;
}
.visual .slide {
  opacity: 0;
}
.visual .slide.slick-initialized {
  opacity: 1;
}
.visual .img-img,
.visual .slide-inner {
  width: 100%;
  height: 25em;
  position: relative;
}
.visual .img-img::before,
.visual .slide-inner::before {
  background: url(../img/top_img001.webp) center center no-repeat;
  background-size: cover;
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
}
:not(.home) .visual .img-img::before {
  background-position: center 75%;
}
.visual .slide-2nd::before {
  background-image: url(../img/top_img002.webp) ;
  background-position: 45%;
}
.visual .slide-3rd::before {
  background-image: url(../img/top_img003.webp) ;
}
/* ------/ slide------ */

.visual .block-inner::after {
  background-color: rgba(100,100,100,.3);
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 2;
}
.visual,
.visual-inner,
.tagline .heading-text,
.visual .text-inner {
  position: relative;
}
.tagline-inner {
  color: #fff;
}
.tagline-subheading {
  text-align: center;
  margin: 2em 0;
}
.tagline {
  display: block;
  width: 18em;
  position: absolute;
  top: 32%;
  left: calc(50% - 9em);
  z-index: 2;
}
.tagline .heading-inner {
  font-size: 1.2em;
  letter-spacing: .04em;
  text-align: center;
}
.tagline .subheading-inner {
  font-size: .9em;
}
.tagline .tagline-inner > .text-block {
  display: none;
  position: absolute;
  top: -4em;
}
.narrow.before {
  padding-right: .2em;
}
.narrow.after {
  padding-left: .2em;
}
.tagline p {
  margin: 0;
}
.tagline .heading-text {
  display: block;
}
.tagline .heading-text.line-1st::before,
.tagline .heading-text.line-2nd::before {
  background-color: #fff;
  content: "";
  width: 107%;
  height: .0625em;
  position: absolute;
  top: -.5em;
  left: -3%;
}
.tagline .heading-text.line-2nd::before {
  top: auto;
  bottom: -.4em;
}
@media screen and (min-width: 576px) {
  .tagline .heading-inner {
    font-size: 1.2em;
  }
  .tagline .text-block {
    display: block;
  }
}
@media screen and (min-width: 768px) {
  .home .visual .block-inner,
  .home .visual .img-img,
  .visual .slide-inner {
    height: 45em;
  }
  .tagline {
    width: 33em;
    top: 38%;
    left: calc(50% - 16.5em);
  }
  .tagline .heading-inner {
    font-size: 1.75em;
  }
}
@media screen and (min-width: 992px) {
  .tagline .heading-inner {
    font-size: 2.4em;
  }
  .tagline .subheading-inner {
    font-size: 1em;
  }
}

/* nav */
.nav-inner {
  text-align: center;
}
.nav a:hover {
  text-decoration: none;
}
/* hamberger menu */
.nav .menu-close .menu-top,
.nav .menu-close .nav-bg {
  /* .menu-closeがあると非表示 */
  visibility: hidden;
}
.nav .menu-top {
  width: 60%;
  /* .menu-closeがないと表示する */
  position: fixed;
  /* margin-top: 2em; */
  top: 0;
  left: 20%;
  z-index: 1002;
}
.nav .nav-bg {
  /* openになっているときに白背景を表示する */
  background-color: rgba(265,265,265,.95);
  width: 100%;
  height: 100%;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 1002;
  visibility: visible;
}
.nav .menu-top .item-label,
.nav .menu-top .sub-menu .item-label {
  background-color: var(--yellow);
  border-bottom: 1px solid var(--darkgray);
  margin: 0 auto;
  padding: 1.5em 2em;
  position: relative;
}
.nav .menu-top .sub-menu .item-label {
  background-color: var(--yellow-light-x);
}
.nav .sub-menu-open .sub-menu .item-label {
  animation: sub-menu-opening .3s ease ;
}
@keyframes sub-menu-opening {
  from {
    padding: 0;
  }
  to {
    padding: 1.5em 2em;
  }
}
.nav .menu-top > li.item-inner {
  width: 100%;
  margin: 0 auto;
}
.nav .sub-menu {
  display: none;
}
.nav .sub-menu-open .sub-menu {
  display: block;
}
/* hanberger btn */
.nav a > .top-has-sub {
  position: absolute;
  top: 1.5em;
  left: 22%;
}
.nav .menu-btn {
  width: 2.2em;
  height: 3em;
  position: fixed;
  top: 1em;
  right: 1em;
  z-index: 1005;
  cursor: pointer;
}
.nav .menu-btn .btn-inner::before,
.nav .menu-btn .btn-inner::after {
  content: "";
}
.nav .menu-btn .hamberger,
.nav .menu-btn .btn-inner::before,
.nav .menu-btn .btn-inner::after {
  background-color: var(--blue-dark-contents);
  display: block;
  width: 110%;
  height: 2.5px;
  position: absolute;
  top: 0;
  left: -5%;
}
.nav .menu-close .menu-btn .btn-inner::before {
  top: .8em;
  opacity: 1;
  transform: none;
  transition: transform .23s ease, opacity .23s ease;
}
.nav .menu-close .menu-btn .btn-inner::after {
  top: 1.6em;
  transform: none;
  transition: transform .23s ease;
}
.nav .menu-close .menu-btn .hamberger {
  top: 0;
  transform: none;
  transition: transform .23s ease;
}
.nav .menu-btn .hamberger {
  top: .5em;
  transform: rotate(-45deg);
  transition: transform .23s ease;
}
.nav .menu-btn .btn-inner::after {
  top: .5em;
  transform: rotate(45deg);
  transition: transform .23s ease;
}
.nav .menu-btn .btn-inner::before {
  opacity: 0;
  transition: opacity .23s ease;
}
@media screen and (min-width: 576px) {
  .nav a > .top-has-sub {
    left: 30%;
  }
}
@media screen and (min-width: 768px) {
  .nav .nav-bg {
    z-index: -1;
  }
  .nav .menu-top > li.item-inner {
    border-bottom: 1px solid transparent;
    width: auto;
    margin: 0;
    padding: 1em;
  }
  .nav li,
  .nav li > a {
    color: #fff;
    position: relative;
  }
  .nav a > .top-has-sub {
    top: 1.2em;
    left: -10%;
  }
  .nav-inner {
    background-color: var(--blue-dark-contents);
    font-size: 1em;
    width: 100%;
    margin: 0 auto;
    padding: 0 1.5em;
    position: relative;
  }
  .nav .menu-top li.item-inner .item-label,
  .nav .menu-top .sub-menu li .item-label {
    background-color: transparent;
    border-bottom: none;
    padding: 0;
  }
  .nav .menu-inner > a {
    color: #fff;
    cursor: pointer;
    transition: transform .3s ease;
  }
  .nav .sub-menu li:hover .item-label {
    transform: scale(1.1);
    transition: transform .3s ease;
  }
  .nav .sub-menu {
    background-color: #fff;
    min-width: 13em;
    padding: 0;
    position: absolute;
    top: 3.4em;
    left: -21%;
    z-index: 2;
  }
  .nav .menu-inner .sub-menu {
    opacity: 0;
    visibility: hidden;
    transition: min-width .3s ease, background-color .3s ease, opacity .3s ease;
  }
  .nav .menu-inner:hover .sub-menu,
  .nav .menu-inner .sub-menu > li:hover,
  .nav .menu-inner.sub-menu-open:hover .sub-menu,
  .nav .menu-inner.sub-menu-open .sub-menu > li:hover,
  .nav .menu-inner:active .sub-menu,
  .nav .menu-inner .sub-menu > li:active {
    opacity: 1;
    visibility: visible;
  }
  .nav .menu-top .sub-menu-open .sub-menu li .item-label,
  .nav .menu-top .sub-menu li .item-label {
    animation: none;
  }
  .nav .sub-menu .caption-wrap {
    background-color: var(--blue-dark-contents);
    padding: 1em 0;
    transition: background-color .3s ease;
  }
  .nav .sub-menu li {
    border-bottom: var(--darkgray) 1px solid;
    line-height: 1.2em;
    margin: 0;
    padding: 0;
    transition: background-color .3s ease;
  }
  .sub-menu li:hover,
  .sub-menu li:active {
    background-color: var(--yellow);
  }
  .nav .menu-btn {
    display: none;
  }
  .nav .menu-close .menu-top,
  .nav .menu-top {
    width: 100%;
    max-width: var(--content-max-width);
    margin: 0 auto;
    padding: 0;
    position: relative;
    left: 0;
    visibility: visible;
  }
}
/* ==============
  TOPページ
  <body class="home">
=============== */
/* #service */
#service .text-box-outline img {
  aspect-ratio: 4 / 3;
  object-fit: cover;
}
#service .yellow-line::before {
  height: 50%;
  bottom: -.2em;
}
#service .text-text {
  margin: 1.5em 0;
}
#service .text-bold {
  font-size: 1.2em;
  font-weight: bold;
}
#service .img-inner {
  width: 60%;
  margin: 0 auto;
}
#service .item-block {
  background-color: #fff;
  border-radius: .8em;
  padding: 1.5em 1.5em 4.3em;
}
#service .item {
  flex-flow: wrap;
}
#service .item .text-block .item {
  justify-content: space-between;
}
#service .item .text-block .item > .item-inner {
  text-align: center;
  width: 48%;
  margin: 0;
  padding: .5em .5em 0 .5em;
}
#service .item-heading {
  font-size: 1em;
}
#service .item-heading,
#service .img-block,
#service div.text-block {
  margin-bottom: 1em;
}
#service .read-more {
  margin: 0 auto;
  position: absolute;
  right: 0;
  bottom: 1.5em;
  left: 0;
}
@media screen and (min-width: 768px) {
  #service .item-inner {
    width: 45%;
    margin: 0 1em 2em;
  }
  #service .article-contents::after {
    border-right: 46em solid transparent;
    border-bottom: 60em solid var(--yellow);
  }
  .home .item-subtitle-ele {
    min-height: 2.7em;
  }
  #service .item-inner {
    background-color: #fff;
    width: calc(45% - 1em);
  }
  #service .item-inner:nth-child(2n+1) {
    margin-right: 1em;
    margin-left: 5%;
  }
  #service .item-inner:nth-child(2n) {
    margin-right: 5%;
    margin-left: 1em;
  }
  #service .text-box-outline .text-box-outline .text-inner {
    font-size: .95em;
  }
}
@media screen and (min-width: 992px) {
  .home .item-subtitle-ele {
    min-height: auto;
  }
  #service .text-box-outline .text-box-outline .text-inner {
    font-size: 1em;
  }
}
@media screen and (min-width: 1200px) {
  #service .item .text-block .item > .item-inner:nth-of-type(1) {
    margin-left: 0;
  }
  #service .item .text-block .item > .item-inner:nth-of-type(2) {
    margin-right: 0;
  }
  #service .item .item .text-inline.text-flap {
    display: block;
  }
}

/* #greeting */
#greeting .img-inner {
  margin: 0 auto;
}
#greeting .text-text {
  margin-bottom: 2em;
}
#greeting .text-text .text-saeki {
  text-align: center;
}
#greeting .text-text .text-saeki .text-block {
  font-size: 1.4em;
  font-weight: bold;
}
#greeting .text-text .text-saeki .text-small {
  display: block;
}
@media screen and (min-width: 768px) {
  #greeting .img-inner {
    width: 20em;
    margin: 0 auto 0 2.5em;
  }
  #greeting .article-contents .text-inner {
    display: flex;
    flex-flow: column;
    width: 100%;
    height: 100%;
  }
  #greeting .article-contents .text-inner .text-text:first-of-type {
    padding-bottom: 2em;
  }
  #greeting .article-contents .text-inner .text-text:last-of-type {
    color: #fff;
    text-align: end;
    display: flex;
    flex-flow: column;
    justify-content: center;
    padding-bottom: 2em;
  }
  #greeting .text-text {
    margin-bottom: 0;
  }
  #greeting .text-text .text-saeki {
    text-align: end;
  }
  #greeting .text-text .text-saeki .text-block {
    font-size: 1.7em;
  }
  .article-contents.blue::before {
    border-bottom: 21em solid var(--blue-dark-contents);
    border-left: 37em solid transparent;
  }
  #greeting .article-contents-inner {
    display: flex;
    justify-content: space-between;
  }
  #greeting .article-contents-inner > .text-block {
    width: 55%;
  }
  #greeting .article-contents-inner > .img-block {
    width: 45%;
  }
  #greeting p.overflow-text {
    text-shadow: #fff 1px 1px .5px;
  }
  #greeting .text-text .text-saeki .text-block {
    font-weight: unset;
  }
}

/* #blog */
#blog .article-contents {
  margin-bottom: 1.5em;
}
#blog .article-contents.no-contents {
  margin-bottom: 0;
}
#blog .article-contents-inner {
  padding: 0 0 1em 0;
}
#blog .item .text-inner {
  padding: .5em 0;
}
#blog .item li.item-inner {
  margin: 0 0 3em 0;
}
#blog .article-contents-inner .img-inner {
  overflow: hidden;
}
#blog .article-contents-inner a:hover .img-block img,
.text-block a:hover .contact-banner-inner,
.sns_wrap:hover,
.go-to-top:hover {
  transform: scale(1.05);
  transition: transform .3s ease;
}
#blog .img-block img {
  aspect-ratio: 16 / 9;
  object-fit: cover;
  transition: transform .3s ease;
}
#blog .text-text {
  line-height: 1.5;
  margin-top: .5em;
}
@media screen and (min-width: 768px) {
  #blog .article-contents-inner {
    padding: 0 2em 1em 2em;
  }
  #blog .item-inner {
    width: 32%;
    margin: 0 1em;
  }
  #blog .article-contents::after {
    border-right: 47em solid transparent;
    border-bottom: 20em solid var(--yellow);
  }
  #blog .item .text-inner {
    padding: .5em 0 .5em .5em;
  }
}
@media screen and (min-width: 1200px) {
}
.item-block .date,
.item-block .label {
  display: inline-block;
  margin-right: .5em;
}
.date-and-label .text-inner > div:last-child {
  margin-right: 1em;
}
.date-and-label .text-inner.column > div:last-child {
  display: flex;
}

/* #news */
.wp .link-block,
.wp .link-text {
  margin: auto 0;
}
.wp .link-block {
  margin-bottom: 1em;
}
#news .item-inner {
  border-bottom: var(--text-color) .5px solid;
  margin: 0 0 1em 0;
}
@media screen and (min-width: 768px) {
  #news .item .item-block {
    display: flex;
  }
  #news .item .text-block {
    width: 25%;
  }
  #news .item .link-block {
    width: 75%;
  }
  .wp .link-block {
    margin-bottom: auto;
  }
}

/* #contact内
  .contact-banner共通 */
.contact-inner,
.contact-inner a {
  color: #fff;
}
.tell-mail-banner .article-contents-inner {
  padding: 2em 2em 1em ;
}
.text-tel-inner {
  font-size: 2em;
  font-weight: 600;
  letter-spacing: .12em;
}
.textsub-tel-inner {
  font-size: 1.2em;
}
.textsub-tel-inner > span:first-of-type {
  padding-right: 1.5em;
}
.tell-mail-banner .contact-inner > div {
  max-width: 27em;
  margin: 0 auto 1em ;
}
.tell-mail-banner .contact-inner > div:first-of-type .text-box {
  text-align: center;
  margin: auto 0;
  /* padding-top: .3em; */
}
.contact-inner,
.contact-banner {
  width: 100%;
  margin: 0 auto;
}
.contact-banner-inner {
  background-color: var(--pink-light-contents);
  display: flex;
  justify-content: center;
  padding: 1em;
  transition: transform .3s ease;
}
.contact-banner-inner .text-box:nth-of-type(2) span,
.contact-banner-inner h2 > span {
  font-size: 1.2em;
  font-weight: bold;
  letter-spacing: .08em;
}
.tell-mail-banner .contact-banner-inner .text-icon {
  width: 20%;
}
.tell-mail-banner .contact-banner-inner .contact-text {
  width: 78%;
  padding-top: .4em;
  padding-left: .625em;
}
.tell-mail-banner.article-contents::after {
  background-color: var(--blue-dark-contents);
  height: 100%;
}
@media screen and (min-width: 374px) {
  .tell-mail-banner .contact-banner-inner .contact-text {
    padding-top: .75em;
  }
}
@media screen and (min-width: 768px) {
  .tell-mail-banner .contact-inner > div {
    width: 49%;
    margin: auto;
  }
  .tell-mail-banner .contact-inner > div:first-of-type .text-box {
    padding-top: .3em;
  }
  .tell-mail-banner .article-contents-inner {
    padding: 2em 1em 2.2em ;
  }
  .tell-mail-banner.article-contents::after {
    background-color: transparent;
  }
  .tell-mail-banner.article-contents::before {
    background-color: var(--yellow);
    height: 100%;
  }
  .tell-mail-banner.article-contents::after {
    border-right: 41em solid transparent;
    border-bottom: 12em solid var(--blue-dark-contents);
  }
  .contact-banner-inner .text-box:nth-of-type(2) span,
  .contact-banner-inner h2 > span {
    font-size: 1.4em;
  }
  .tell-mail-banner .contact-banner-inner .contact-text {
    padding-left: 0;
  }
}
@media screen and (min-width: 992px) {
  .tell-mail-banner .contact-banner-inner .contact-text {
    padding-left: .625em;
  }
}
@media screen and (min-width: 1024px) {
  .contact-banner-inner .text-box:nth-of-type(2) span,
  .contact-banner-inner h2 > span {
    font-size: 1.5em;
  }
}

/* #sns */
#sns .link-block {
  justify-content: center;
}
#sns .item {
  justify-content: center;
}
.sns-box {
  display: flex;
  margin-bottom: 1em;
}
.sns-box > .img-block {
  width: 20%;
  margin: auto 0;
}
.sns-box .img-inner {
  width: 3.5em;
  min-width: 32px;
  height: auto;
  margin: 0 auto;
}
.sns-box > .text-block {
  width: 80%;
  padding-left: 1.2em;
}
.sns-box .text-text > span {
  font-size: 1.2em;
  font-weight: 600;
}
.sns_wrap {
  margin-right: auto;
  margin-left: auto;
}
.sns_wrap.tw {
  max-height: 500px;
}
.sns_wrap.tw div,
.sns_wrap.tw iframe {
  width: 100% !important;
}
.sns_wrap.fb {
  width: 100%;
  max-width: 100%;
  margin: 0 auto;
}
.fb-page,
.fb-page span,
._2p3a,
._2lqg,
._2lqh,
.sns_wrap.fb iframe {
  width: 100% !important;
  min-width: 100% !important;
  height: 400px !important;
}
@media screen and (min-width: 576px) {
  #sns .item {
    flex-flow: inherit;
  }
  #sns .item-inner:nth-child(1) {
    margin-right: 2em;
  }
  #sns .item-inner:nth-child(2) {
    margin-left: 2em;
  }
  .sns_wrap.tw,
  .fb-page,
  .fb-page span,
  ._2p3a,
  ._2lqg,
  ._2lqh,
  .sns_wrap.fb iframe {
    height: 500px !important;
  }
}
@media screen and (min-width: 768px) {
  .sns_wrap.fb {
    width: 340px;
    max-width: 340px;
  }
}

/* #access */
.address-inner .postal-code,
.address-inner .address-text {
  display: block;
}
.map-inner iframe {
  width: 100%;
  height: 35em;
}
.access-name {
  padding-left: .5em;
  position: relative;
}
.access-name::before {
  background-color: #000;
  border-radius: 50%;
  content: "";
  width: .4em;
  height: .4em;
  position: absolute;
  top: 38%;
  left: 0;
}
.access_left {
  padding-left: .5em;
}

/* footer */
.go-to-top {
  position: absolute;
  top: 2em;
  right: 2em;
  z-index: 4;
  transition: transform .3s ease;
}
.go-to-top:hover {
  transform: scale(1.2);
}
.footer-heading {
  width: 100%;
  margin: 0 auto 1.5em ;
}
.footer-inner {
  background-color: var(--blue-dark-contents);
  color: #fff;
  text-align: center;
  padding: 2em 1em 1em;
}
.footer-inner a {
  color: #fff;
}
footer .heading-link {
  justify-content: center;
}
footer .site-heading,
footer .address,
footer .privacy-policy {
  margin-bottom: 1.5em;
}

/* TOP以外でのページ共通ヘッダー画像 */
body:not(.home) .visual .img-img {
  height: 10em;
  position: relative;
}

/* ==============
  記事一覧ページ / 記事ページ
=============== */
/* 記事ページ */
.single .archive-title > .heading-inner {
  font-size: 1.6em;
  display: inline-block;
  position: relative;
  z-index: 1;
}
.single header.article-header {
  margin-bottom: 2em;
}
/* 記事一覧ページ */
.article.entry-card {
  margin: 6em 0 ;
}
.posts-not-found.text-center {
  padding-left: .5em;
}
.entry-card-inner {
  position: relative;
}
.archive .entry-card-inner > .item-block {
  position: absolute;
  top: 14em;
  z-index: 2;
}
.entry-card-wrap:hover .link-block,
.entry-card-wrap:hover .entry-card-snippet,
.entry-card-wrap:hover .date {
  text-decoration: underline;
}
.entry-card-thumb {
  overflow: hidden;
}
.archive .entry-card-thumb img {
  aspect-ratio: 16 / 9;
  object-fit: cover;
}
.archive .entry-card-wrap img {
  transform: scale(1);
  transition: transform .3s ease;
}
.archive .entry-card-wrap:hover img {
  transform: scale(1.1);
}
.archive .entry-card-content {
  margin-top: 4em;
}
.archive .entry-card-snippet {
  margin: 1em 0;
}
/* 2023-10-10　added　サムネイル画像にテキストを載せる */
.text-on-thumb_inner {
  border: var(--text-color) 1px solid;
  text-align: center;
  height: 100%;
  position: relative;
}
.text-on-thumb_inner figcaption {
  font-weight: bold;
  line-height: 1.6em;
  display: grid;
  align-items: center;
  padding: .5em 1em;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 3;
}
.text-on-thumb_inner figcaption::after {
  background-color: var(--yellow);
  content: "";
  width: 100%;
  height: 100%;
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: -1;
}
@media screen and (min-width: 374px) {
  .archive .entry-card-inner > .item-block {
    top: 16.5em;
  }
}
@media screen and (min-width: 576px) {
  body:not(.home) .visual .img-img {
    height: 14em;
  }
  .archive-blog .entry-card-inner,
  .archive-blog .entry-card-wrap {
    flex-flow: row;
  }
  .archive-blog .entry-card-thumb {
    width: 30%;
    max-width: 20em;
    height: 100%;
    margin-bottom: 0;
  }
  .archive-blog .entry-card-content {
    width: 70%;
    padding-left: 2em;
  }
  .archive-blog .text-on-thumb_inner figcaption {
    font-size: .85em;
    padding: .3em 1em;
  }
  .archive .entry-card-content {
    margin-top: 3em;
  }
  .archive .entry-card-inner > .item-block {
    top: 0;
    left: calc(30% + 2em);
  }
}
@media screen and (min-width: 768px) {
  body:not(.home) .visual .img-img {
    height: 13em;
  }
  body.tag .article-header {
    margin-top: 6em;
  }
  .archive .entry-card-snippet,
  .archive .entry-card-title {
    line-height: 1.5;
    margin: 0 0 1em 0;
  }
  .archive .entry-card-snippet {
    margin: 0;
  }
  .text-on-thumb_inner figcaption {
    font-size: .9em;
    line-height: 1.4em;
    padding: .5em 1em .5em .8em;
  }
}
@media screen and (min-width: 992px) {
  body:not(.home) .visual .img-img {
    height: 18em;
  }
}
@media screen and (min-width: 1200px) {
  body:not(.home) .visual .img-img {
    height: 20em;
  }
}
/* パンくずリスト */
.breadcrumb-inner {
  display: block;
  margin: 0;
  padding: 2em 0;
}
.breadcrumb-home,
.breadcrumb-item {
  display: inline-block;
  margin-right: .5em;
}
.breadcrumb-home > a,
.breadcrumb-item > a {
  margin-right: .4em;
}
/* ページャー */
.under-entry-content {
  margin: 1em 0 2em;
}
.under-entry-content div.fa-chevron-left,
.under-entry-content div.fa-chevron-right {
  cursor: pointer;
}
.pager-post-navi {
  display: flex;
}
.pager-post-navi > a {
  display: flex;
  width: 50%;
}
.pager-post-navi > a.next-post-only,
.pager-post-navi > a.prev-post-only {
  width: 100%;
}
.pager-post-navi > a.next-post {
  flex-flow: row-reverse;
}
.pager-post-navi .fa-chevron-left,
.pager-post-navi .fa-chevron-right {
  position: relative;
}
.pager-post-navi .fa-chevron-left:before,
.pager-post-navi .fa-chevron-right:before {
  position: absolute;
  top: 20%;
}
.pager-post-navi .blog-icon.fa-chevron-left:before,
.pager-post-navi .blog-icon.fa-chevron-right:before {
  top: 20%;
}
.pager-post-navi .fa-chevron-right:before {
  right: 10%;
}
.prev-post-thumb,
.next-post-thumb {
  display: none;
}
.prev-post-title,
.prev-post-thumb {
  margin: auto 0 auto 1em;
}
.next-post-title,
.next-post-thumb {
  margin: auto 1.1em auto 0;
}
.page-numbers {
  font-size: 1.1em;
  font-weight: bold;
  margin-right: .5em;
  padding: 0 .5em;
  transition: color .23s ease;
}
.paginatinon,
.page-numbers {
  text-align: center;
}
.page-numbers.current {
  color: var(--blue-dark-contents);
  position: relative;
}
.page-numbers.current::after {
  background-color: var(--blue-dark-contents);
  content: "";
  width: 50%;
  height: 2px;
  position: absolute;
  bottom: -.1em;
  left: 25%;
}
a.page-numbers:hover,
a.pagination-next-link:hover {
  color: rgba(10, 33, 92, .5);
  transition: color .23s ease;
}
.supplement-text > p:first-child {
  margin: .5em 0;
}
@media screen and (min-width: 576px) {
  .prev-post-title.display_sp,
  .prev-post-thumb,
  .next-post-title.display_sp,
  .next-post-thumb {
    display: inherit !important;
  }
  .prev-post-title.display_pc,
  .prev-post-thumb,
  .next-post-title.display_pc,
  .next-post-thumb {
    display: none;
  }
  .prev-post-thumb,
  .next-post-thumb {
    display: block;
  }
  .pager-post-navi .blog-icon.fa-chevron-left:before,
  .pager-post-navi .blog-icon.fa-chevron-right:before {
    top: 37%;
  }
}
@media screen and (min-width: 768px) {
  .prev-post-title.display_sp,
  .prev-post-thumb,
  .next-post-title.display_sp,
  .next-post-thumb {
    display: none !important;
  }
  .prev-post-title.display_pc,
  .prev-post-thumb,
  .next-post-title.display_pc,
  .next-post-thumb {
    display: inherit;
  }
  .prev-post-title,
  .next-post-title {
    display: block;
  }
  .under-entry-content {
    margin: 1em 0;
  }
}

/* 固定ページ共通シェイプなど */
.error404 .entry-title {
  text-align: center;
}
span.item.row {
  justify-content: left;
}
.page-contents {
  margin: 4em 0;
}
.page-heading > .heading-inner {
  font-size: 1.6em;
}
.page-contents .header {
  margin-top: 0;
}
.page-contents.title-sideline .item > .img-block {
  width: 80%;
  margin: 2em auto 0;
}
.title-sideline .header-inner:before {
  background-color: var(--yellow);
  content: "";
  width: .5em;
  height: 2em;
  position: absolute;
  top: 0;
  left: 0;
}
.page-contents.title-sideline .item {
  flex-flow: column-reverse;
}
.page-allow,
.get_btn span,
.text-label-box .page-heading,
.yuigon-page table td.cost {
  width: auto;
  height: 1em;
  padding: 0;
  position: relative;
}
.page-allow .page-allow-inner::before,
.three-item li::before,
.item.flowchart > li::before,
.souzoku-page .item.row.flowchart > li:nth-of-type(1)::after {
  border-top: 1.2em solid var(--blue-dark-contents);
  border-right: 1.2em solid transparent;
  border-left: 1.2em solid transparent;
  content: "";
  width: 1em;
  height: 1em;
  /* ページ中にある三角矢印 */
  position: absolute;
  top: 0;
  left: 48%;
}
.text-box-outline > .text-box-inner,
.text-box-inner,
.text-box-nooutline > .text-box-inner {
  padding: 1em;
  position: relative;
}
.text-box-nooutline > .text-box-inner {
  padding: 1.5em;
}
.text-box-inner.item.column > p,
.text-box-inner.item.column > div,
.text-box-inner.item.column > ul {
  display: inline-block;
  margin: 0 auto;
}
.text-box-inner.item.column > p span,
.text-box-inner.item.column > div p {
  text-align: left;
}
.page-contents.title-sideline .img-block {
  margin-bottom: 2em;
}
.get_btn {
  margin-top: 1em;
}
.get_btn span::before {
  background-image: url(../img/icon/get_btn.webp);
  background-repeat: no-repeat;
  background-size: 100%;
  content: "";
  width: 3.6em;
  height: 3.6em;
  position: absolute;
  top: -100%;
  left: 100%;
}
.get_btn a:hover span::before {
  background-color: rgba(256,256,256, .3);

  background-blend-mode: lighten;
}
.text-label-box {
  margin: 3em 0;
}
.text-label-box .page-heading {
  text-align: center;
}
.text-label-box > .text-box p {
  margin-top: .5em;
}
.text-side-label-box .page-heading {
  display: flex;
}
.text-side-label-box .page-heading span {
  font-size: 1em;
  margin: auto 0;
  vertical-align: middle;
}
.text-label-box .page-heading span:first-of-type,
.text-side-label-box .page-heading span:first-of-type,
.text-center-label-box .page-heading {
  background-color: var(--yellow);
  border-radius: .3em;
  padding: 1em 1.5em;
  position: relative;
  z-index: 1;
}
.text-side-label-box .page-heading span:first-of-type {
  color: #fff;
  padding: .5em 1.5em;
}
.text-side-label-box .page-heading span:first-of-type {
  border-top-right-radius: 0;
  border-bottom-left-radius: 0;
  font-size: 1em;
  display: inline-block;
}
.text-center-label-box .page-heading p:nth-child(2) > span {
  font-size: 1.2em;
}
.text-center-label-box .item.column {
  justify-content: center;
  min-height: 9em;
  margin: auto 0;
}
/* 色違い */
.text-side-label-box.orange .text-box-outline {
  border: var(--orange) 1px solid;
}
.text-side-label-box.orange .page-heading span:first-of-type {
  background-color: var(--orange);
  border-top-left-radius: .2em;
}
.text-center-label-box.blue .page-heading {
  background-color: var(--blue-dark-contents);
  border-radius: .2em;
  border-bottom-right-radius: 0;
  border-bottom-left-radius: 0;
  color: #fff;
}
.text-blowing > div.text-box-outline,
.text-blowing > div.text-box-nooutline {
  width: 100%;
  height: 100%;
  margin: auto 0 2em 0;
}
.text-blowing > div.img-block {
  width: 8em;
  margin: 0 0 auto 0;
}
.text-blowing.question {
  flex-flow: row-reverse;
}
.text-blowing.question .text-box-nooutline,
.text-blowing.question .text-box-outline {
  margin-left: 2em;
}
.text-blowing.answer .text-box-nooutline,
.text-blowing.answer .text-box-outline {
  margin-right: 2em;
}
.text-blowing.answer .text-box-nooutline .text-box-inner::before,
.text-blowing.question .text-box-nooutline .text-box-inner::before {
  border-top: .8em solid transparent;
  border-right: 1.4em solid var(--yellow-light-xxx);
  border-bottom: .8em solid transparent;
  border-left: .8em solid transparent;
  content: "";
  width: 1em;
  height: 1em;
  position: absolute;
  top: 1.5em;
  left: -2em;
}
.text-blowing.answer .text-box-nooutline .text-box-inner::before {
  border-right: .8em solid transparent;
  border-left: 1.4em solid var(--yellow-light-xxx);
  right: -2em;
  left: auto;
}
.text-blowing.question .text-box-nooutline.green .text-box-inner::before {
  border-right: 1.4em solid var(--green-contents-light-x);
}
.text-blowing.answer .text-box-nooutline.green .text-box-inner::before {
  border-left: 1.4em solid var(--green-contents-light-x);
}
.page-contents ol {
  list-style-type: none;
  text-align: initial;
}
.page-contents ol > li {
  margin-left: 1.5em;
  position: relative;
}
.page-contents ol .ol_number {
  position: absolute;
  left: -1.3em;
}
.table-inner {
  margin-top: 1.5em;
}
article:not(.yuigon-page) table tr {
  border-top: var(--text-color) .8px solid;
  border-bottom: var(--text-color) .8px solid;
  text-align: center;
}
article:not(.yuigon-page) table thead > tr {
  background-color: var(--darkorange-light-x);
}
article:not(.yuigon-page) table  tr > th {
  width: 19%;
  padding: .5em;
}
article:not(.yuigon-page) table  tr > td {
  width: 39%;
  padding: .5em;
}
article:not(.yuigon-page) thead  tr > th,
article:not(.yuigon-page) tbody  tr > th,
article:not(.yuigon-page) tbody  tr > td {
  border-right: var(--text-color) .8px solid;
  border-left: var(--text-color) .8px solid;
}
/* ==============
  固定ページ＞お問い合わせページ
  <article class="contact-page">
=============== */
.three-item .img-block {
  width: 8em;
  height: auto;
  margin: 0 auto;
}
.three-item > li::before {
  border-top: .8em solid var(--blue-dark-contents);
  border-right: .8em solid transparent;
  border-left: .8em solid transparent;
  /* 矢印 */
  top: auto;
  bottom: -11%;
}
.three-item li:last-of-type:before {
  display: none;
}
.contact-page .item-inner:first-of-type .text-center-label-box li {
  display: flex;
  padding: 0 .5em;
}
.text-box-outline.blue .text-center,
.contact-page .text-center-label-box .item.column p > span {
  margin-bottom: 0;
}
.text-box-outline.blue .text-center > span {
  margin: 0;
}
.contact-page .item-inner:first-of-type .text-center-label-box .item.column .img-block,
.contact-page .item-inner:first-of-type .text-center-label-box .item.column p {
  line-height: 1.5;
  margin: auto 0 auto .5em;
}
.contact-page .contact-banner .img-inner {
  width: 6em;
  margin: 0 .2em 0 auto;
}
.contact-page .contact-banner .text-block {
  padding-top: .4em;
}
.contact-page .contact-banner-inner {
  border-radius: .3em;
  justify-content: center;
}
.contact-page .text-block {
  margin: 1em 0;
}
.contact-page .checkbox-box .text-block {
  margin: 0;
}
.form-inner,
.form-contents {
  margin: 2em 0;
}
.form .item-heading {
  margin-bottom: .5em;
}
.text-block.blowing-text {
  background-color: var(--blue-light-form);
  border-radius: .3em;
  max-width: 32em;
  margin: 0 1em;
  padding: 1em;
  position: relative;
}
.text-block.blowing-text::before {
  border-top: 1em solid var(--blue-light-form);
  border-right: 1em solid transparent;
  border-left: 1em solid transparent;
  content: "";
  width: 0;
  height: 0;
  position: absolute;
  bottom: -.8em;
  left: 2.1em;
}
.contact-page .label .label-inner,
.contact-page .label .label-title-inner {
  font-weight: initial;
  padding: .2em .3em;
}
.form .label {
  display: flex;
  margin-bottom: .6em;
}
.form .label-box {
  width: 7%;
  min-width: 2.8em;
}
.form .label-title-inner {
  width: 90%;
}
.form li.item-inner {
  margin: 0 0 2em 0;
}
.contact-page .form .label-inner {
  background-color: var(--gray-dark-xxx);
  border-radius: 3px;
  color: #fff;
}
.label.must .label-inner {
  background-color: var(--pink-light-form);
}
.form .checkbox-inner {
  padding-left: .4em;
}
.contact-page .text-block.link-color-text a {
  color: var(--blue);
}
.contact-page .text-block.link-color-text a.link-text::after {
  background-color: var(--blue);
}
.contact-page .text-bold.text-green {
  font-size: 1.2em;
}
.checkbox-box {
  position: relative;
}
[type="checkbox"],
[type="radio"] {
  position: absolute;
  top: 0;
  left: 0;
  opacity: 0;
}
.input_label {
  padding: .1em .1em .1em 1.4em;
  position: relative;
}
.input_label::before,
.input_label::after {
  content: "";
  display: block;
  position: absolute;
  top: 40%;
  left: 0;
}
.input_label::before {
  background-color: #fff;
  border: .075em solid var(--text-color);
  width: 1em;
  height: 1em;
  top: .2em;
  left: .1em;
  opacity: 3;
  transition: opacity .15s ease, background-color .15s ease;
}
.input_label.checkbox::after {
  border-right: .1875em solid #fff;
  border-bottom: .1875em solid #fff;
  width: .65em;
  height: .9em;
  /* ✓マーク表示 */
  top: .1em;
  left: .28em;
  opacity: 0;
  transform: rotate(45deg);
  transition: opacity .15s ease;
}
input[type=checkbox]:checked + .input_label::before {
  /* background-color: var(--blue-dark-contents); */
  background-color: #1a3678;
  opacity: 1;
  transition: opacity .15s ease, background-color .15s ease;
}
input[type=checkbox]:checked + .input_label::after {
  opacity: 2;
  transition: opacity .15s ease;
}
input[type="text"]:focus,
textarea:focus,
select:focus,
button:focus {
  border: var(--pink-light-contents) .125em solid;
  outline: 0;
}
input[type=checkbox]:focus + .input_label {
  border-radius: .25em;
  outline: .125em solid var(--pink-light-contents);
  position: relative;
  z-index: 1;
}
.submit-inner {
  width: 10em;
  margin: 0 auto;
}
.contact-thanks-page .page-heading > span {
  font-size: 1.2em;
}
.contact-thanks-page .body-inner {
  text-align: center;
  margin: 0 auto;
}
@media screen and (min-width: 576px) {
  .contact-page .contact-banner .text-block {
    margin-right: 1.4em;
  }
}
@media screen and (min-width: 768px) {
  .text-box-outline > .text-box-inner,
  .text-box-inner,
  .text-box-nooutline > .text-box-inner {
    padding: 1.5em;
  }
  .item.three-item > li {
    width: 29%;
    margin: 0 1em 2em;
  }
  .contact-page .contact-inner {
    width: 80%;
  }
  .form ul.item {
    flex-flow: column;
  }
  .form-contents {
    width: 80%;
    margin: 2em auto 0;
  }
}
/* ==============
  固定ページ＞遺言書ページ
  <article class="yuigon-page">
=============== */
/* .yuigon-page */
.plan-yuigon ul.item {
  margin-bottom: 1em;
}
.plan-yuigon .contents-plan {
  margin-bottom: 3em;
}
.yuigon-page .body-inner > .page-contents:last-of-type {
  margin-bottom: 8em;
}
.plan-yuigon
.yuigon-page .tell-mail-banner {
  margin-bottom: 7em;
}
.plan-yuigon .contents-plan-inner > div {
  margin-bottom: 1.5em;
}
.plan-yuigon .contents-plan-inner > div:last-child {
  margin-bottom: 0;
}
.plan-yuigon .contents-plan h4 > .text-block:nth-child(1) {
  font-size: 1.2em;
  margin-bottom: .5em;
}
.plan-yuigon .contents-plan-inner {
  text-align: center;
  overflow: hidden;
}
.plan-yuigon .contents-plan.text-box-outline.orange {
  border: var(--orange) 1.5px solid ;
}
.plan-yuigon .contents-plan.text-box-outline.blue {
  border: var(--blue-dark-xx) 1.5px solid ;
}
.plan-yuigon .contents-plan.orange .contents-plan-inner {
  background-color: var(--orange-light);
}
.plan-yuigon .contents-plan.blue .contents-plan-inner {
  background-color: var(--blue-light-xxx);
}
.contents-plan.orange .contents-plan-subtitle,
.page-contents.plan-yuigon .contents-plan.orange div:nth-of-type(3) > p:first-child {
  background-color: var(--orange);
}
.contents-plan.blue .contents-plan-subtitle,
.page-contents.plan-yuigon .contents-plan.blue div:nth-of-type(3) > p:first-child {
  background-color: var(--blue-dark-x);
}
.contents-plan .contents-plan-subtitle,
.page-contents.plan-yuigon .contents-plan div:nth-of-type(3) > p:first-child {
  color: #fff;
  text-align: center;
  margin: 0 -1.5em;
  padding: 1em 0;
}
.contents-plan .contents-plan-subtitle span {
  font-size: 1.6em;
}
.page-contents.plan-yuigon .contents-plan  div:nth-of-type(2) .text-box-allow {
  margin-bottom: 2em;
  position: relative;
}
.page-contents.plan-yuigon .contents-plan  div:nth-of-type(2) .text-box-allow::before {
  border-top: .6em solid var(--orange);
  border-right: .6em solid transparent;
  border-left: .6em solid transparent;
  content: "";
  width: 1em;
  height: 1em;
  position: absolute;
  bottom: -78%;
  left: calc(50% - .6em);
}
.page-contents.plan-yuigon .contents-plan.blue  div:nth-of-type(2) .text-box-allow::before {
  border-top: .6em solid var(--blue-dark-xx);
  border-right: .6em solid transparent;
  border-left: .6em solid transparent;
}
.page-contents.plan-yuigon .contents-plan  div:nth-of-type(2) .text-text,
.page-contents.plan-yuigon ol {
  background-color: #fff;
  border-radius: .3em;
  display: inline-block;
  width: 100%;
  padding: 1em;
}
.page-contents.plan-yuigon .contents-plan
 div:nth-of-type(3) > p:first-child span {
  font-size: 2em;
  font-weight: bold;
  line-height: 1.5;
  letter-spacing: .02em;
}
.page-contents.plan-yuigon .contents-plan
 div:nth-of-type(3) > p:first-child span:last-child {
  font-size: 1.8em;
  padding-right: .5em;
}
.page-contents.plan-yuigon .contents-plan div:nth-of-type(3) > p:last-child {
  margin-top: 1em;
}
.yuigon-page table {
  width: 100%;
  max-width: 100%;
  min-height: 28em;
  margin: 0 auto;
}
.yuigon-page table,
.yuigon-page .table-inner .text-text > span {
  font-size: .9em;
}
.yuigon-page table tr {
  display: flex;
  justify-content: space-between;
}
.yuigon-page table td.cost.cost-4letter {
  padding-left: .6em;
}
.yuigon-page table td.cost-text {
  width: 17em;
  max-width: 100%;
  padding: 0;
}
.yuigon-page tr.cost-text-inner {
  flex-flow: column;
  margin-top: 2.4em;
}
.yuigon-page tbody tr:nth-of-type(8) {
  margin-top: 0;
}
.yuigon-page tr.cost-text-inner td.cost {
  line-height: 1.5;
  text-align: end;
}
.page-contents.checklist .item-inner-inner {
  flex-flow: row;
  justify-content: flex-start;
}
.page-contents.checklist .item-inner-inner > .text-block {
  width: 100%;
  margin: auto 0;
  padding-left: .6em;
}
.page-contents.checklist .item-inner {
  margin: 0 0 1em 0;
}
.page-contents.checklist h4,
.page-contents.checklist .item-inner .item-inner {
  margin: 0 0 .5em 0;
}
.page-contents.checklist h4 > .text-bluedark {
  font-size: 1.2em;
}
.checkbox-icon.img-block {
  width: 2.5em;
  height: auto;
}

/* ==============
  固定ページ＞家族信託ページ
  <article class="family-page">
=============== */
.page-heading.green {
  background-color: var(--green-contents);
  border-radius: .3em;
  color: #fff;
  margin-bottom: 1em;
  padding: 1em 0;
}
.family-page .text-box-outline.green .page-heading > .heading-inner,
.family-page h5.page-heading .heading-inner {
  font-size: 1.4em;
}
.family-page .text-box-outline.green .header {
  margin-bottom: 2em;
}
.family-page .text-box-outline.green {
  margin: 2em 0;
}
.family-page .item .item-inner.text-blowing {
  margin: 0 0 2em;
}
.family-page .item .item-inner.text-blowing:last-of-type {
  margin: 0 ;
}
/* ==============
  固定ページ＞会社設立ページ
  <article class="company-page">
=============== */
.company-page .item.two-item .text-box-inner {
  background-color: var(--yellow);
  border-radius: .3em;
  border-top-left-radius: 0;
  border-top-right-radius: 0;
}
/* ==============
  固定ページ＞不動産ページ
  <article class="fudosan-page">
=============== */
.fudosan-page .text-box-nooutline .img-inner {
  display: block;
  width: 6em;
  margin: 0 auto;
  padding-bottom: 1em;
}
.fudosan-page .text-box-nooutline.green {
  background-color: var(--green-contents-dark);
  color: #fff;
}
/* ==============
  固定ページ＞代表挨拶ページ
  <article class="greeting-page">
=============== */
.greeting-page .text-inner.item.column {
  height: 100%;
}
.site-icon > .item.row {
  justify-content: end;
}
.site-icon > .item .site-img {
  width: 3em;
  margin-right: .5em;
}
.site-icon > .item .text-box span:nth-of-type(2) {
  text-align: end;
}
.greeting-page li.item-inner {
  margin: 0 0 2em 0;
}
.greeting-page .page-contents-inner > .text-box,
.profile-page .page-contents-inner > .text-box {
  margin-bottom: 4em;
}
.greeting-page .page-heading
.greeting-page .page-heading > .heading-inner {
  font-size: 1.4em;
}
.greeting-page ol > li {
  counter-increment: number-greeting;
}
.greeting-page ol > li > .page-heading::before {
  content: "(" counter(number-greeting) ")";
  font-size: 1.6em;
}
/* ==============
  固定ページ＞プライバシーポリシーページ
  <article class="privacy-policy-page">
=============== */
.privacy-policy-page .privacy-contents .heading-inner {
  font-size: 1.4em;
}
.privacy-policy-page p.text-text {
  margin: 1em 0;
}
.privacy-policy-page .item-inner.left {
  margin: 0;
  padding-left: 1em;
}
.privacy-policy-page .item-inner:last-of-type {
  margin-bottom: 0;
}
.privacy-policy-page ol > li {
  counter-increment: number;
}
.privacy-policy-page ol > li .header > .page-heading::before {
  content: counter(number) ".";
  font-size: 1.4em;
}
.privacy-policy-page .heading-underline::before,
.privacy-policy-page .heading-underline::after {
  left: -1em;
}
/* ==============
  固定ページ＞相続手続きページ
  <article class="souzoku-page">
=============== */
.souzoku-page .text-blowing > div.img-block {
  margin: 0 auto;
}
.souzoku-page li.item-inner {
  margin: 0 0 3em 0;
}
.page-heading.blue {
  background-color: var(--blue-dark-contents);
  border-radius: .2em;
  color: #fff;
  margin-bottom: 1em;
  padding: 1em 0;
  position: relative;
}
.yellow-triangle::before,
.souzoku-page .page-heading.blue::before {
  border-top: var(--yellow) 1.4em solid;
  border-right: var(--yellow) 1.4em solid;
  border-bottom: transparent 1.4em solid;
  border-left: transparent 1.4em solid;
  border-top-right-radius: .2em;
  top: 0;
  right: 0;
  bottom: auto;
  left: auto;
}
.yellow-triangle::after,
.souzoku-page .page-heading.blue::after {
  border-top: transparent 1.4em solid;
  border-right: transparent 1.4em solid;
  border-bottom: var(--yellow) 1.4em solid;
  border-left: var(--yellow) 1.4em solid;
  border-bottom-left-radius: .2em;
  top: auto;
  right: auto;
  bottom: 0;
  left: 0;
}
.item.flowchart > li::before {
  border-top: .8em solid var(--blue-dark-contents);
  border-right: .8em solid transparent;
  border-left: .8em solid transparent;
  top: auto;
  bottom: -2em;
}
.item.flowchart > li:last-of-type::before,
.item.flowchart > li:nth-child(3)::before {
  display: none;
}
.souzoku-page li.item-inner:last-of-type,
.souzoku-page .text-side-label-box li:last-of-type,
.souzoku-page .checklist .text-box-inner > ul > li:last-child,
.souzoku-page .item-inner:last-of-type ul.number-list {
  margin: 0;
}
span.text-center.text-red {
  margin-bottom: 0;
}
.souzoku-page div.letter-one-space {
  width: 89%;
  margin: auto 0 ;
}
.text-blowing.answer .text-box-nooutline.blue .text-box-inner::before {
  border-top: 1.4em solid var(--blue-dark-contents);
  border-left: .8em solid transparent;
  top: auto;
  bottom: -2em;
  left: 48%;
}
.text-blowing.question .text-box-outline.blue .text-box-inner::before,
.text-blowing.answer .text-box-outline.blue .text-box-inner::before,
.text-blowing.question .text-box-outline.blue .text-box-inner::after,
.text-blowing.answer .text-box-outline.blue .text-box-inner::after {
  border: .0625em solid transparent;
  border-top: .8em solid transparent;
  border-right: 1.4em solid var(--blue-dark-contents);
  border-bottom: .8em solid transparent;
  border-left: .8em solid transparent;
  content: "";
  width: 1em;
  height: 1em;
  position: absolute;
  top: 1.5em;
  left: -2.2em;
}
.text-blowing.answer .text-box-outline.blue .text-box-inner::before,
.text-blowing.answer .text-box-outline.blue .text-box-inner::after {
  border-top: 1.4em solid var(--blue-dark-contents);
  border-right: .8em solid transparent;
  border-left: .8em solid transparent;
  top: auto;
  bottom: -2.2em;
  left: 48%;
}
.text-blowing.question .text-box-outline.blue .text-box-inner::after {
  border-right: 1.4em solid #fff;
  margin-left: .125em;
}
.text-blowing.answer .text-box-outline.blue .text-box-inner::after {
  border-top: 1.4em solid #fff;
  margin-bottom: .125em;
}
span.letter-one-space.orange {
  position: relative;
}
span.letter-one-space.orange::before {
  border-top: .5em solid transparent;
  border-right: .5em solid transparent;
  border-bottom: .5em solid transparent;
  border-left: .8em solid var(--orange);
  content: "";
  width: 1em;
  height: 1em;
  position: absolute;
  top: 0;
  left: -.125em;
}
.souzoku-page .heading-underline::before,
.souzoku-page .heading-underline::after {
  left: -.2em;
}
.souzoku-page .heading-underline::before {
  width: 105%;
}
.souzoku-page .heading-underline::after {
  width: 52.5%;
}
.souzoku-page li.double {
  width: 45%;
  margin: auto 0;
}
.souzoku-page li.allow-down {
  margin: auto 0 !important;
}
.souzoku-page .allow-down > div {
  width: 60%;
  margin: 0 0 0 auto;
}
.souzoku-page .allow-down > div::before {
  background-color: var(--orange);
  content: "";
  width: .25em;
  height: 165%;
  position: absolute;
  top: -35%;
  left: 30%;
}
.souzoku-page .allow-down > div::after {
  border-top: .8em solid var(--orange);
  border-right: .8em solid transparent;
  border-left: .8em solid transparent;
  content: "";
  width: 1em;
  height: 1em;
  position: absolute;
  top: auto;
  bottom: -2em;
  left: calc(30% - .6em);
}
.souzoku-page ul.allow-down > li:first-child::after {
  border-top: .8em solid transparent;
  border-bottom: .8em solid transparent;
  border-left: .8em solid var(--orange);
  content: "";
  width: 1em;
  height: 1em;
  position: absolute;
  top: 27%;
  left: 110%;
}
.souzoku-page .text-blowing {
  margin-bottom: 4em;
}
.souzoku-page .text-side-label-box .text-box-inner {
  min-height: 3em;
  padding: 0 .5em .5em;
}
.souzoku-page .page-contents-inner > .item.flowchart {
  width: 100%;
  margin: 0 auto 4em !important;
}
.souzoku-page .item.flowchart > li:nth-of-type(2)::before {
  display: none;
}
.souzoku-page .item.row.flowchart > li:nth-of-type(1)::after {
  border-top: .8em solid var(--blue-dark-contents);
  border-right: .8em solid transparent;
  border-left: .8em solid transparent;
  top: -2em;
}
.souzoku-page .text-box > .img-block {
  margin: 2em 0;
}
.souzoku-page .page-heading .letter-one-space.orange {
  font-size: 1.125em;
}
.souzoku-page .flowchart .page-heading {
  margin-bottom: .5em;
}
.souzoku-page .flowchart .page-heading .text-red-span {
  padding: .5em;
}
.souzoku-page .text-blowing.answer .text-box-nooutline.blue .text-bold > span,
.souzoku-page .text-box-nooutline.blue .text-bold span.text-yellow {
  font-size: 1.2em;
}
.souzoku-page .text-side-label-box li {
  margin-bottom: 1em;
}
.item-annotation.text-text {
  font-size: .9em;
  margin-top: -1em;
}
.item-annotation.text-text > span,
span.item-annotation {
  background-color: var(--orange);
  border-radius: .2em;
  color: #fff;
  padding: .5em;
  position: relative;
  z-index: 2;
}
.souzoku-page .figure-chart .item-inner:nth-child(2) {
  margin-bottom: 6em;
}
.souzoku-page .figure-chart .item-inner > .text-text,
.souzoku-page .figure-chart .li .text-text {
  text-align: center;
  margin: 0 auto;
  position: relative;
}
.souzoku-page .figure-chart span.item-annotation {
  display: inline-block;
  min-width: 20em;
}
.souzoku-page .figure-chart .text-vertical span.item-annotation {
  min-width: auto;
  min-height: 15em;
  padding: .75em;
}
.souzoku-page .figure-chart .item-inner > .text-text::before,
.souzoku-page .figure-chart-vertical .text-text::before,
.souzoku-page .figure-chart-vertical .text-text::after {
  background-color: var(--blue-dark-contents);
  content: "";
  width: .2em;
  height: 8em;
  position: absolute;
  top: 100%;
  left: 50%;
}
.souzoku-page .figure-chart .figure-chart-vertical .text-text::before {
  height: 3em;
  top: -3em;
}
.souzoku-page .figure-chart .figure-chart-vertical .text-text::after {
  width: 4em;
  height: .2em;
  top: -3em;
}
.souzoku-page .figure-chart-vertical li:last-of-type .text-text::after,
.souzoku-page .figure-chart-vertical li:nth-of-type(6) .text-text::after {
  left: -84%;
}
.souzoku-page li.item-inner.figure-chart-vertical {
  margin-bottom: 1em;
}
.souzoku-page .figure-chart > ul > li:last-of-type > div {
  justify-content: center;
  margin-bottom: 4em;
}
.souzoku-page .figure-chart > ul > li:last-of-type > div p {
  width: 60%;
  margin: auto 0;
  padding-right: .5em;
}
.souzoku-page .figure-chart .text-blowing div.img-block {
  width: 6em;
}
.souzoku-page .checklist .text-box-inner > ul > li:nth-child(1) {
  margin-bottom: 4em;
}
.souzoku-page .checklist .item-inner-inner .page-heading {
  color: var(--blue-dark-contents);
}
.souzoku-page .page-contents .checklist .item-inner .item-inner {
  border-bottom: var(--blue-dark-contents) .03125em solid;
  margin: 0 0 1em 0;
  padding: .5em 0;
}
.souzoku-page p > strong {
  font-size: 1.2em;
}
.souzoku-page .item-inner.item.row > .text-box {
  width: 90%;
}
.souzoku-page .item-inner.item.row > .number-box {
  width: 10%;
  min-height: 8em;
}
ul.number-list {
  margin: 2em 0;
}
ul.number-list > li.item-inner {
  margin: 0 0 2em ;
}
.number-list .number-box {
  background-color: var(--blue-dark-contents);
  color: #fff;
  display: flex;
  justify-content: space-evenly;
  vertical-align: middle;
}
.number-box > .text-bold {
  font-size: 1.8em;
  display: block;
  margin: auto 0;
}
.number-list .page-heading {
  background-color: var(--blue-light-xxx);
  height: 100%;
  padding: 1em 0;
}
.souzoku-page .number-list .page-heading {
  height: auto;
}
.souzoku-page .text-block.blowing-text {
  max-width: 100%;
  margin: 1em 0;
}
.souzoku-page .text-block.blowing-text::before {
  border-top: none;
  border-bottom: 1em solid var(--blue-light-form);
  top: -1em;
  bottom: auto;
}
/* ==============
  固定ページ＞佐伯先生のプロフィールページ
  <article class="profile-page">
=============== */
article.profile-page .text-box .article-heading > .heading-inner {
  margin-left: 1.6em;
}
.profile-page .heading-inner .letter-one-space {
  padding-left: .5em;
}
.profile-page .item > .img-block {
  margin-bottom: 1.5em;
}
.profile-page .number-list .page-heading {
  padding: 1em;
}
.profile-page ul.number-list {
  border: #000 .07142em solid;
  margin: 0 ;
}
.profile-page .number-list li {
  border-bottom: #000 .07142em solid;
}
.profile-page .number-list li:last-of-type {
  border-bottom: none;
}
.profile-page .number-list li > div:first-of-type {
  width: 30%;
}
.profile-page .number-list li > div:last-of-type {
  width: 70%;
}
.profile-page .number-list li > div:first-of-type > span {
  margin: auto 0;
  padding: 1em;
}
.profile-page .page-contents-inner > .text-text {
  text-align: right;
}
@media screen and (min-width: 374px) {
  /* yuigon-page */
  .yuigon-page table,
  .yuigon-page .table-inner .text-text > span {
    font-size: 1em;
  }
  .yuigon-page table td.cost:before {
    content: "・・・";
    position: absolute;
    top: 10%;
    left: -3.5em;
  }
  .yuigon-page table .cost-text-inner td.cost:before {
    left: 5em;
  }
  /* souzoku-page */
  .item-annotation.text-text {
    font-size: 1em;
  }
  .souzoku-page .figure-chart span.item-annotation,
  .souzoku-page .text-side-label-box.orange .text-box span.text-orange.text-bold {
    font-size: 1.2em;
  }
  .souzoku-page .figure-chart .figure-chart-vertical .text-text::after {
    width: 9em;
  }
  .souzoku-page .figure-chart-vertical li:last-of-type .text-text::after,
  .souzoku-page .figure-chart-vertical li:nth-of-type(6) .text-text::after {
    left: -255%;
  }
  .souzoku-page ul.allow-down > li:first-child::after {
    left: 110%;
  }
}
@media screen and (min-width: 576px) {
  /* privacy-policy-page */
  .privacy-policy-page .heading-underline::before,
  .privacy-policy-page .heading-underline::after {
    width: 110%;
  }
  .privacy-policy-page .heading-underline::after {
    width: 50%;
  }
  /* yuigon-page */
  .yuigon-page table .cost-text-inner td.cost:before {
    left: 15em;
  }
  /* souzoku-page */
  .souzoku-page ul.allow-down > li:first-child::after {
    left: 127%;
  }
  .souzoku-page li.double {
    width: 42%;
  }
  .souzoku-page ul.allow-down > li:first-child::before {
    background-color: var(--orange);
    content: "";
    width: 20%;
    height: .25em;
    position: absolute;
    top: 35%;
    left: 108%;
  }
  /* family-page */
  .family-page .text-box-outline.green .page-heading > .heading-inner {
    font-size: 1.6em;
  }
}
@media screen and (min-width: 768px) {
  .page-contents.title-sideline .item > .img-block {
    margin: 0 auto ;
  }
  .text-blowing > div.text-box-outline,
  .text-blowing > div.text-box-nooutline {
    width: 83%;
    margin: auto 0;
  }
  .text-blowing.answer .text-box-nooutline.blue .text-box-inner::before {
    border-top: .8em solid transparent;
    border-left: 1.4em solid var(--blue-dark-contents);
    bottom: 2em;
    left: auto;
  }
  .souzoku-page .text-blowing > div.img-block {
    margin: auto 0 0 0;
  }
  .text-blowing.answer .text-box-outline.blue .text-box-inner::before,
  .text-blowing.answer .text-box-outline.blue .text-box-inner::after {
    border-top: .8em solid transparent;
    border-left: 1.4em solid var(--blue-dark-contents);
    right: -2.2em;
    bottom: 2em;
    left: auto;
  }
  .text-blowing.answer .text-box-outline.blue .text-box-inner::after {
    border-left: 1.4em solid #fff;
    margin-right: .125em;
    margin-bottom: 0;
  }
  article:not(.yuigon-page) table tr > td,
  article:not(.yuigon-page) table  tr > th {
    padding: .5em 1em;
  }
  .text-side-label-box .page-heading span {
    font-size: 1.2em;
  }
  .text-label-box .text-box-nooutline,
  .text-box .text-box-nooutline {
    width: 80%;
    margin: 0 auto;
  }
  .page-contents.title-sideline .item {
    flex-flow: inherit;
  }
  .page-contents.title-sideline .img-block {
    margin-bottom: 0;
  }
  .page-contents.title-sideline .item > .img-block {
    width: 38%;
  }
  .page-contents.title-sideline .item > .text-block {
    width: 60%;
  }
  .page-contents .text-side-label-box .text-box-outline {
    width: 80%;
    margin: 0 auto;
  }
  /* yuigon-page */
  .plan-yuigon ul.item {
    margin-bottom: 2em;
  }
  .yuigon-page table .cost-text-inner td.cost:before {
    left: -3.5em;
  }
  .plan-yuigon .text-box > .item > li {
    width: calc(49% - 1em);
  }
  .plan-yuigon .text-box > .item > li:nth-child(2n+1) {
    margin-right: 1em;
    margin-left: 1%;
  }
  .plan-yuigon .text-box > .item > li:nth-child(2n+2) {
    margin-right: 1%;
    margin-left: 1em;
  }
  .page-contents.plan-yuigon .text-box-outline {
    width: 100%;
    overflow: hidden;
  }
  .yuigon-page tr.cost-text-inner {
    flex-flow: row;
    margin-top: 2.2em;
  }
  .page-contents.plan-yuigon .contents-plan-inner > div:last-of-type {
    height: 18em;
  }
  .page-contents.plan-yuigon .contents-plan.blue ol {
    min-height: 15.5em;
  }
  .yuigon-page table {
    width: 45em;
    min-height: 23em;
  }
  /* family-page */

  /* contact-page */
  .three-item > li::before {
    border-top: .8em solid transparent;
    border-right: .8em solid transparent;
    border-bottom: .8em solid transparent;
    border-left: .8em solid var(--blue-dark-contents);
    top: 53%;
    left: 106%;
  }
  /* company-page */
  .item.two-item {
    flex-flow: wrap;
  }
  .item.two-item > .item-inner {
    width: calc(50% - 1em);
  }
  .item.two-item > .item-inner:nth-child(2n+1) {
    margin-right: 1em;
  }
  .item.two-item > .item-inner:nth-child(2n+2) {
    margin-left: 1em;
  }
  /* greeting-page */
  .greeting-page .text-box.item > .img-block {
    width: 33%;
  }
  .greeting-page .text-box.item > .img-block .img-inner {
    min-width: 16em;
  }
  .greeting-page .text-box.item > .text-block {
    width: 67%;
    margin-left: 2em;
  }
  .greeting-page .page-contents-inner > .text-box:first-of-type  p.text-text:first-of-type,
  .profile-page .page-contents-inner > .text-box  p.text-text:first-of-type {
    margin: 0 0 1em;
  }
  /* fudosan-page */
  .fudosan-page .text-box-nooutline {
    width: 100%;
  }
  /* souzoku-page */
  .souzoku-page .page-contents.title-sideline .item > .img-block {
    width: 33%;
  }
  .souzoku-page .page-contents .text-side-label-box .text-box-outline {
    width: 100%;
  }
  .souzoku-page .text-side-label-box .text-box-inner {
    padding: 0 1.5em 1.5em;
  }
  .souzoku-page .text-side-label-box.orange .text-box span.text-orange.text-bold {
    font-size: 1.4em;
  }
  .souzoku-page .page-contents-inner > .item.flowchart,
  .souzoku-page .text-blowing.mini,
  .souzoku-page .figure-chart {
    width: 80%;
    margin: 0 auto;
  }
  .souzoku-page .figure-chart > ul > li:last-of-type::before,
  .souzoku-page .figure-chart > ul > li:last-of-type::after {
    background-color: var(--orange);
    content: "";
    width: .2em;
    height: 8em;
    position: absolute;
    top: 0;
    left: 5%;
    transform: rotate(-20deg);
  }
  .souzoku-page .figure-chart > ul > li:last-of-type::after {
    right: 5%;
    left: auto;
    transform: rotate(20deg);
  }
  .souzoku-page .figure-chart > ul > li:last-of-type > div p {
    width: auto;
  }
  /* profile-page */
  .profile-page .page-contents-inner .text-box .item > div.img-block {
    width: 40%;
  }
  .profile-page .page-contents-inner .text-box .item > div.text-block {
    width: 60%;
    padding-left: 2em;
  }
  .profile-page .item > .img-block {
    margin-bottom: 0;
  }
  .item.reversal {
    flex-flow: row-reverse;
  }
  .profile-page .page-contents-inner .text-box .item.reversal > div.text-block {
    padding-right: 2em;
    padding-left: 0;
  }
  .profile-page .item.reversal .img-inner p {
    text-align: right;
  }
}
@media screen and (min-width: 992px) {
  .page-contents.plan-yuigon .contents-plan-inner > div:last-of-type {
    height: auto;
  }
  .page-contents.plan-yuigon .contents-plan ol,
  .page-contents.plan-yuigon .contents-plan.blue ol {
    min-height: 14em;
  }
  /* souzoku-page */
  .souzoku-page .figure-chart > ul > li:last-of-type::before,
  .souzoku-page .figure-chart > ul > li:last-of-type::after {
    left: 7%;
    transform: rotate(-25deg);
  }
  .souzoku-page .figure-chart > ul > li:last-of-type::after {
    right: 7%;
    left: auto;
    transform: rotate(25deg);
  }
}
@media screen and (min-width: 1188px) {
  .page-contents.plan-yuigon .contents-plan ol {
    font-size: .98em;
  }
}
@media screen and (min-width: 1200px) {
  .page-contents.plan-yuigon .contents-plan ol,
  .page-contents.plan-yuigon .contents-plan.blue ol {
    min-height: 12em;
  }
}
/*  */
/* 2024-09-30 */
.page-contents.plan-yuigon ol .text-small {
  text-indent: -1em;
  margin-left: 1em;
}
@media screen and (min-width: 768px) {
  .page-contents.plan-yuigon .contents-plan-inner > div:last-of-type {
    height: auto;
  }
}
/* 2025-03-06 TOPページバナー部分 */
.article-contents::before,
.article-contents::after {
  content: "";
  width: 100%;
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: -1;
}
.visual .top-link-banner a.text-link:hover {
  transform: scale(1.05);
  transition: transform .3s ease;
}

/* 2025-04-18 TOPバナー部分追加 */
.tagline {
  display: block;
  width: 18em;
  position: absolute;
  top: 28%;
  left: calc(50% - 9em);
  z-index: 2;
}
@media screen and (min-width: 768px) {
  .tagline {
    width: 33em;
    top: 33%;
    left: calc(50% - 16.5em);
  }
}

.visual .top-link-banner {
  text-align: center;
  display: block;
  margin: 0 auto;
  position: absolute;
  left: 0;
  right: 0;
  z-index: 3;
}
.visual .top-link-banner .text-inner {
    display: inline-block;
    z-index: 3;
}
.visual .top-link-banner .text-inner .text-link::before,
.visual .top-link-banner .text-inner .text-link::after {
    border: none;
}
.visual .top-link-banner .text-inner .text-link > span {
  color: #fff;
  font-size: 1em;
  font-weight: bold;
  letter-spacing: .1em;
}
@media screen and (min-width: 768px) {
  .visual .top-link-banner {
    font-size: 1em;
  }
  .visual .top-link-banner .text-inner .text-link > span {
    font-size: 1.2em;
  }
}
@media screen and (min-width: 992px) {
  .visual .top-link-banner .text-inner .text-link > span {
    font-size: 1.4em;
  }
}

.visual .top-link-banner-01 {
  top: auto;
  bottom: 22%;
}
.visual .top-link-banner-01 .text-inner .text-link {
    background-color: var(--pink-light-contents);
    box-shadow: 0px 5px 1px 0px #b85d5d;
    line-height: 1.4;
    letter-spacing: .04em;
    display: inline-block;
    padding: .5em 1.5em;
    position: relative;
    transform: scale(1);
    transition: transform .3s ease;
    z-index: 3;
}
.visual .top-link-banner-01 .text-inner .text-link::before,
.visual .top-link-banner-01 .text-inner .text-link::after {
  border-top: transparent 1.4em solid;
  border-right: transparent 1.4em solid;
  border-bottom: var(--yellow) 1.4em solid;
  border-left: var(--yellow) 1.4em solid;
  content: "";
  width: 100%;
  width: 1.6em;
  height: 1.6em;
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: 4;
}
.visual .top-link-banner-01 .text-inner .text-link::after {
  border-top: var(--yellow) 1.4em solid;
  border-right: var(--yellow) 1.4em solid;
  border-bottom: transparent 1.4em solid;
  border-left: transparent 1.4em solid;
  top: 0;
  right: 0;
  bottom: auto;
  left: auto;
  z-index: 4;
}
@media screen and (min-width: 768px) {
  .visual .top-link-banner-01 {
    bottom: 27%;
  }
  .visual .top-link-banner-01 .text-inner .text-link {
    padding: 1em 2.5em;
  }
}

.visual .top-link-banner-02 {
  top: 10%;
}
@media screen and (min-width: 768px) {
  .visual .top-link-banner-02 {
    top: 15%;
  }
}
.visual .top-link-banner-02 a.text-link {
    background-color: var(--yellow);
    box-shadow: inset 0px -2px 1px 2px #a37216;
    border-radius: 5em;
    line-height: 1.4;
    letter-spacing: .04em;
    display: inline-block;
    padding: .75em 1.5em;
    position: relative;
    transform: scale(1);
    transition: transform .3s ease;
    z-index: 3;
}
.visual .top-link-banner-02 a.text-link:hover {
  transform: scale(1.05);
  transition: transform .3s ease;
}
.visual .top-link-banner-02 .text-inner a.text-link > span {
  color: var(--blue-dark-contents);
  font-size: 1em;
  font-weight: bold;
  font-family: "M PLUS Rounded 1c",serif;
  letter-spacing: 0.05em;
}
@media screen and (min-width: 768px) {
  .visual .top-link-banner-02 a.text-link {
  box-shadow: inset 0px -5px 1px 2px #a37216;
  padding: 1.2em 2.5em;
  }
  .visual .top-link-banner-02 .text-inner  a.text-link > span {
    font-size: 1.2em;
  }
}
@media screen and (min-width: 992px) {
  .visual .top-link-banner-02 .text-inner a.text-link > span {
    font-size: 1.4em;
  }
}
.visual .top-link-banner-02 a.text-link .icon {
    font-size: .9em;
    position: relative;
    top: -.05em;
}


/*  */
