/* ##############################################################################

    KEYFRAMES

############################################################################## */
@keyframes fadezoom {
  0% {
    transform: scale(1);
  }

  100% {
    transform: scale(1.05);
  }
}

/* ##############################################################################

    COMMON

############################################################################## */

html {
  height: 100%;
  overflow-y: scroll;
  overflow-x: hidden;
}

body {
  height: 100%;
}

.subpage {
  padding-top: 88px;
}

@media print,
screen and (max-width: 1250px) {
  .subpage {
    padding-top: 64px;
  }
}

/* layout
**************************************** */

/* --- inner --- */
.inner {
  width: 90%;
  max-width: 1080px;
  margin-left: auto;
  margin-right: auto;
}

.inner-sm {
  max-width: 880px;
}

.inner-lg {
  max-width: 1440px;
}

.inner-xl {
  max-width: calc(100% - 320px);
}

.inner-xll {
  max-width: calc(100% - 160px);
}

/* --- section_pdg --- */
.section_pdg {
  padding-top: 100px;
  padding-bottom: 100px;
}

.page-contact .section_pdg,
.section_pdg-sm {
  padding-top: 40px;
  padding-bottom: 40px;
}

@media print,
screen and (max-width: 1600px) {
  .inner-xl {
    max-width: 90%;
  }
}

@media print,
screen and (max-width: 1080px) {

  /* --- inner --- */
  .inner {
    width: 90%;
  }

  .inner-xl {
    max-width: 90%;
  }
}

@media screen and (max-width: 767px) {

  /* --- inner --- */
  .inner {
    width: 86%;
  }

  .inner-xl {
    max-width: 86%;
  }

  /* --- section_pdg --- */
  .section_pdg {
    padding-top: 50px;
    padding-bottom: 50px;
  }

  .section_pdg-sm {
    padding-top: 24px;
    padding-bottom: 24px;
  }
}

/* flex
**************************************** */

/* --- ざっくりflexレイアウト --- */
.flex-col1 {
  display: block;
}

.flex-col2,
.flex-col3,
.flex-col4 {
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

.flex-col2>* {
  width: 48.5%;
  margin-right: 3%;
  margin-bottom: 3%;
}

.flex-col2>*:nth-child(even) {
  margin-right: 0;
}

.flex-col3>* {
  width: 31.33%;
  margin-right: 3%;
  margin-bottom: 3%;
}

.flex-col3>*:nth-child(3n) {
  margin-right: 0;
}

.flex-col4>* {
  width: 23.5%;
  margin-right: 2%;
  margin-bottom: 2%;
}

.flex-col4>*:nth-child(4n) {
  margin-right: 0;
}

@media screen and (max-width: 767px) {

  /* --- ざっくりflexレイアウト - sp --- */
  .flex-col2.flex-sp-block>*,
  .flex-col3.flex-sp-block>*,
  .flex-col4.flex-sp-block>* {
    width: 100%;
    margin-bottom: 16px;
    margin-right: 0;
  }

  .flex-col2.flex-sp-block>*:last-child,
  .flex-col3.flex-sp-block>*:last-child,
  .flex-col4.flex-sp-block>*:last-child {
    margin-bottom: 0;
  }

  .flex-sp-col2>*,
  .flex-sp-col2.flex-col3>*:nth-child(3n) {
    width: 48.5%;
    margin-right: 3%;
    margin-bottom: 3%;
  }

  .flex-sp-col2>*:nth-child(even) {
    margin-right: 0;
  }

  .flex-sp-col3>*,
  .flex-sp-col3.flex-col4>*:nth-child(4n) {
    width: 31.33%;
    margin-right: 3%;
    margin-bottom: 3%;
  }

  .flex-sp-col3>*:nth-child(3n) {
    margin-right: 0;
  }
}

/* bg
********************************************** */
.lps_sec:nth-child(2n) {
  background-color: #faf6f5;
}

.bg-main,
.lps_sec:nth-child(2n):not([style]) {
  background-color: #eee;
  background-image: url(/vendor/seitai-demo/generated/paper-ivory.png);
}

.bg-sub {
  background-color: #eee;
  background-image: url(/vendor/seitai-demo/generated/paper-mint.png);
}

/* img
********************************************** */
.img-ctr {
  display: block;
  margin-left: auto;
  margin-right: auto;
}

.img-trim {
  display: flex;
  justify-content: center;
  align-items: center;
}

.img-trim.pos_rel::before {
  content: "";
  display: block;
}

.img-cover {
  width: 100%;
  height: 100%;
  object-fit: cover;
  font-family: "object-fit: cover;";
}

.img-cover.pos_ab {
  top: 0;
  left: 0;
}

.img-contain {
  object-fit: contain;
  font-family: "object-fit: contain;";
}

/* ttl
********************************************** */
/* --- page_ttl --- */
.page_ttl {
  position: relative;
  z-index: 10;
  overflow: hidden;
  height: 240px;
  color: #fff;
}

.page_ttl--bg {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: -1;
  background-color: #eee;
  background-size: cover;
  background-position: center;
}

.page_ttl-jp {
  display: block;
  font-size: 300%;
  /* 48px */
}

.page_ttl-en {
  display: inline-block;
  text-transform: capitalize;
  font-size: 112.5%;
  /* 18px */
}

/* --- section_ttl --- */
.section_ttl-jp {
  position: relative;
  z-index: 2;
  display: inline-block;
  font-size: 166%;
  font-weight: normal;
  line-height: 1.3;
}

.section_ttl-sm .section_ttl-jp {
  font-size: 144%;
}

.section_ttl-sm .section_ttl-jp::before {
  margin-bottom: 18px;
}

.cta .section_ttl-jp {
  font-size: 277%;
}

.section_ttl-jp::before {
  content: "";
  position: relative;
  z-index: 2;
  display: block;
  width: 100%;
  height: 1px;
  background-color: #5dc1a8;
}

.section_ttl.txt-wh .section_ttl-jp::before {
  background-color: #fff;
}

.cta .section_ttl-jp::before {
  width: 93px;
}

.home_greetings .section_ttl-en {
  z-index: 1;
  font-size: 1277%;
  left: 40%;
  transform: translateX(-50%);
}

.section_ttl-en,
.section_ttl-en::after {
  position: absolute;
  font-weight: normal;
  top: 0;
  left: 0;
  color: rgba(173, 211, 172, 0.2);
  font-size: 1111%;
  line-height: 1;
  letter-spacing: 0;
}

.section_ttl-en::after {
  content: attr(data-en);
  font-size: 100%;
}

@media (-ms-high-contrast: none),
(-ms-high-contrast: active) {
  .section_ttl-en::after {
    display: none;
  }
}

.home_treatment .section_ttl-en {
  top: 83px;
  left: 4.3%;
  z-index: 1;
}

.section_ttl-en.txt-wh::after {
  color: #fff;
  mix-blend-mode: multiply;
  text-shadow: 0 0 50px rgba(193, 248, 228, 0.1);
}

.home_greetings .section_ttl {
  padding-top: 73px;
}

.cta .section_ttl {
  padding-top: 88px;
}

.section_ttl-jp::before {
  margin-bottom: 24px;
}

.cta .section_ttl-en {
  transform: translateY(-82px);
}

.cta--txt {
  width: 40%;
  min-width: 540px;
  flex-shrink: 0;
  padding-bottom: 80px;
  padding-right: 80px;
}

.cta--contact {
  flex: 1;
  max-width: 968px;
  padding-top: 88px;
}

.cta--contact .btn-cta a {
  height: 146px;
  max-width: none;
  justify-content: center;
  font-size: 133%;
}

.cta--contact .btn+.btn {
  margin-top: 36px;
}

@media all and (-ms-high-contrast: none) {
  .cta {
    overflow: hidden;
  }
}

/* --- ttl --- */
.ttl-01,
.ttl-02,
.ttl-03 {
  z-index: 1;
  letter-spacing: 0.1em;
}

.ttl-01 {
  font-size: 300%;
  /*48px*/
}

.ttl-01::before {
  content: "";
  display: block;
  width: 120px;
  height: 1px;
  background-color: #3cb37b;
  margin: 0 auto 40px;
}

.ttl-02 {
  padding-top: 40px;
}

.ttl-01+.ttl-02 {
  padding-top: 0;
}

.ttl-02,
.lps_parts--img_text .inner-lg .ttl-03 {
  font-size: 250%;
  /*40px*/
}

.ttl-03 {
  font-size: 175%;
  /*28px*/
}

.lps_sec .ttl-01,
.lps_sec .ttl-02,
.lps_sec .ttl-03 {
  position: relative;
}

.lps_sec .ttl-01,
.lps_sec .ttl-02,
.lps_sec .ttl-03:not(:last-child) {
  margin-bottom: 1em;
}

.lps_sec .column-3 .ttl-03,
.lps_sec .column-4 .ttl-03 {
  font-size: 160%;
  /*24px*/
}

@media print,
screen and (max-width: 1250px) and (min-width: 768px) {
  .cta--contact .btn-cta a {
    padding-right: 96px;
  }

  .btn-cta .icon-arrow {
    right: 32px !important;
  }
}

@media screen and (max-width: 767px) {

  /* --- page_ttl --- */
  .page_ttl {
    height: 120px;
  }

  .page_ttl-jp {
    font-size: 200%;
    /* 28px */
  }

  .page_ttl-en {
    font-size: 114.29%;
    /* 16px */
  }

  /* --- section_ttl --- */
  .section_ttl-jp {
    font-size: 143%;
  }

  .section_ttl-sm .section_ttl-jp {
    font-size: 144%;
  }

  .section_ttl-sm .section_ttl-jp::before {
    margin-bottom: 10px;
  }

  .cta .section_ttl-jp {
    font-size: 200%;
  }

  .cta .section_ttl-jp::before {
    width: 46px;
  }

  .home_greetings .section_ttl-en {
    font-size: 500%;
    white-space: nowrap;
    transform: translateX(-50%) translateY(36px);
  }

  .section_ttl-en,
  .section_ttl-en::after {
    font-size: 480%;
  }

  .section_ttl-en::after {
    font-size: 100%;
  }

  .home_treatment .section_ttl-en {
    top: 32px;
    left: 2%;
  }

  .section_ttl-en.txt-wh::after {
    text-shadow: 0 0 24px rgba(193, 248, 228, 0.1);
  }

  .home_greetings .section_ttl {
    padding-top: 36px;
  }

  .cta .section_ttl {
    padding-top: 30px;
  }

  .section_ttl-jp::before {
    margin-bottom: 12px;
  }

  .cta .section_ttl-en {
    transform: translateY(-28px);
  }

  .cta--txt {
    width: 100%;
    min-width: 0;
    padding-bottom: 0;
    padding-right: 0;
  }

  .cta--contact {
    padding-top: 0;
    padding-bottom: 32px;
  }

  .cta--contact .btn-cta a {
    height: 72px;
    padding: 16px 12px;
    font-size: 125%;
  }

  .cta--contact .btn+.btn {
    margin-top: 8px;
  }

  /* --- ttl --- */
  .ttl-01 {
    font-size: 214.29%;
    /*30px*/
  }

  .ttl-01::before {
    width: 62px;
    margin: 0 auto 24px;
  }

  .ttl-02,
  .lps_parts--img_text .inner-lg .ttl-03 {
    font-size: 185.71%;
    /*26px*/
  }

  .ttl-02 {
    padding-top: 24px;
  }

  .ttl-03,
  .lps_sec .column-3 .ttl-03,
  .lps_sec .column-4 .ttl-03,
  .lps_parts--img_text .inner-lg .ttl-03 {
    font-size: 171.43%;
    /*24px*/
  }
}

/* breadcrumbs
**************************************** */
.breadcrumbs {
  padding: 16px 0;
  font-size: 87%;
}

.breadcrumbs a {
  color: #3cb37b;
  text-decoration: underline;
}

.breadcrumbs a:hover {
  text-decoration: none;
}

.breadcrumbs .breadcrumb_last {
  display: table-cell;
  max-width: 280px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* txt
**************************************** */
.txt-lg {
  font-size: 112.5%;
  /*18px*/
}

.txt-sm {
  font-size: 88.888%;
  /*16px*/
}

.txt-wh,
.txt-wh * {
  color: #fff;
}

.txt-main,
.txt-main * {
  color: #3cb37b;
}

.txt-sub,
.txt-sub * {
  color: #eee;
}

/* --- font --- */
.font-jp,
.editor-ttl,
.editor-ttl2,
.editor-ttl3,
.editor-ttl4 {
  font-family: "A1明朝", serif;
}

.font-en,
.wp-pagenavi {
  font-family: "Crimson Text", serif;
}

@media screen and (max-width: 767px) {
  .txt-lg {
    font-size: 107.14%;
    /*15px*/
  }

  .txt-sm {
    font-size: 92.86%;
    /*13px*/
  }
}

/* btn
********************************************** */
.btn+.btn {
  margin-top: 8px;
}

.btn_list .btn+.btn {
  margin-top: 0;
  margin-left: 8px;
}

.btn a {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 24px 36px 24px 80px;
  border-radius: 50px;
  width: 100%;
  max-width: 317px;
  font-size: 111%;
  text-align: center;
  border: 1px solid #add3ac;
  line-height: 1.2;
  box-shadow: 0 0 20px rgba(60, 179, 123, 0.2);
  background-color: #fff;
}

.btn svg {
  fill: #3cb37b;
  transition: all 0.4s ease-out;
}

.btn a:not([target="_blank"]):not([href$=".pdf"])::after {
  content: "";
  display: block;
  flex-shrink: 0;
  width: 26px;
  height: 10px;
  margin-left: 24px;
  transition: all 0.2s ease-out;
  background: url(/vendor/seitai-demo/assets/images/common/icon-arrow01.svg);
}

.btn.btn-next_page a {
  max-width: 100%;
  border-radius: 0;
  font-size: 120%;
  text-align: left;
}

/* --- btn-cta --- */
.btn-cta a {
  max-width: 330px;
  height: 84px;
  padding: 22px 20px;
  color: #fff;
  font-size: 100%;
  border: none;
}

.header.is-scroll .btn-cta a {
  height: 64px;
}

.btn-cta a::before,
.btn-cta a::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  width: 100%;
  height: 100%;
  display: block;
  transition: 0.4s ease-out;
  border-radius: 4px;
}

.gnav--contact .btn-cta a::before,
.gnav--contact .btn-cta a::after {
  border-radius: 4px 0 0 4px;
}

.btn-cta a::before {
  background-image: linear-gradient(134deg,
      rgb(232, 166, 52) 0%,
      rgb(232, 139, 52) 100%);
}

.btn-cta a::after {
  border: 1px solid transparent;
}

.btn-line a::before {
  background-image: linear-gradient(134deg,
      rgb(86, 208, 151) 0%,
      rgb(60, 179, 123) 100%);
}

.btn-cta svg {
  margin-right: 16px;
}

.btn-cta path {
  transition: 0.4s ease-out;
}

.btn-cta .icon-arrow {
  position: absolute;
  top: calc(50% - 49px / 2);
  right: 70px;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 49px;
  height: 49px;
  border-radius: 50%;
  border: 1px solid #fff;
  transition: 0.4s ease-out;
}

.btn-cta a:hover .icon-arrow {
  border-color: #e88b34;
}

.btn-line a:hover .icon-arrow {
  border-color: #3cb37b;
}

.btn-cta .icon-arrow svg {
  width: 20px;
  margin-right: 0;
}

.btn-cta .icon-arrow path {
  fill: #fff;
}

/* --- btn-wh --- */
.btn-wh a {
  color: #333;
  background-color: #fff;
}

.btn-wh svg {
  fill: #333;
}

@media (hover: hover),
(-ms-high-contrast: none) {
  .btn a:hover {
    color: #3cb37b;
    box-shadow: 0 0 0 transparent;
  }

  .btn-cta a:hover {
    color: #e88b34;
  }

  .btn-cta a:hover::before {
    opacity: 0;
  }

  .btn-cta a:hover::after {
    border-color: #e88b34;
  }

  .btn-cta a:hover path {
    fill: #e88b34 !important;
  }

  .btn-line a:hover {
    color: #3cb37b;
  }

  .btn-line a:hover::before {
    opacity: 0;
  }

  .btn-line a:hover::after {
    border-color: #3cb37b;
  }

  .btn-line a:hover path {
    fill: #3cb37b !important;
  }

  .btn-cta a:hover .icon-arrow {
    border-color: #e88b34;
  }

  .btn-line a:hover .icon-arrow {
    border-color: #3cb37b;
  }
}

@media print,
screen and (max-width: 1850px) {
  .btn-cta a {
    justify-content: center;
    max-width: 310px;
    height: 64px;
    font-size: 90%;
  }

  .btn-cta svg {
    width: 30px;
  }
}

@media print,
screen and (max-width: 1800px) {
  .btn-cta a i {
    display: none;
  }

  .gnav--contact-txt {
    font-size: 90%;
  }
}

@media print,
screen and (max-width: 1400px) {
  .gnav--contact-txt i {
    display: block;
  }

  .btn-cta a {
    height: 54px;
    padding: 10px 14px;
  }

  .btn-cta svg {
    width: 25px;
    margin-right: 8px;
  }

  .header.is-scroll .btn-cta a {
    height: 54px;
  }
}

@media screen and (max-width: 767px) {
  .btn a {
    max-width: 100%;
    padding: 20px 44px;
  }

  .btn a:not([target="_blank"]):not([href$=".pdf"])::after {
    margin-left: 16px;
  }

  .btn.btn-next_page a {
    padding: 20px;
  }

  .btn-cta a {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1em;
  }

  .btn-cta .icon-arrow {
    top: calc(50% - 24px / 2);
    right: 16px;
    width: 24px;
    height: 24px;
  }

  .btn-cta .icon-arrow svg {
    width: 12px;
  }

  .gnav--contact-txt {
    font-size: 110%;
  }
}

@media screen and (max-width: 420px) {

  .btn-cta .icon-arrow,
  .btn-cta .icon-arrow svg {
    display: none;
  }
}

/* ##############################################################################

    HEADER

############################################################################## */

/* header
**************************************** */
.header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 9990;
  height: 169px;
  padding-right: 378px;
  transition: all 0.4s ease-out;
}

.page-contact .header {
  position: absolute;
  background-color: transparent;
  box-shadow: none;
}

.header_news {
  position: relative;
  z-index: 99999;
  background-color: #3cb37b;
  height: 32px;
  padding-top: 6px;
  margin-right: 358px;
  transition: all 0.4s ease-out;
  font-size: 100%;
  line-height: 1;
}

.header_news:hover {
  opacity: 0.7;
}

.header_news--txt {
  max-width: calc(100% - 24px);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.header_news svg {
  width: 18px;
  height: 18px;
  fill: #fff;
  margin-right: 0.5em;
}

.header_news.disable {
  height: 0;
  opacity: 0;
  padding-top: 0;
  pointer-events: none;
}

.header_news .close {
  top: 50%;
  right: 0;
  transform: translateY(-50%);
  width: 60px;
  height: 40px;
  cursor: pointer;
  transition: all 0.4s ease-out;
}

.header_news .close:hover {
  transform: translateY(-50%) rotate(180deg);
}

.header_news .close::before,
.header_news .close::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  width: 19px;
  height: 1px;
  background-color: #fff;
}

.header_news .close::before {
  transform: rotate(45deg);
}

.header_news .close::after {
  transform: rotate(-45deg);
}

.header>.inner {
  width: 100%;
  max-width: 100%;
  height: 100%;
  padding-left: 44px;
}

.header--logo {
  position: relative;
}

.header--logo a,
.footer--logo a {
  display: block;
}

.header--logo a:hover,
.footer--logo a:hover {
  opacity: 0.7;
}

.header--logo-txt {
  position: absolute;
  left: 39%;
  font-size: 83%;
  line-height: 1;
  white-space: nowrap;
  transition: all 0.4s ease-out;
}

.subpage .header,
.header.is-scroll {
  height: 88px !important;
  background-color: #fff;
}

.subpage .header--logo img,
.header.is-scroll .header--logo img {
  width: 210px;
}

.subpage .header--logo-txt,
.header.is-scroll .header--logo-txt {
  font-size: 70%;
}

.header.is-scroll .gnav--contact {
  padding-bottom: 96px;
}

@media print,
screen and (min-width: 1251px) {

  .header--nav,
  .gnav,
  .gnav>.flex,
  .gnav--menu,
  .gnav--menu li,
  .gnav--link {
    height: 100%;
  }
}

@media print,
screen and (max-width: 1850px) {
  .header>.inner {
    padding-left: 30px;
  }

  .header_news {
    margin-right: 334px;
  }
}

@media print,
screen and (max-width: 1800px) {
  .header {
    height: 120px;
    padding-right: 312px;
  }

  .header_news {
    margin-right: 305px;
  }

  .header--logo {
    width: 250px;
  }

  .header--logo-txt {
    font-size: 70%;
  }
}

@media print,
screen and (max-width: 1550px) {
  .header--logo {
    width: 180px;
  }
}

@media print,
screen and (max-width: 1400px) {
  .header {
    padding-right: 240px;
  }

  .header_news {
    margin-right: 230px;
  }
}

@media print,
screen and (max-width: 1300px) {
  .header--logo {
    width: 130px;
  }

  .header--logo-txt {
    display: none;
  }
}

@media print,
screen and (max-width: 1250px) {
  .header {
    top: 32px;
    height: 64px;
    padding-right: 140px;
  }

  .subpage .header,
  .header.is-scroll {
    top: 0;
    height: 64px !important;
  }

  .header_news {
    margin-right: 0;
  }

  .header_news {
    -webkit-order: 2;
    order: 2;
  }

  .header_news svg {
    width: 17px;
    height: 17px;
  }

  .header_news .close::before,
  .header_news .close::after {
    width: 15px;
  }

  .header>.inner {
    padding-left: 12px;
  }

  .header--logo-txt {
    display: block;
    font-size: 9px;
  }
}

@media screen and (max-width: 428px) {
  .header_news .close {
    width: 30px;
  }
}

/* gnav
********************************************** */
.gnav .gnav--link {
  display: flex;
  justify-content: center;
  align-items: center;
}

.gnav--link {
  padding: 0 16px;
  font-size: 94%;
}

.gnav--link[href="javascript:void(0);"] {
  cursor: inherit;
}

.gnav--link span {
  position: relative;
  display: inline-block;
}

.gnav--link span::before {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  display: block;
  height: 2px;
  background-color: #3cb37b;
  opacity: 0;
  transform: translateY(4px);
  transition: 0.4s ease-out;
}

.gnav_sub_toggle {
  display: none;
  cursor: pointer;
}

.sub_nav-link {
  position: relative;
}

.head_sub_nav li:not(:last-child) {
  border-bottom: 1px solid #eee;
}

.head_sub_nav a {
  display: block;
  padding: 16px 24px;
}

.gnav_sub--wrap {
  background-color: #fff;
  position: absolute;
  z-index: 9999;
  left: 6%;
  right: 6%;
  width: 88%;
  display: none;
  box-shadow: 0 0 50px rgb(236 223 189 / 15%);
}

.gnav_sub--inner {
  align-items: center;
}

.gnav_sub--li {
  position: relative;
}

.gnav_sub--li:nth-child(-n + 3)::after {
  content: "";
  display: block;
  position: absolute;
  bottom: 0;
  height: 1px;
  background-color: #eaeaea;
  left: 0;
  right: 0;
}

.gnav_sub--li:nth-child(1)::after {
  right: 20px;
}

.gnav_sub--li:nth-child(2)::after {
  right: 20px;
  left: 20px;
}

.gnav_sub--li:nth-child(3)::after {
  left: 20px;
}

.gnav_sub--wrap .gnav_sub--title {
  width: 20%;
  font-size: 160%;
  text-align: center;
  font-family: A1明朝, serif;
}

.gnav_sub--wrap .gnav_sub--title::after {
  content: "";
  position: absolute;
  background-color: #5dc2aa;
  width: 1px;
  top: 32px;
  bottom: 32px;
  margin-left: 32px;
}

.gnav_sub--wrap .gnav_sub--list {
  align-items: center;
  width: 80%;
}

.gnav_sub--wrap .gnav_sub--list .gnav_sub--box .gnav_sub--li {
  width: 33.33%;
  height: auto;
  padding: 32px 0 32px 64px;
  margin-left: 0;
  min-height: 300px;
}

.gnav_sub--li:nth-child(n + 4) .gnav_sub--line {
  bottom: 20px;
  top: 20px;
}

.gnav_sub--list .gnav_sub_ttl-en {
  position: absolute;
  font-weight: normal;
  right: 0;
  color: rgba(173, 211, 172, 0.2);
  font-size: 820%;
  line-height: 1;
  letter-spacing: 0.06em;
  bottom: 0;
}

.gnav_sub--line {
  position: absolute;
  width: 1px;
  background-color: #eaeaea;
  right: 0;
  top: 20px;
  bottom: 20px;
}

.gnav_sub--link,
.side--cat--link {
  text-decoration: underline;
}

.gnav_sub--li:nth-child(n + 4) .gnav_sub--line {
  bottom: 20px;
  top: 20px;
}

.gnav_sub--li:nth-child(3n) .gnav_sub--line {
  display: none;
}

.gnav_sub--li::before {
  left: 32px !important;
  top: 48px !important;
}

.gnav_sub--child .sidebar-child_cat {
  padding-bottom: 0;
}

.sidebar-child_cat a {
  text-decoration: underline !important;
}

/* ---CTA --- */
.cta_tel--txt {
  display: inline-block;
  padding: 8px 16px;
  font-size: 88%;
  line-height: 1;
  border-radius: 50px;
  border: 1px solid;
}

.cta--txtarea {
  line-height: 2;
}

.cta_tel a {
  display: inline-flex !important;
  flex-direction: column;
  justify-content: center;
  align-items: flex-end;
  line-height: 1;
}

.cta_tel a>span {
  display: block;
}

.cta_tel .tel {
  font-size: 177%;
  line-height: 1;
}

.cta_tel .num {
  font-size: 197%;
}

.gnav--cta {
  margin-left: 24px;
}

.gnav--tel {
  position: fixed;
  margin-top: 24px;
  right: 2%;
}

.gnav--tel a {
  align-items: flex-end;
}

.gnav--cta .is-scroll {
  padding: 20px 0 96px 20px;
}

.gnav--contact {
  position: fixed;
  right: 0;
  padding: 28px 0 23px 28px;
  background-color: #fff;
  transition: all 0.4s ease-out;
}

.gnav--contact-txt {
  line-height: 1;
}

.gnav--contact-txt .red {
  color: #e84934;
  font-size: 127%;
}

.gnav--cta .tel {
  font-size: 105%;
}

.gnav--cta .num {
  font-size: 211%;
}

.gnav--cta .hours {
  font-size: 88%;
}

@media print,
screen and (min-width: 1251px) {
  .gnav {
    display: flex;
  }

  .gnav_btn,
  .cta_btn {
    display: none;
  }

  .gnav--link:not([href="javascript:void(0);"]):hover,
  .gnav--menu li.current>.gnav--link {
    color: #3cb37b;
  }

  .gnav--link:not([href="javascript:void(0);"]):hover span::before,
  .gnav--menu li.current>.gnav--link span::before {
    opacity: 1;
    transform: translateY(0);
  }

  .head_sub_nav a {
    background-color: #fff;
  }

  /* hover */
  .gnav--menu .sub_nav-link:hover .head_sub_nav--wrap {
    opacity: 1;
    pointer-events: auto;
  }

  .gnav--menu .head_sub_nav a:hover {
    opacity: 0.7;
  }
}

@media print,
screen and (max-width: 1850px) {
  .gnav--cta .tel {
    font-size: 95%;
  }

  .gnav--contact {
    padding: 20px 0 15px 20px;
  }
}

@media print,
screen and (max-width: 1800px) {
  .gnav--link {
    padding: 0 10px;
    font-size: 87%;
  }

  .gnav--cta .tel {
    font-size: 85%;
  }

  .gnav--cta .hours {
    font-size: 70%;
  }
}

@media print,
screen and (max-width: 1550px) {
  .gnav--link {
    font-size: 80%;
  }

  .gnav--cta .tel {
    font-size: 80%;
  }
}

@media print,
screen and (max-width: 1400px) {
  .gnav--cta {
    margin-left: 8px;
  }

  .gnav--cta .tel {
    font-size: 70%;
  }

  .gnav_sub--list .gnav_sub_ttl-en {
    font-size: 600%;
  }

  .gnav_sub--wrap .gnav_sub--title {
    font-size: 160%;
  }
}

@media print,
screen and (max-width: 1250px) {

  .gnav,
  .gnav_overlay {
    position: fixed;
    top: 96px;
    right: 0;
    height: calc(100% - 64px);
    opacity: 0;
    pointer-events: none;
    transition: all 0.4s ease-out;
  }

  .subpage .gnav,
  .is-scroll .gnav,
  .subpage .gnav_overlay,
  .is-scroll .gnav_overlay {
    top: 64px;
  }

  .gnav {
    width: 70%;
    margin: 0;
    padding: 24px 7%;
    overflow: scroll;
    background-color: #eee;
    background-image: url(/vendor/seitai-demo/generated/paper-ivory.png);
    z-index: 300;
    transform: translateX(100%);
    -webkit-overflow-scrolling: touch;
  }

  .gnav_overlay {
    width: 100%;
    background-color: rgba(255, 255, 255, 0.8);
  }

  .gnav.active,
  .gnav_overlay.active {
    opacity: 1;
    pointer-events: auto;
  }

  .gnav.active {
    transform: translateX(0);
  }

  .gnav--menu,
  .gnav--cta {
    display: block;
  }

  .gnav--menu li {
    position: relative;
    display: block;
    width: 100%;
  }

  .gnav--menu li:not(:last-child) {
    border-bottom: 1px dotted #3cb37b;
  }

  .gnav--menu a {
    display: block;
    padding: 12px 8px;
  }

  .gnav--menu li:not(.sub_nav-link) a::before {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    right: 10px;
    margin: auto;
    width: 7px;
    height: 7px;
    border-top: 1px solid #3cb37b;
    border-right: 1px solid #3cb37b;
    transform: rotate(45deg);
  }

  .gnav--link {
    font-size: 100%;
  }

  .head_sub_nav--wrap {
    position: relative;
    width: 100%;
    border-top: 1px dotted #3cb37b;
    transition: none;
    opacity: 1;
    pointer-events: inherit;
    display: none;
  }

  .sub_nav-link.active .head_sub_nav--wrap {
    opacity: 1;
    pointer-events: auto;
  }

  .head_sub_nav a {
    padding-left: 32px;
  }

  .gnav_sub_toggle {
    position: absolute;
    top: 0;
    right: -15px;
    display: -webkit-flex;
    display: flex;
    -webkit-justify-content: center;
    justify-content: center;
    -webkit-align-items: center;
    align-items: center;
    font-size: 10px;
    width: 54px;
    height: 54px;
    transition: all 0.4s ease-out;
    color: #3cb37b;
  }

  .gnav_sub_toggle::before,
  .gnav_sub_toggle::after {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    margin: auto;
    width: 11px;
    height: 1px;
    border-bottom: 1px solid;
  }

  .gnav_sub_toggle::after {
    transform: rotate(90deg);
  }

  .gnav_sub_toggle.active {
    transform: rotate(180deg);
  }

  /* .current .gnav_sub_toggle {
    color: #fff;
  } */
  .head_sub_nav {
    position: relative;
  }

  .cta_btn,
  .gnav_btn {
    position: fixed;
    top: 32px;
    width: 64px;
    height: 64px;
    border-left: 1px solid #e7e5e4;
    z-index: 9999999;
    transition: all 0.4s ease-out;
  }

  .subpage .cta_btn,
  .is-scroll .cta_btn,
  .subpage .gnav_btn,
  .is-scroll .gnav_btn {
    top: 0;
  }

  .cta_btn {
    right: 0;
  }

  .cta_btn a {
    display: flex !important;
    width: 100%;
    height: 100%;
    padding: 18px;
    background-image: linear-gradient(134deg,
        rgb(86, 208, 151) 0%,
        rgb(60, 179, 123) 100%);
  }

  .cta_btn svg {
    fill: #3cb37b;
  }

  .gnav_btn {
    right: 64px;
  }

  .gnav_btn.active {
    background-color: #eee;
    background-image: url(/vendor/seitai-demo/generated/paper-ivory.png);
  }

  .gnav_btn--lines {
    position: relative;
    width: 24px;
    height: 16px;
  }

  .gnav_btn--lines span {
    transition: all 0.4s ease-out;
    box-sizing: border-box;
  }

  .gnav_btn--lines span {
    position: absolute;
    left: 0;
    width: 100%;
    height: 2px;
    background-color: #3cb37b;
  }

  .gnav_btn--lines span:nth-of-type(1) {
    top: 0;
  }

  .gnav_btn--lines span:nth-of-type(2) {
    top: 7px;
  }

  .gnav_btn--lines span:nth-of-type(3) {
    bottom: 0;
  }

  .active .gnav_btn--lines span:nth-of-type(1) {
    transform: translateY(7px) rotate(-45deg);
  }

  .active .gnav_btn--lines span:nth-of-type(2) {
    opacity: 0;
  }

  .active .gnav_btn--lines span:nth-of-type(3) {
    transform: translateY(-7px) rotate(45deg);
  }

  .gnav_sub--wrap {
    position: relative;
    background: none;
    left: 0;
    right: 0;
    width: 100%;
  }

  .gnav_sub--title,
  .gnav_sub--line {
    display: none;
  }

  .gnav .gnav--link {
    justify-content: flex-start;
  }

  .gnav_sub--inner {
    display: block;
  }

  .gnav_sub--wrap .gnav_sub--list {
    width: 100%;
  }

  .gnav_sub--box {
    display: block;
  }

  .gnav_sub--wrap .gnav_sub--list .gnav_sub--box .gnav_sub--li {
    width: 100%;
    padding: 0 0 0 24px;
    margin: 4px 0;
    min-height: 0;
    border-top: 1px solid #e6e6e6;
  }

  .gnav_sub--li a {
    font-weight: normal;
    font-family: "こぶりなゴシック W3 JIS2004";
    font-size: 100%;
    padding: 8px 0;
  }

  .list li::before {
    width: 4px !important;
    height: 4px !important;
  }

  .gnav_sub--li::before {
    left: 10px !important;
    top: 20px !important;
  }

  .gnav_sub--child {
    display: none;
  }

  .gnav_sub--child li::before {
    top: 20px !important;
    height: 1px !important;
    width: 8px !important;
  }

  /* .gnav--menu .gnav_sub--box li:not(.sub_nav-link) a::before {
    display: none;
  } */
  .gnav--menu .gnav_sub--box li:not(:last-child) {
    border-bottom: none;
  }

  .gnav_sub--li:last-child {
    padding-bottom: 10px;
  }

  .gnav_sub--list .gnav_sub_ttl-en {
    display: none;
  }

  .gnav_sub_toggle.active::after {
    display: none;
  }

  .gnav_sub_toggle {
    top: -3px;
  }

  .gnav_sub--li:nth-child(-n + 3)::after {
    display: none;
  }

  .menu-item-has-children>a::before,
  .gnav_sub--li.child a::before {
    display: none;
  }

  /* ---CTA --- */
  .gnav--contact {
    width: 100%;
    padding: 32px 16px 40px;
    background-color: transparent;
  }

  .gnav--cta .is-scroll {
    padding: 32px 16px 40px;
  }

  .cta_tel {
    text-align: center;
  }

  .gnav--tel {
    position: relative;
    margin-top: 0;
    right: 0;
  }

  .cta_tel .num {
    font-size: 140%;
    white-space: nowrap;
  }

  .gnav--cta .tel {
    margin-top: 16px;
    font-size: 130%;
    white-space: nowrap;
  }

  .gnav--contact .btn-cta a::before,
  .gnav--contact .btn-cta a::after {
    border-radius: 4px;
  }
}

@media screen and (max-width: 340px) {

  /* ---CTA --- */
  .gnav--cta .tel {
    font-size: 120%;
  }
}

/* ##############################################################################

    FOOTER

############################################################################## */

.footer {
  background-color: #eee;
}

/* fnav
********************************************** */
.fnav {
  margin-left: -16px;
  margin-right: -16px;
}

.footer--lft {
  width: 50%;
}

.footer--inner {
  margin-left: 100px;
  margin-right: 80px;
}

.footer--address {
  line-height: 1.6;
}

.footer--address .tel .txt-lg {
  font-size: 126%;
}

.footer--info {
  max-width: 556px;
  line-height: 1.75;
}

.info_table td {
  padding: 1.3em 0.7em !important;
  text-align: center;
  line-height: 1 !important;
}

.footer--map {
  position: relative;
  width: 50%;
  overflow: hidden;
}

.footer--map iframe {
  width: 140%;
  height: 140%;
  position: absolute;
  top: -20%;
  left: -20%;
  z-index: 0;
}

@media print,
screen and (max-width: 1700px) {
  .footer--inner {
    margin-left: 64px;
    margin-right: 64px;
  }
}

@media screen and (max-width: 767px) {
  .footer--logo img {
    width: 150px;
  }

  .fnav {
    margin-left: 8px;
    margin-right: 8px;
  }

  .fnav .gnav {
    position: static;
    width: 100%;
    height: auto;
    padding: 0;
    transform: translateX(0);
    opacity: 1;
    pointer-events: auto;
  }

  .fnav .gnav--menu {
    text-align: left;
  }

  .fnav .gnav a {
    justify-content: left;
  }

  .footer--lft {
    width: 100%;
  }

  .footer--inner {
    margin-left: 24px;
    margin-right: 24px;
  }

  .footer--address .tel .txt-lg {
    font-size: 126%;
  }

  .info_table {
    width: 100%;
    margin-top: 24px;
  }

  .info_table tbody {
    display: flex;
  }

  .info_table tr:first-child {
    width: 35%;
  }

  .info_table tr:last-child {
    width: 65%;
  }

  .info_table th,
  .info_table td {
    display: flex;
    justify-content: center;
    align-items: center;
    height: 40px;
    padding: 0;
    border-top: 1px solid #add3ac;
  }

  .info_table td {
    border-right: 1px solid #add3ac;
  }

  .footer--map {
    width: 100%;
    height: 300px;
  }

  .footer--map iframe {
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
  }
}

/* footer--sub_nav
*************************************************** */
.footer--sub_nav {
  padding: 16px 0;
}

.footer--sub_nav .inner::before {
  content: "";
  display: block;
}

.footer--copyright {
  display: inline-block;
  font-size: 66%;
  line-height: 1;
}

.pbl {
  display: block;
  line-height: 1;
  opacity: 0.5;
}

.pbl:hover {
  opacity: 1;
}

@media screen and (max-width: 767px) {
  .footer--sub_nav .flex-j-end {
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    justify-content: center;
  }

  .pbl {
    margin-top: 12px;
  }
}

/* ##############################################################################

    INDEX

############################################################################## */

.txtarea p:not(:last-child) {
  margin-bottom: 2em;
}

/* hero
********************************************** */
.hero {
  position: relative;
  z-index: 5;
}

.hero::before {
  content: "";
  display: block;
  padding-top: 54.687%;
  min-height: 800px;
  max-height: 1050px;
  pointer-events: none;
}

.hero--cont {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 1;
  padding-top: 15%;
  pointer-events: none;
}

.hero--catch {
  font-size: 400%;
  line-height: 1.6;
  letter-spacing: 0.1em;
  pointer-events: auto;
}

.hero--catch .txt-vertical-brackets {
  font-size: 66.5%;
}

.hero--catch .txt-vertical-brackets-open {
  vertical-align: 24px;
}

.hero--lead {
  font-size: 111%;
  line-height: 2;
  pointer-events: none;
}

.hero_slides {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 0;
}

.hero_slide {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  overflow: hidden;
}

.hero_slides::before,
.hero_slides::after {
  content: "";
  position: absolute;
  top: 0;
  z-index: 1;
  display: block;
  height: 100%;
}

.hero_slides::before {
  left: 0;
  width: 711px;
  background-image: url(/vendor/seitai-demo/generated/decor-hero-wash-left.svg);
  background-position: top right;
  background-size: cover;
}

.hero_slides::after {
  right: 0;
  width: 786px;
  background-image: url(/vendor/seitai-demo/generated/decor-hero-wash-right.svg);
  background-position: top left;
  background-size: cover;
}

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

.hero_slides,
.hero_slide,
.hero_slide .slick-list,
.hero_slide .slick-track,
.hero_slide .slick-slider,
.hero_slide .slick-slide {
  width: 100%;
  height: 100%;
}

.hero_slide .slick-list {
  position: relative;
  overflow: hidden;
}

.slide-animation {
  animation: fadezoom 8s 0s forwards;
}

/* hero_slide--dots */
.hero_slide--dots {
  position: absolute;
  right: 54px;
  bottom: 273px;
  z-index: 2;
}

.hero_slide--dots .slick-dots {
  display: flex;
  align-items: center;
}

.hero_slide--dots li {
  display: block;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 60px;
  height: 60px;
  color: #fff;
  font-size: 133%;
  line-height: 1;
  letter-spacing: 0;
  border-radius: 50%;
  background-color: transparent;
  transition: 0.4s ease-out;
  cursor: pointer;
}

.hero_slide--dots .slick-active {
  color: #3cb37b;
  background-color: #fff;
}

.hero_slide--dots li:not(:last-child) {
  margin-right: 8px;
}

/* hero--scroll */
.hero--scroll {
  position: absolute;
  left: 50%;
  bottom: 0;
  width: 1px;
  height: 152px;
}

.hero--scroll span {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  background-color: #fff;
  overflow: hidden;
}

.hero--scroll span::before {
  content: "";
  display: block;
  width: 100%;
  height: 150%;
  background-color: #3cb37b;
  transform: translateY(-150%);
  animation: hero_scroll 3s linear infinite;
}

@keyframes hero_scroll {
  0% {
    transform: translateY(-150%);
  }

  100% {
    transform: translateY(150%);
  }
}

.hero--scroll .font-en {
  position: absolute;
  top: 0;
  right: -1.5em;
  line-height: 1;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
}

/* hero--cta */
.hero--cta {
  position: absolute;
  right: 0;
  bottom: -40px;
  width: 35%;
  min-width: 630px;
  max-width: 630px;
  background-color: #fff;
  padding: 32px 40px;
  border-radius: 4px 0 0 4px;
}

.hero--cta::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 0;
  display: block;
  box-shadow: 0 0 50px #ecdfbd;
  background-color: #ffffff;
  mix-blend-mode: multiply;
  pointer-events: none;
}

.hero--cta table {
  width: 100%;
  margin-bottom: 24px;
}

.hero--cta .btn_list li {
  width: 49%;
}

.hero--cta-btn a {
  max-width: none;
  padding: 12px 36px;
  color: #3cb37b;
  font-size: 88%;
  border: 1px solid;
  box-shadow: none;
  justify-content: center;
}

.hero--cta-btn a img {
  margin-right: 8px;
}

.hero--cta-btn a::after {
  display: none !important;
}

.hero--cta-btn-form a {
  color: #e88b34 !important;
}

.hero--cta-btn a:hover {
  opacity: 0.8;
}

@media print,
screen and (max-width: 1440px) {
  .hero--catch {
    font-size: 300%;
  }

  .hero--lead {
    font-size: 100%;
  }
}

@media print,
screen and (max-width: 1366px) {
  .hero--scroll {
    display: none;
  }
}

@media print,
screen and (max-width: 1160px) {
  .hero--cta {
    display: none;
  }

  /* hero_slide--dots */
  .hero_slide--dots {
    right: 16px;
    bottom: 94px;
  }

  .hero_slide--dots li {
    width: 30px;
    height: 30px;
    font-size: 100%;
  }

  /* hero--scroll */
  .hero--scroll {
    display: block;
    left: auto;
    right: 48px;
    height: 80px;
  }
}

@media screen and (max-width: 767px) {
  .hero::before {
    min-height: 640px;
  }

  .hero_slide-pc {
    display: none !important;
  }

  .hero_slide-sp {
    display: block !important;
  }

  .hero--cont {
    left: -3%;
    padding-top: 96px;
    text-shadow: 1px 1px 2px #fff, 0 0 1em #fff, 0 0 0.2em #fff;
  }

  .hero--catch {
    font-size: 200%;
  }

  .hero--catch .txt-vertical-brackets-open {
    vertical-align: 12px;
  }

  .hero--lead {
    width: 85%;
    font-size: 100%;
    line-height: 1.8;
    letter-spacing: 0.02em;
  }

  .hero--lead br {
    display: none;
  }

  .hero_slides::before {
    width: 40%;
  }

  .hero_slides::after {
    width: 40%;
  }
}

/* home_greetings
********************************************** */
.bg-konoha-l::after,
.bg-konoha-r::after {
  content: "";
  position: absolute;
  top: 0;
  display: block;
}

.bg-konoha-l::after {
  top: -38px;
  left: 0;
  width: 250px;
  height: 519px;
  background-image: url(/vendor/seitai-demo/generated/decor-leaves-left.svg);
}

.bg-konoha-r::after {
  right: 0;
  width: 376px;
  height: 494px;
  background-image: url(/vendor/seitai-demo/generated/decor-leaves-right.svg);
}

.home_greetings {
  z-index: 2;
  background-image: url(/vendor/seitai-demo/generated/decor-greetings-wash.svg),
    url(/vendor/seitai-demo/generated/paper-ivory.png);
  background-position: top right, center;
  background-repeat: no-repeat, repeat;
  background-size: contain, auto;
}

.home_greetings::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  z-index: 0;
  display: block;
  width: 60%;
  max-width: 1070px;
  background-color: #ecfdf1;
  mix-blend-mode: multiply;
}

.home_greetings--imgarea img {
  position: relative;
  top: 76px;
  z-index: 0;
}

.home_greetings--cont {
  flex: 1;
  margin-left: auto;
  padding-bottom: 357px;
  padding-left: 6%;
}

.home_greetings--cont .inner {
  max-width: 604px;
  margin-left: 0;
}

.home_greetings--txtarea {
  position: relative;
  z-index: 1;
  padding-left: 1em;
}

.home_greetings--cont img {
  position: absolute;
}

.home_greetings--cont .img02 {
  left: 53%;
  bottom: -4%;
  width: 22.91%;
  max-width: 440px;
}

.home_greetings--cont .img03 {
  right: 0;
  bottom: 8%;
  width: 16.6%;
  max-width: 319px;
}

.home_greetings--imgarea {
  width: 47%;
  max-width: 853px;
  margin-right: auto;
}

@media screen and (max-width: 767px) {
  .bg-konoha-l::after {
    top: -19px;
    width: 125px;
    height: 260px;
    background-size: contain;
  }

  .bg-konoha-r::after {
    width: 188px;
    height: 247px;
    background-size: contain;
  }

  .home_greetings::before {
    width: 20%;
    z-index: -1;
  }

  .home_greetings--imgarea {
    width: 70%;
  }

  .home_greetings--imgarea img {
    position: static;
    top: 0;
    transform: translateY(-17%);
  }

  .home_greetings--txtarea p {
    font-size: 108%;
  }

  .home_greetings--cont {
    padding-bottom: 48px;
  }

  .home_greetings--cont .inner {
    width: 90%;
    margin-left: 3%;
  }

  .home_greetings--cont .img02 {
    bottom: 11%;
    width: 35%;
    z-index: 2;
  }

  .home_greetings--cont .img03 {
    bottom: 26%;
    width: 33%;
    z-index: 2;
  }
}

/* home_treatment
********************************************** */
.home_treatment {
  z-index: 1;
  padding-top: 220px;
  background-image: url(/vendor/seitai-demo/generated/decor-treatment-wash.svg),
    url(/vendor/seitai-demo/generated/paper-ivory.png);
  background-position: top left, center;
  background-repeat: no-repeat, repeat;
  background-size: contain, auto;
}

.home_treatment--cont {
  width: 40%;
  flex: 1;
}

.home_treatment--cont .inner {
  max-width: 644px;
  width: 80%;
  margin-right: 0;
  padding-left: 10%;
}

.home_treatment--cont .btn a {
  max-width: 400px;
}

.home_treatment--imgarea-ttl span {
  position: relative;
  display: inline-block;
  padding-top: 64px;
  font-size: 166%;
  line-height: 1;
}

.home_treatment--imgarea-ttl span::before {
  content: "";
  position: absolute;
  top: -1px;
  left: 0;
  right: 0;
  display: block;
  background-color: #3cb37b;
  height: 10px;
}

.home_treatment--imgarea {
  position: relative;
  overflow: hidden;
  width: 55%;
  max-width: 1058px;
  margin-left: 6%;
  padding: 0 0 100px 56px;
  border-left: 1px solid #add3ac;
  border-top: 1px solid #add3ac;
  border-radius: 4px 0 0 0;
}

.home_treatment--imgarea::before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-image: url(/vendor/seitai-demo/generated/paper-mint.png);
  mix-blend-mode: multiply;
  border-radius: 4px 0 0 0;
}

.treatment-card {
  max-width: 409px;
}

.treatment-card--img {
  border-radius: 4px 4px 0 0;
}

.treatment-card--icon {
  position: absolute;
  top: -112px;
  left: calc(50% - 130px / 2);
  display: block;
  width: 130px;
  height: 130px;
  padding: 13px;
  margin: auto;
  background-color: #3cb37b;
  border-radius: 4px;
}

.treatment-card--icon span {
  display: block;
  font-size: 111%;
  line-height: 1;
}

.treatment-card--icon i {
  font-size: 149%;
}

.treatment-card--txtarea {
  padding: 48px 40px 40px;
  border-radius: 0 0 4px 04px;
}

.treatment-card--txtarea p {
  line-height: 1.75;
}

/* slide-treatment */
.slide_wrap {
  position: relative;
  overflow: hidden;
}

.slide-treatment {
  max-width: 409px;
}

.slide-treatment img {
  display: inline-block;
}

.slide-treatment .slick-list {
  margin-bottom: 35px;
  margin-left: -24px;
  overflow: visible !important;
}

.slide-treatment .slick-slide {
  margin-left: 24px;
}

.slide-treatment .slick-dots {
  justify-content: flex-start;
}

.slide-treatment--ttl {
  font-size: 144%;
}

.slide-treatment--arrows {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  pointer-events: none;
}

.slide-treatment--arrows .slick-arrow {
  height: 82px;
  pointer-events: auto;
}

.slide-treatment--arrows .slick-prev {
  left: 17px;
}

.slide-treatment--arrows .slick-next {
  left: 868px;
}

@media print,
screen and (max-width: 1760px) {
  .slide-treatment--arrows .slick-next {
    left: auto;
    right: 4%;
  }

  .home_treatment--cont .inner {
    padding-left: 0;
  }
}

@media print,
screen and (max-width: 1366px) {
  .home_treatment--cont {
    width: 60%;
  }

  .home_treatment--imgarea {
    width: 40%;
  }
}

@media screen and (max-width: 767px) {
  .home_treatment {
    padding-top: 80px;
  }

  .home_treatment--cont {
    width: 100%;
  }

  .home_treatment--cont .inner {
    width: 80%;
    padding-left: 0;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 64px;
  }

  .home_treatment--cont .btn a {
    max-width: 400px;
  }

  .home_treatment--imgarea-ttl span {
    padding-top: 32px;
    font-size: 125%;
  }

  .home_treatment--imgarea-ttl span::before {
    height: 6px;
  }

  .home_treatment--imgarea {
    width: 90%;
    margin-left: auto;
    margin-right: auto;
    padding: 0 24px 40px;
    border-radius: 4px 4px 0 0;
    border-right: 1px solid #add3ac;
  }

  .home_treatment--imgarea::before {
    border-radius: 4px 4px 0 0;
  }

  .treatment-card--img {
    border-radius: 4px 4px 0 0;
  }

  .treatment-card--icon {
    top: -72px;
    left: calc(50% - 80px / 2);
    width: 80px;
    height: 80px;
    padding: 10px;
  }

  .treatment-card--icon span {
    font-size: 80%;
  }

  .treatment-card--icon img {
    transform: scale(0.65, 0.65) translateY(-35%);
  }

  .treatment-card--txtarea {
    padding: 28px 24px 24px;
  }

  /* slide-treatment */
  .slide-treatment .slick-list {
    margin-bottom: 24px;
  }

  .slide-treatment--arrows .slick-next {
    right: 4px;
  }

  .slide-treatment--arrows .slick-prev {
    left: 4px;
  }
}

/* home_strengths
********************************************** */
.home_strengths--ttl {
  max-height: 804px;
  padding-top: 41%;
  background-image: linear-gradient(rgba(255, 249, 243, 0.1), rgba(255, 249, 243, 0.1)), url(/vendor/seitai-demo/generated/strengths-bg.jpg);
  background-size: cover;
}

.home_strengths--ttl .section_ttl {
  position: absolute;
  left: 50%;
  bottom: 0;
  z-index: 2;
  padding-bottom: 164px;
  transform: translateX(-50%);
}

.home_strengths--ttl .section_ttl-en {
  top: auto;
  bottom: -35px;
}

.home_strengths--points li {
  background-repeat: no-repeat;
  background-size: contain;
}

.home_strengths--points li:nth-child(2n + 1) {
  background-image: url(/vendor/seitai-demo/generated/decor-strengths-odd.svg);
  background-position: top left;
}

.home_strengths--points li:nth-child(2n) {
  background-image: url(/vendor/seitai-demo/generated/decor-strengths-even.svg);
  background-position: top right;
}

/* points_box */
.points_box>.inner {
  max-width: 1560px;
  background-color: #fff;
}

.points_box--num {
  display: flex;
  align-items: center;
  font-size: 311%;
  line-height: 1;
}

.points_box--num::after {
  content: "";
  display: block;
  flex: 1;
  height: 1px;
  margin-left: 32px;
  background-color: #3cb37b;
}

.points_box--num i {
  font-size: 160%;
}

.points_box--txt {
  margin-right: 47%;
  padding: 117px;
}

.flex-reverse .points_box--txt {
  margin-left: 47%;
  margin-right: 0;
}

.points_box--txt .ttl-02,
.points_box--txt p,
.points_box--txt .btn {
  margin-left: 28px;
}

.points_box--img {
  position: absolute;
  top: 70px;
  width: 50%;
  max-width: 940px;
}

.home_strengths--points li:not(:last-child) {
  margin-bottom: 100px;
}

.home_strengths--points li:nth-child(2n) .points_box--img {
  bottom: 0;
  left: 0;
}

.home_strengths--points li:nth-child(2n + 1) .points_box--img {
  bottom: 0;
  right: 0;
}

.home_strengths--points li:nth-child(4) .points_box--img {
  position: absolute;
  top: -42px;
  left: 0;
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  max-width: 926px;
}

.points_box--img04-01,
.points_box--img04-03 {
  margin-bottom: 22px;
}

.points_box--img04-02 {
  width: 85.34%;
}

.points_box--img-c {
  flex-direction: column;
}

.points_box--img-c:nth-child(1) {
  width: 57.34%;
  margin-right: 22px;
}

.points_box--img-c:nth-child(2) {
  width: 37.6%;
  margin-top: 131px;
}

@media print,
screen and (max-width: 1600px) {
  .points_box--txt {
    padding: 80px;
  }
}

@media print,
screen and (max-width: 1366px) {
  .points_box--img {
    width: 45%;
  }

  .points_box--txt {
    margin-right: 45%;
    padding: 64px;
  }

  .flex-reverse .points_box--txt {
    margin-left: 45%;
  }
}

@media screen and (max-width: 767px) {
  .home_strengths--ttl {
    padding-top: 75%;
  }

  .home_strengths--ttl .section_ttl {
    left: auto;
    right: 3em;
    display: inline-block;
    bottom: 22px;
    padding-bottom: 32px;
    transform: translateX(0);
  }

  .home_strengths--ttl .section_ttl-en {
    top: auto;
    bottom: -35px;
    white-space: nowrap;
  }

  /* points_box */
  .points_box--num {
    font-size: 150%;
  }

  .points_box--num::after {
    margin-left: 16px;
  }

  .points_box--txt {
    margin-right: 0;
    padding: 32px 28px 276px;
  }

  .flex-reverse .points_box--txt {
    margin-left: 0;
  }

  .points_box--txt .ttl-02 {
    padding-top: 0;
  }

  .points_box--txt .ttl-02 {
    font-size: 200%;
  }

  .points_box--txt .ttl-02,
  .points_box--txt p,
  .points_box--txt .btn {
    margin-left: 14px;
  }

  .points_box--img {
    top: auto;
    width: 87%;
    height: 260px;
  }

  .home_strengths--points li:not(:last-child) {
    margin-bottom: 48px;
  }

  .home_strengths--points li:nth-child(2n) .inner {
    width: 95%;
    margin-left: 0;
  }

  .home_strengths--points li:nth-child(2n + 1) .inner {
    width: 95%;
    margin-right: 0;
  }

  .home_strengths--points li:nth-child(2n) .points_box--img {
    bottom: -24px;
    left: 0;
  }

  .home_strengths--points li:nth-child(2n + 1) .points_box--img {
    bottom: -24px;
    right: 0;
  }

  .home_strengths--points li:nth-child(4) {
    margin-bottom: 32%;
  }

  .home_strengths--points li:nth-child(4) .points_box--img {
    top: auto;
    bottom: -24px;
    left: 0;
  }

  .points_box--img04-01,
  .points_box--img04-03 {
    margin-bottom: 12px;
  }

  .points_box--img04-02 {
    width: 85.34%;
  }

  .points_box--img-c:nth-child(1) {
    width: 57.34%;
    margin-right: 12px;
  }

  .points_box--img-c:nth-child(2) {
    width: 38.82%;
    margin-top: 64px;
  }
}

@media screen and (max-width: 360px) {
  .points_box--img-c:nth-child(2) {
    width: 38%;
  }

  .home_strengths--points li:nth-child(4) {
    margin-bottom: 16%;
  }
}

/* home_news
********************************************** */
.home_news {
  position: absolute;
  left: 0;
  bottom: 48px;
  z-index: 1;
  width: 45%;
  max-width: 786px;
  padding: 24px;
  background-color: rgba(255, 255, 255, 0.9);
  border-radius: 4px;
}

.home_news::before {
  content: "";
  position: absolute;
  top: -4px;
  left: 0;
  display: block;
  width: 120px;
  height: 4px;
  background-color: #3cb37b;
}

.news_list {
  flex: 1;
}

.home_news .btn a {
  max-width: 115px;
  padding: 8px 16px;
  color: #3cb37b;
  font-size: 88%;
  text-align: center;
  line-height: 1;
  box-shadow: none;
}

.home_news .btn a::after {
  display: none !important;
}

.news_list--ttl {
  position: relative;
  flex-shrink: 0;
  display: block;
  margin-right: 40px;
  padding: 0;
  font-size: 122%;
  line-height: 1.2;
}

@media print,
screen and (max-width: 1160px) {
  .home_news {
    bottom: -26px;
    width: 80%;
    padding: 16px;
    border-radius: 2px;
  }

  .home_news::before {
    top: -2px;
    width: 64px;
    height: 2px;
  }

  .news_list--ttl {
    display: none;
  }

  .home_news .btn a {
    margin-left: 8px;
  }
}

/* ##############################################################################

    PAGE

############################################################################## */

/* contact
********************************************** */
.page-contact .cta_tel {
  width: 100%;
  max-width: 500px;
  margin-left: auto;
  margin-right: auto;
}

@media screen and (max-width: 767px) {
  .page-contact .cta_tel a {
    display: block;
  }
}

/* ##############################################################################

    ARCHIVE

############################################################################## */

/* main_column
**************************************** */
.main_column {
  flex: 1;
  margin-right: 80px;
  overflow: hidden;
}

/* --- post --- */
.post {
  position: relative;
}

.post--link::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  cursor: pointer;
}

.cat_list {
  position: relative;
  z-index: 1;
  overflow: hidden;
}

.cat_list a {
  display: inline-block;
  vertical-align: middle;
  font-size: 79%;
  background-color: #3cb37b;
  color: #f6f6f6;
  line-height: 1;
  padding: 6px 12px;
  border-radius: 2px;
  float: left;
  margin-right: 4px;
  margin-bottom: 4px;
  white-space: nowrap;
}

.post .post--img {
  border-radius: 3px;
}

.no-image {
  background-size: 70% auto !important;
  background-repeat: no-repeat;
  background-position: center;
  background-color: #fefaf9;
  background-image: url(/vendor/seitai-demo/generated/logo-kagoshima-seitaiin.png);
}

@media print,
screen and (max-width: 1100px) {
  .main_column {
    width: 100%;
    margin-right: 0;
  }

  .main_column:not(:last-child) {
    margin-bottom: 64px;
  }
}

@media screen and (max-width: 767px) {
  .cat_list a {
    font-size: 110%;
  }
}

/* side_column
**************************************** */
.side_column {
  width: 264px;
}

.side_section:not(:last-child) {
  margin-bottom: 64px;
}

.side--ttl {
  font-size: 120%;
  letter-spacing: 0.2em;
  line-height: 1;
  margin-bottom: 16px;
}

.side--ttl small {
  font-size: 62%;
  opacity: 0.5;
  letter-spacing: 0.15em;
  display: block;
  line-height: 1;
  margin-top: 8px;
}

/* --- post --- */
.posts-side .post:not(:last-child) {
  margin-bottom: 16px;
}

.posts-side .post--img {
  margin-right: 16px;
  width: 64px;
  height: 64px;
}

.posts-side .txtarea {
  flex: 1;
}

.posts-side .post--date {
  margin-bottom: 0;
}

.posts-side .post--ttl {
  line-height: 1.4;
}

/* --- archive --- */
.side_column .archive_list--ttl {
  cursor: pointer;
}

.side_column .archive_list--ttl::after {
  content: "";
  display: block;
  width: 8px;
  height: 8px;
  border-top: 1px solid;
  border-right: 1px solid;
  transform: rotate(135deg);
  transition: all 0.4s ease-out;
}

.side_column .archive_list--ttl.active::after {
  transform: rotate(315deg);
}

.side_column .archive_month {
  display: none;
}

@media print,
screen and (max-width: 1100px) {
  .side_column {
    width: 100%;
  }

  .side_section:not(:last-child) {
    margin-bottom: 32px;
  }
}

/* --- archive-pulldown --- */
.archive-pulldown {
  position: relative;
  margin-left: auto;
  z-index: 1;
}

.archive-pulldown .archive_list {
  position: relative;
  font-size: 92%;
}

.archive-pulldown .archive_list:not(:last-child) {
  margin-right: 24px;
}

.archive-pulldown .archive_list a {
  display: block;
  padding: 2px 16px;
  text-align: left;
}

.archive-pulldown .archive_list a:not(:last-child) {
  border-bottom: 1px solid #eee;
}

.archive-pulldown .archive_list--label {
  margin-right: 8px;
}

.archive-pulldown .archive_list--btn {
  cursor: pointer;
  border: none;
  outline: none;
  appearance: none;
  padding: 8px 54px 8px 32px;
  background-color: #fff;
  border: 1px solid #ccc;
}

.archive-pulldown .archive_list--btn::after {
  content: "";
  position: absolute;
  top: 9px;
  right: 10px;
  display: block;
  width: 10px;
  height: 10px;
  border-bottom: 2px solid #333;
  border-right: 2px solid #333;
  transform: rotate(45deg);
  transition: all 0.2s ease-out;
  transform-origin: 50% 50%;
}

.archive-pulldown .active .archive_list--btn::after {
  top: 14px;
  transform: rotate(225deg);
}

.archive-pulldown .archive_list--menu {
  position: absolute;
  z-index: 1;
  width: 100%;
  background-color: #fff;
  border: 1px solid #ccc;
  visibility: hidden;
  margin-top: -1px;
  opacity: 0;
  transition: all 0.2s ease-out;
}

.archive-pulldown .active .archive_list--menu {
  visibility: visible;
  opacity: 1;
}

/* indications
**************************************** */
.indications-nav .side_column {
  width: 100%;
}

.indications-nav .side--list>li {
  width: calc(33.33% - 2em);
}

.side--list a:hover {
  color: #3cb37b;
}

.side--link_list li {
  line-height: 1.8;
  margin-left: 1em !important;
}

.side--link_list li::before,
.gnav_sub--child li::before {
  top: 0.9em;
  height: 2px !important;
}

.posts-indications .post {
  padding-bottom: 48px;
  padding-top: 48px;
  border-bottom: 1px solid #e5e5e5;
}

.posts-indications .post:first-child {
  border-top: 1px solid #e5e5e5;
}

.posts-indications .post--txtarea {
  flex: 1;
}

.posts-indications .post--date {
  margin-right: 16px;
  font-weight: bold;
  margin-bottom: 4px;
}

.posts-indications .post--img {
  width: 280px;
  height: 220px;
  margin-right: 40px;
}

.posts-indications .post--img img {
  border: 1px solid #e5e5e5;
  padding: 16px;
}

.posts-indications .post--img::before {
  padding-top: 75%;
}

.posts-indications .post--link {
  border-bottom: 1px solid;
}

.posts-indications .btn a {
  margin: 24px auto 42px;
  padding: 20px 42px;
  text-decoration: none;
}

.btn-indications .btn a {
  padding-top: 20px;
  padding-bottom: 20px;
}

.btn-indications .btn+.btn {
  margin-top: 0;
}

.post--txt--link {
  display: inline-block;
  color: #3cb37b;
  position: absolute;
  right: 0;
  font-size: 96%;
}

.post--txt--link::after {
  content: "";
  display: inline-block;
  height: 1px;
  background-color: #3cb37b;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
}

@media print,
screen and (max-width: 1100px) {
  .posts-indications {
    margin-bottom: 56px;
  }

  .archive-indications .container>.inner.flex,
  .archive- .container>.inner.flex,
  .single-indications .container>.inner.flex {
    display: block;
  }
}

@media screen and (max-width: 767px) {
  .indications-nav .side--list li {
    width: calc(100% - 2em);
  }

  .posts-indications .post {
    display: block;
    padding-top: 24px;
    padding-bottom: 56px;
  }

  .posts-indications .post--img {
    width: 100%;
    height: auto;
    padding-left: 0;
    margin-right: auto;
    margin-left: auto;
    margin-bottom: 24px;
    text-align: center;
  }

  .post--txt--link {
    left: 0;
    right: 0;
    margin: auto;
    display: table;
    font-size: 100%;
  }

  .post--img-box {
    display: block;
  }

  .posts-indications .post--link {
    font-size: 140%;
  }

  .posts-indications .post--txtarea .post--txt {
    font-size: 116%;
  }
}

/* news
**************************************** */

/* --- news--archive --- */
.news--archive {
  padding-top: 20px;
  padding-bottom: 20px;
  background-color: #111;
}

.news--archive li {
  margin-left: 8px;
  margin-right: 8px;
}

.news--archive a {
  color: #fff;
}

/* --- news_list --- */
.home.news_list .post--ttl {
  border-bottom: 1px solid;
}

.news_list .post--date {
  margin-right: 16px;
  line-height: 1;
}

.news_list a[href="javascript:void(0);"],
.news_list a[href="javascript:void(0);"]::before {
  color: inherit;
  cursor: inherit;
  opacity: 1;
  text-decoration: none;
}

.archive .news_list .post {
  padding-top: 16px;
  padding-bottom: 16px;
  border-bottom: 1px solid #add3ac;
}

@media screen and (max-width: 767px) {
  .news_list .post {
    display: block;
  }

  .news_list .post--date {
    margin-bottom: 6px;
  }

  .archive .news_list .post {
    padding-top: 12px;
    padding-bottom: 12px;
  }
}

/* ##############################################################################

    SINGLE

############################################################################## */

/* pass
**************************************** */
#pass p {
  margin-bottom: 1em;
}

#pass input[name="post_password"] {
  padding: 5px;
  border: solid 1px #aaa;
  outline: none;
}

#pass input[type="submit"] {
  padding: 4px 16px;
  letter-spacing: 0.15em;
  background-color: #ddd;
  border-radius: 4px;
  outline: none;
  border: none;
  cursor: pointer;
  transition: all 0.4s ease-out;
}

#pass input[type="submit"]:hover {
  opacity: 0.7;
}

/* wp-pagenavi
**************************************** */
.wp-pagenavi {
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-justify-content: center;
  justify-content: center;
  margin-top: 40px;
}

.wp-pagenavi .pages {
  display: block;
  text-align: center;
  width: 100%;
  margin-bottom: 1em;
}

.wp-pagenavi a {
  position: relative;
  padding: 0.5em 1em;
  background-color: #3cb37b;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  border-radius: 2px;
}

.wp-pagenavi a:hover {
  opacity: 0.7;
}

.wp-pagenavi a {
  color: #fff;
}

.wp-pagenavi>*:not(.pages) {
  max-width: calc(100% / 2.6);
}

.archive .wp-pagenavi>*:not(.pages) {
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-align-items: center;
  align-items: center;
  width: 40px;
  height: 40px;
}

.wp-pagenavi-single a[rel="prev"],
.wp-pagenavi-single a[rel="next"] {
  width: 40px;
}

.wp-pagenavi>*:not(.pages) {
  margin-bottom: 4px;
}

.wp-pagenavi>*:not(.pages):not(:last-child) {
  margin-right: 4px;
}

.wp-pagenavi .extend {
  width: 24px !important;
}

.wp-pagenavi a[rel="prev"]::before,
.wp-pagenavi a[rel="next"]::before,
.wp-pagenavi .first::before,
.wp-pagenavi .last::before,
.wp-pagenavi .first::after,
.wp-pagenavi .last::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  border-top: 2px solid;
  border-right: 2px solid;
}

.wp-pagenavi a[rel="prev"]::before,
.wp-pagenavi a[rel="next"]::before,
.wp-pagenavi .first::before,
.wp-pagenavi .last::before,
.wp-pagenavi .first::after,
.wp-pagenavi .last::after {
  width: 8px;
  height: 8px;
}

.wp-pagenavi a[rel="prev"]::before,
.wp-pagenavi .first::before,
.wp-pagenavi .first::after {
  -webkit-transform: rotate(-135deg);
  transform: rotate(-135deg);
}

.wp-pagenavi a[rel="next"]::before,
.wp-pagenavi .last::before,
.wp-pagenavi .last::after {
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}

.wp-pagenavi-single a[rel="prev"]::before {
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}

.wp-pagenavi-single a[rel="next"]::before {
  -webkit-transform: rotate(-135deg);
  transform: rotate(-135deg);
}

.wp-pagenavi .first::before,
.wp-pagenavi .last::before {
  left: -6px;
}

.wp-pagenavi .first::after,
.wp-pagenavi .last::after {
  right: -6px;
}

.single-indications .wp-pagenavi {
  display: block;
  text-align: center;
}

.single-indications .wp-pagenavi a {
  display: inline-block;
  max-width: none;
}

.single-indications .wp-pagenavi a::after {
  content: " 一覧へ戻る";
}

@media screen and (max-width: 767px) {
  .wp-pagenavi {
    margin-top: 24px;
  }

  .archive .wp-pagenavi>*:not(.pages) {
    width: 32px;
    height: 32px;
  }

  .wp-pagenavi-single a[rel="prev"],
  .wp-pagenavi-single a[rel="next"] {
    width: 32px;
  }

  .wp-pagenavi .first::before,
  .wp-pagenavi .last::before {
    left: -5px;
  }

  .wp-pagenavi .first::after,
  .wp-pagenavi .last::after {
    right: -5px;
  }
}

/* ##############################################################################

    SEARCH

############################################################################## */

#search-list .section_pdg {
  padding-top: 50px;
  padding-bottom: 50px;
}

#search-list .ttl-01 {
  margin: 70px 0 0;
}

/* ##############################################################################

    FORMY

############################################################################## */
#formy_form {
  font-family: "YuGothic", "游ゴシック", "ヒラギノ角ゴ Pro W3",
    "Hiragino Kaku Gothic ProN", sans-serif;
}

#formy_form table {
  width: 100%;
}

#formy_form th,
#formy_form td {
  padding: 16px;
  vertical-align: middle;
  border-bottom: solid 1px #eee;
}

#formy_form th {
  font-weight: 500;
  white-space: nowrap;
  text-align: left;
  width: 34%;
}

#formy_form table input[type="text"],
#formy_form table input[type="email"],
#formy_form table input[type="tel"],
#formy_form table input[type="date"],
#formy_form table input[type="password"],
#formy_form table textarea {
  width: 100%;
  border-radius: 3px;
  vertical-align: bottom;
}

#formy_form table input[type="text"],
#formy_form table input[type="email"],
#formy_form table input[type="tel"],
#formy_form table input[type="date"],
#formy_form table input[type="password"],
#formy_form select,
#formy_form textarea {
  margin: 0;
  padding: 5px 15px;
  border: 1px solid #ccc;
  font: inherit;
  font-size: 100%;
}

#formy_form textarea {
  height: 100px;
}

#formy_form select {
  height: 40px;
}

#formy_form ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

#formy_form input:hover {
  opacity: 0.7;
}

#formy_form textarea:hover {
  opacity: 0.7;
}

#formy_form input:focus {
  outline: none;
}

#formy_form .parsley-validated {
  background-color: #eee;
}

#formy_form .parsley-error {
  background-color: #fee;
}

#formy_form .parsley-success {
  background-color: #fff;
}

.help_text {
  font-size: 85%;
  color: #999;
}

.hidden_help {
  display: none;
}

.formy_privacy div {
  overflow-y: scroll;
  height: 140px;
  border: solid 1px #ccc;
  font-size: 85%;
  padding: 8px 16px;
}

.requiredIcon {
  background-color: #f55;
  color: #fff;
  margin: 0 0 0 1em;
  font-size: 70%;
  padding: 2px 5px;
  border-radius: 3px;
  float: right;
}

#formy_btn {
  padding-top: 32px;
  text-align: center;
}

#formy_btn input {
  font-size: inherit;
  border: none;
  cursor: pointer;
  color: #fff;
  border-radius: 3px;
  padding: 16px 32px;
  -webkit-appearance: none;
  appearance: none;
}

#formy_form ul li input[type="radio"],
#formy_form ul li input[type="checkbox"] {
  display: none !important;
}

#formy_form ul li label {
  position: relative;
  display: inline-block;
  padding: 0.5em 8px 0.5em 40px;
  line-height: 1.6;
  vertical-align: top;
  cursor: pointer;
}

#formy_form ul li label:hover {
  opacity: 0.7;
}

#formy_form ul li label::before {
  content: "";
  position: absolute;
  width: 16px;
  height: 16px;
  border: 2px solid #788b93;
  left: 16px;
  top: 12px;
}

#formy_form ul li input[type="radio"]+label::before {
  border-radius: 10px;
}

#formy_form ul li input[type="radio"]:checked+label,
#formy_form ul li input[type="checkbox"]:checked+label {
  color: #e75f5f;
  font-weight: bold;
}

#formy_form ul li input[type="radio"]:checked+label::before,
#formy_form ul li input[type="checkbox"]:checked+label::before {
  border-color: #e75f5f;
}

#formy_form ul li input[type="radio"]:checked+label::after,
#formy_form ul li input[type="checkbox"]:checked+label::after {
  content: "";
  width: 10px;
  height: 18px;
  top: 4px;
  left: 20px;
  border-right: 2px solid #e75f5f;
  border-bottom: 2px solid #e75f5f;
  display: block;
  position: absolute;
  z-index: 10;
  -webkit-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  transform: rotate(45deg);
}

.formy_confirm {
  background-color: #4dbaff;
}

.formy_submit_disabled {
  background-color: #ccc;
}

#formy_btn .formy_submit_disabled:hover {
  opacity: 1;
  cursor: default;
}

.autoConfirmBack {
  background-color: #aaa;
}

.formy_send {
  background-color: #ff6600;
}

#total_required {
  padding: 16px;
  color: #f55555;
  text-align: center;
}

@media screen and (max-width: 767px) {

  #formy_form th,
  #formy_form td {
    display: block;
    width: auto;
    padding-left: 0;
    padding-right: 0;
  }

  #formy_form th {
    border-bottom: none;
    padding-bottom: 0;
    white-space: normal;
    font-weight: bold;
  }

  #formy_form td {
    padding-top: 0;
  }

  #formy_btn {
    padding-top: 8px;
  }

  #formy_btn input {
    width: 100%;
    background-size: contain;
    background-position: center;
  }

  .autoConfirmBack {
    margin-bottom: 8px;
  }
}
