@import url("https://fonts.googleapis.com/css2?family=Zen+Kaku+Gothic+New&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Outfit:wght@100..900&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,100..900;1,100..900&display=swap");
html {
  font-size: 10px; }
  @media (max-width: 1440px) and (min-width: 961px) {
    html {
      font-size: 0.694444vw; } }
  @media (max-width: 960px) and (min-width: 768px) {
    html {
      font-size: 1.30208vw; } }
  @media (max-width: 767px) {
    html {
      font-size: 2.66667vw; } }

*,
:after,
:before {
  box-sizing: border-box;
  margin: 0;
  padding: 0; }

body {
  font-size: 1.6rem;
  letter-spacing: 0;
  line-height: 175%;
  font-weight: 500;
  font-family: "Zen Kaku Gothic New", sans-serif; }

.anchor_fixtop {
  display: block;
  position: relative;
  top: -15rem;
  width: 100%;
  visibility: hidden; }
  @media (max-width: 960px) {
    .anchor_fixtop {
      top: -8rem; } }

.grid-1200 {
  max-width: 1230px; }

.is-group-content > div {
  width: 100%;
  max-width: 121rem;
  margin: 0 auto;
  padding-left: 1.5rem;
  padding-right: 1.5rem; }

p {
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 200%;
  letter-spacing: .05rem;
  color: #333333; }

p.has-text-align-center {
  text-align: center; }

#page_top {
  position: fixed;
  bottom: 14rem;
  right: 1rem;
  width: 6rem;
  height: 6rem;
  opacity: 0;
  border: #FFF solid .1rem;
  background: #0e7ebe url(assets/img/page-top.svg) no-repeat center;
  border-radius: 100%;
  background-size: 2.1rem;
  cursor: pointer;
  outline: none;
  z-index: 50; }
  #page_top.show {
    opacity: 1; }
    #page_top.show:hover {
      opacity: 0.8; }
  @media (max-width: 960px) {
    #page_top {
      right: 1.5rem;
      bottom: 18rem;
      width: 5rem;
      height: 5rem;
      position: fixed; }
      #page_top.fixed {
        bottom: 14rem; } }
  @media (max-width: 767px) {
    #page_top {
      bottom: 18rem; } }

.wow_custom {
  opacity: 0;
  -webkit-transform: translate(0, 35px);
  transform: translate(0, 35px);
  transition: all 0.5s ease; }
  .wow_custom.show {
    opacity: 1;
    -webkit-transform: none;
    transform: none; }
    .wow_custom.show.wow_vz_02 {
      animation: fade_in_0 500ms 500ms linear;
      animation-fill-mode: forwards; }
    .wow_custom.show.wow_vz_03 {
      animation: fade_in_0 500ms 1000ms linear;
      animation-fill-mode: forwards; }
    .wow_custom.show.wow_vz_04 {
      animation: fade_in_0 500ms 1500ms linear;
      animation-fill-mode: forwards; }
    .wow_custom.show.wow_vz_05 {
      animation: fade_in_0 500ms 2000ms linear;
      animation-fill-mode: forwards; }

@keyframes fade_in_0 {
  0% {
    opacity: 0;
    transform: translate3d(0, 35px, 0); }
  100% {
    opacity: 1;
    transform: translateZ(0); } }
@keyframes fade_in_1 {
  0% {
    opacity: 0; }
  100% {
    opacity: 1; } }
@keyframes fade_in {
  0% {
    opacity: 0;
    position: relative;
    top: 100px; }
  100% {
    position: relative;
    top: 0px;
    opacity: 1; } }
@keyframes fade_left {
  0% {
    opacity: 0;
    transform: translate3d(-100px, 0, 0); }
  100% {
    opacity: 1;
    transform: translateZ(0); } }
@keyframes fade_right {
  0% {
    opacity: 0;
    transform: translate3d(100px, 0, 0); }
  100% {
    opacity: 1;
    transform: translateZ(0); } }
.fade-left.show {
  animation: fade_left 300ms 200ms ease-in-out;
  animation-fill-mode: forwards; }

.fade-right.show {
  animation: fade_right 300ms 200ms ease-in-out;
  animation-fill-mode: forwards; }

[data-animation="fade-in"].show {
  animation: fade_in_1 500ms 1s ease-in-out;
  animation-fill-mode: forwards; }

.wow_custom_no {
  opacity: 0;
  position: relative;
  z-index: 1; }

@media (max-width: 1280px) and (min-width: 960.5px) {
  body,
  p {
    font-size: 2rem; } }
@media (max-width: 960px) {
  body,
  p {
    font-size: 1.5rem; }

  p {
    letter-spacing: .022rem;
    line-height: 175%;
    text-align: justify; } }
:root {
  --wp--preset--color--black: #000000;
  --wp--preset--color--cyan-bluish-gray: #abb8c3;
  --wp--preset--color--white: #ffffff;
  --wp--preset--color--pale-pink: #f78da7;
  --wp--preset--color--vivid-red: #cf2e2e;
  --wp--preset--color--luminous-vivid-orange: #ff6900;
  --wp--preset--color--luminous-vivid-amber: #fcb900;
  --wp--preset--color--light-green-cyan: #7bdcb5;
  --wp--preset--color--vivid-green-cyan: #00d084;
  --wp--preset--color--pale-cyan-blue: #8ed1fc;
  --wp--preset--color--vivid-cyan-blue: #0693e3;
  --wp--preset--color--vivid-purple: #9b51e0; }

[class*="dflex"] {
  display: flex;
  flex-wrap: wrap; }

[class*="aic"] {
  align-items: center; }

[class*="aie"] {
  align-items: flex-end; }

[class*="ais"] {
  align-items: flex-start; }

[class*="jcc"] {
  justify-content: center; }

[class*="jcsb"] {
  justify-content: space-between; }

[class*="jcfe"] {
  justify-content: flex-end; }

[class*="fcolumn"] {
  flex-flow: column; }

a[href^="tel:"] {
  cursor: default;
  pointer-events: none; }
  @media (max-width: 1024px) {
    a[href^="tel:"] {
      cursor: pointer;
      pointer-events: all; } }

.p-fixed {
  position: fixed;
  left: var(--fixed-left);
  top: var(--fixed-top); }

[class*="grid"] {
  padding-left: 1.5rem;
  padding-right: 1.5rem;
  margin-left: auto;
  margin-right: auto;
  width: 100%; }

.grid-1272 {
  max-width: 130.2rem; }

.grid-1260 {
  max-width: 129rem; }

.grid-1240 {
  max-width: 127rem; }

.grid-1080 {
  max-width: 111rem; }

body,
html {
  height: 100%; }

p {
  font-family: "Zen Kaku Gothic New", sans-serif; }

img {
  max-width: 100%;
  height: auto;
  vertical-align: top;
  overflow-clip-margin: inherit; }

a,
button {
  color: inherit;
  text-decoration: none; }

input,
textarea,
button,
select {
  outline: none;
  resize: none; }

.hv-o {
  transition: ease all 0.5s; }
  .hv-o:hover {
    opacity: 0.8; }

.ho-main,
.os-main {
  overflow: hidden; }

.os-y-hidden {
  overflow-y: hidden; }

.os-section {
  position: relative; }

.os-align-center {
  text-align: center; }

.u-center {
  text-align: center; }

.u-right {
  text-align: right; }

.u-sp {
  display: none; }

ul,
ol {
  list-style: none; }

@media (max-width: 960px) {
  .u-pc {
    display: none; }

  .u-sp {
    display: block; } }
header {
  height: 12.8rem; }

.header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 10;
  padding: 2.5rem 5rem;
  transition: all 0.35s;
  background: #FFFFFF; }
  .header-btn-gp {
    background: #e28787;
    border-radius: 1rem;
    padding: .2rem 1.2rem;
    padding-left: 1.6rem;
    margin-bottom: .6rem; }
    .header-btn-gp li {
      margin-right: 2rem; }
      .header-btn-gp li:last-child {
        margin-right: 0; }
      .header-btn-gp li a {
        color: #FFFFFF;
        font-size: 1.3rem;
        font-weight: 500;
        line-height: 175%;
        letter-spacing: 0; }
      .header-btn-gp li .tel a {
        font-size: 2.3rem;
        padding-left: 2.5rem;
        background: url(assets/img/icon-tel-01.svg) no-repeat center left;
        background-size: 2rem;
        font-family: "Outfit", sans-serif;
        font-weight: 400;
        letter-spacing: .2rem; }
  .header-gp-item:first-child {
    padding-top: .9rem; }
  .header-gp-item:last-child {
    flex-flow: column; }
  .header-gp-item img {
    width: 29.7rem; }
  .header-menu {
    position: relative; }
    .header-menu li {
      margin-left: 4.2rem; }
      .header-menu li:first-child {
        margin-left: 0; }
      .header-menu li a {
        color: #3e0f2a;
        font-size: 1.4rem;
        font-weight: 500;
        line-height: 175%;
        letter-spacing: 0.1rem;
        transition: all 0.35s; }
      @media (min-width: 961px) {
        .header-menu li .sub-menu {
          pointer-events: none;
          position: absolute;
          display: flex;
          flex-wrap: wrap;
          z-index: 0;
          opacity: 0;
          right: 0;
          top: 100%;
          padding-top: 1.5rem;
          transition: all 0.35s;
          min-width: 76rem;
          width: 100%;
          padding: 3rem 1.5rem; }
          .header-menu li .sub-menu::before {
            content: "";
            position: absolute;
            bottom: 0;
            left: 0;
            z-index: -1;
            width: 100%;
            height: calc(100% - 1rem);
            background: #FFFFFF;
            filter: drop-shadow(0 0 2rem rgba(0, 0, 0, 0.15));
            border-radius: 2rem; }
          .header-menu li .sub-menu li {
            border-bottom: #d9e3f0 .1rem solid;
            width: calc((100% - 3.001rem) / 2);
            margin-right: 3rem;
            margin-left: 0; }
            .header-menu li .sub-menu li:nth-child(2n) {
              margin-right: 0; }
            .header-menu li .sub-menu li a {
              display: block;
              padding: 1.7rem 0 1rem;
              border-right: 0;
              color: #333333;
              position: relative; }
              .header-menu li .sub-menu li a::before {
                content: "";
                position: absolute;
                top: 50%;
                transform: translateY(-50%);
                right: 0;
                left: auto;
                width: 1rem;
                height: 1rem;
                -webkit-mask: url(assets/img/icon_arrow.svg) center/100% no-repeat;
                mask: url(assets/img/icon_arrow.svg) center/100% no-repeat;
                background: #333333; }
              .header-menu li .sub-menu li a::after {
                content: "";
                position: absolute;
                bottom: -0.1rem;
                left: 0;
                width: 0;
                height: .1rem;
                background: #e28787;
                transition: all 0.35s; }
              .header-menu li .sub-menu li a:hover {
                padding-left: 1rem; }
                .header-menu li .sub-menu li a:hover::before {
                  background: #e28787; }
                .header-menu li .sub-menu li a:hover::after {
                  width: 100%; }
            .header-menu li .sub-menu li.current_page_item a {
              color: #e28787; }
              .header-menu li .sub-menu li.current_page_item a::before {
                background: #e28787; }
        .header-menu li:hover .sub-menu {
          opacity: 1;
          pointer-events: auto; }
        .header-menu li:hover.menu-item-has-children > a::before {
          opacity: 1; } }
    .header-menu > li > a {
      position: relative;
      padding-bottom: .5rem; }
      .header-menu > li > a::before {
        content: "";
        position: absolute;
        width: 0;
        height: 0.3rem;
        bottom: 0;
        left: 50%;
        transform: translateX(-50%);
        background: #e6837e;
        transition: all 0.35s; }
      .header-menu > li > a:hover::before {
        width: calc(100% + .4rem); }
    .header-menu > li.current-menu-item > a::before {
      width: calc(100% + .4rem); }

@media (min-width: 960.5px) {
  .home header {
    height: auto; }
  .home .header {
    background: transparent; }
    .home .header.active {
      background: #FFFFFF; } }
.banner-images img {
  width: 100%;
  height: var(--banner-img-height-xrem);
  object-fit: cover;
  aspect-ratio: auto; }

@media (max-width: 960px) {
  header {
    height: 7rem; }

  .header {
    padding: .5rem 0;
    background: #FFFFFF;
    z-index: 60; }
    .header-gp-item {
      padding-left: 1.5rem;
      padding-right: 1.5rem; }
      .header-gp-item:first-child {
        padding-top: 0;
        display: flex;
        align-items: center;
        width: 100%;
        justify-content: space-between; }
      .header-gp-item:last-child {
        display: none;
        height: calc(100vh - 6rem);
        overflow-y: scroll;
        padding-bottom: 20rem;
        width: 100%;
        position: fixed;
        top: 6.5rem;
        left: 0;
        background: #FFFFFF; }
      .header-gp-item img {
        width: 24rem; }
      .header-gp-item #menu-header {
        display: none; }
    .header-menu li {
      margin-left: 0;
      border-bottom: #333333 solid 1px; }
      .header-menu li a {
        display: block;
        padding: 1.2rem 3.5rem 1.2rem 0.5rem;
        border-right: 0;
        font-size: 1.5rem; }
      .header-menu li:first-child a {
        border-left: 0; }
    .header-menu .menu > li {
      position: relative; }
      .header-menu .menu > li:not(.item-has-children) a:before {
        content: "";
        display: block;
        position: absolute;
        top: 50%;
        left: auto;
        right: 1rem;
        width: 1rem;
        aspect-ratio: 1 / 1;
        z-index: 1;
        -webkit-mask: url(assets/img/icon_arrow.svg) center/100% no-repeat;
        mask: url(assets/img/icon_arrow.svg) center/100% no-repeat;
        background: #333333;
        transform: translateY(-50%);
        border: 0;
        opacity: 1;
        height: 1rem; }
      .header-menu .menu > li .dropdow {
        position: absolute;
        display: block;
        top: 1rem;
        right: 0rem;
        width: 3rem;
        height: 3rem;
        z-index: 2;
        background: #FFFFFF;
        border-radius: 100%; }
        .header-menu .menu > li .dropdow::before, .header-menu .menu > li .dropdow::after {
          content: "";
          position: absolute;
          top: 50%;
          left: 50%;
          transform: translate(-50%, -50%);
          width: 1rem;
          height: 0.1rem;
          background: #e28787; }
        .header-menu .menu > li .dropdow::after {
          transition: all 0.35s;
          transform: translate(-50%, -50%) rotate(90deg); }
        .header-menu .menu > li .dropdow.active::after {
          transform: translate(-50%, -50%) rotate(0deg); }
      .header-menu .menu > li .sub-menu {
        position: relative;
        margin-bottom: 1.5rem;
        padding: 2rem;
        opacity: 1;
        display: none;
        min-width: 100%;
        background-color: #e28787; }
        .header-menu .menu > li .sub-menu::before {
          content: none; }
        .header-menu .menu > li .sub-menu li {
          border: 0;
          width: 100%;
          margin-right: 0; }
          .header-menu .menu > li .sub-menu li:first-child a {
            border-top: #FFFFFF dashed .1rem; }
          .header-menu .menu > li .sub-menu li a {
            width: 100%;
            text-align: left;
            padding-left: 0;
            border-bottom: #FFFFFF dashed .1rem;
            color: #ffffff;
            position: relative; }
            .header-menu .menu > li .sub-menu li a::before {
              content: "";
              display: block;
              position: absolute;
              top: 50%;
              right: 0rem;
              width: 1rem;
              aspect-ratio: 1 / 1;
              z-index: 1;
              -webkit-mask: url(assets/img/icon_arrow.svg) center/100% no-repeat;
              mask: url(assets/img/icon_arrow.svg) center/100% no-repeat;
              background: #ffffff;
              transform: translateY(-50%); }
      .header-menu .menu > li a {
        position: relative;
        color: #333333; }
      .header-menu .menu > li.current-menu-item > a {
        color: #0e7ebe; }
        .header-menu .menu > li.current-menu-item > a::before {
          background: #0e7ebe; }
    .header-btn-gp {
      display: none; }

  .nav-menu {
    display: flex;
    position: relative;
    bottom: 0;
    right: 0;
    background: #0e7ebe;
    width: 7.5rem;
    height: 6rem;
    z-index: 10; }
    .nav-menu-item {
      width: 100%;
      display: flex;
      align-items: center;
      justify-content: center;
      flex-wrap: wrap;
      padding: 1.5rem; }
      .nav-menu-item span {
        background: #fff;
        display: block;
        height: 1px;
        transition: transform 0.3s;
        width: 100%;
        transform-origin: center;
        position: relative; }
      .nav-menu-item.active span:first-child {
        transform: rotate(45deg);
        margin-bottom: 0;
        top: .9rem; }
      .nav-menu-item.active span:nth-child(2) {
        display: none; }
      .nav-menu-item.active span:nth-child(3) {
        transform: rotate(135deg);
        top: -0.6rem; }

  .menu-title {
    font-size: 2.4rem;
    color: #333333;
    margin-top: 4rem; } }
.footer {
  background: linear-gradient(180deg, rgba(237, 210, 217, 0) 0%, #edd2d9 84%);
  position: relative;
  overflow: hidden;
  z-index: 0;
  padding-top: 10rem;
  padding-bottom: 9.8rem; }
  .footer::before {
    content: "";
    position: absolute;
    width: 49rem;
    height: 67.9rem;
    bottom: -6.6rem;
    right: -10.7rem;
    z-index: -1;
    background: url(assets/img/footer-bg.png) no-repeat center;
    background-size: contain; }
  .footer-gp-box .logo {
    margin-bottom: 4.1rem; }
    .footer-gp-box .logo img {
      width: 31rem; }
  .footer-gp-item:first-child {
    width: 25.3rem; }
  .footer-gp-item:last-child {
    width: calc(100% - 25.3rem); }
  .footer-title-01 {
    color: #0e7ebe;
    font-size: 2rem;
    font-weight: 300;
    line-height: 175%;
    letter-spacing: 0;
    margin-bottom: 2.7rem;
    font-family: "Montserrat", sans-serif; }
  .footer-link-fix {
    position: fixed;
    bottom: 2.4rem;
    right: 5rem;
    z-index: 60;
    transition: all 0.35s; }
    .footer-link-fix a {
      width: 33.5rem;
      height: 11.3rem;
      padding: 0 .9rem;
      border-radius: 0 .6rem .6rem 0;
      background: url(assets/img/footer-link.png) no-repeat center;
      background-size: cover;
      display: flex;
      align-items: center;
      position: relative;
      transition: all 0.35s; }
      .footer-link-fix a::before {
        content: "";
        position: absolute;
        width: 2.4rem;
        height: 2.4rem;
        bottom: .4rem;
        right: .7rem;
        border-radius: 100%;
        background: #0e7ebe; }
      .footer-link-fix a::after {
        content: "";
        position: absolute;
        width: 0.5rem;
        height: 0.6rem;
        background: #FFFFFF;
        bottom: 1.3rem;
        right: 1.5rem;
        clip-path: polygon(0 0, 0% 100%, 100% 50%); }
      .footer-link-fix a span {
        background: #FFFFFF;
        text-align: center;
        border-radius: .5rem;
        padding: .7rem 1.2rem;
        color: #0e7ebe;
        font-size: 1.5rem;
        font-weight: 700;
        line-height: 155%;
        letter-spacing: 0.05rem; }
      .footer-link-fix a:hover {
        opacity: 0.8; }
    .footer-link-fix .close {
      width: 3rem;
      height: 3rem;
      border-radius: 100%;
      background: rgba(255, 255, 255, 0.65);
      position: absolute;
      top: -1.2rem;
      left: -1.7rem;
      z-index: 1;
      cursor: pointer;
      box-shadow: 0 0 0.7rem rgba(0, 0, 0, 0.15); }
      .footer-link-fix .close::before {
        content: "";
        position: absolute;
        width: 2rem;
        height: 1px;
        background: #0e7ebe;
        top: 1.5rem;
        left: .6rem;
        transform: rotate(45deg); }
      .footer-link-fix .close::after {
        content: "";
        position: absolute;
        width: 2rem;
        height: 1px;
        background: #0e7ebe;
        top: 1.5rem;
        left: .6rem;
        transform: rotate(-45deg); }
    .footer-link-fix.active {
      opacity: 0;
      pointer-events: none; }

.menu-footer li {
  margin-bottom: 1.3rem; }
  .menu-footer li:last-child {
    margin-bottom: 0; }
  .menu-footer li a {
    color: #3e0f2a;
    font-size: 1.5rem;
    font-weight: 400;
    line-height: 175%;
    letter-spacing: 0;
    position: relative;
    padding-left: 1.6rem;
    transition: all 0.35s; }
    .menu-footer li a::before {
      content: "";
      position: absolute;
      width: 0.5rem;
      height: 0.5rem;
      top: .9rem;
      left: 0;
      background: #eb7d78;
      border-radius: 100%; }
    .menu-footer li a:hover {
      opacity: 0.8; }
  .menu-footer li .sub-menu {
    padding-left: 1.6rem;
    margin-top: .8rem; }
    .menu-footer li .sub-menu li {
      margin-bottom: .3rem; }
      .menu-footer li .sub-menu li a {
        padding-left: 2rem; }
        .menu-footer li .sub-menu li a::before {
          width: .4rem;
          height: 1px;
          border-radius: 0;
          background: #3e0f2a; }
        .menu-footer li .sub-menu li a[href="#"] {
          cursor: default;
          pointer-events: none; }
.menu-footer > li > a[href="#"] {
  cursor: default;
  pointer-events: none; }
.menu-footer.vs-02 {
  width: 24.8rem; }

.copyright {
  background: #0e7ebe;
  padding: 1.6rem;
  border-top: #FFFFFF solid 2px; }
  .copyright .logo {
    border-right: white solid 0.1rem;
    padding: .4rem 1.5rem;
    text-align: right; }
    .copyright .logo img {
      width: 18rem; }
  .copyright-item {
    width: 50%; }
  .copyright .txt {
    padding-left: 1.5rem; }
    .copyright .txt p {
      font-size: 1.4rem;
      color: #ffffff !important;
      font-weight: 400;
      letter-spacing: 0;
      line-height: 150%; }

@media (min-width: 960.5px) {
  .menu_right_fix {
    display: none; } }
@media (max-width: 960px) {
  .footer {
    padding-top: 6rem;
    padding-bottom: 3rem; }
    .footer-link-fix {
      right: 1.5rem;
      bottom: 6rem; }
    .footer-gp-box:last-child {
      display: none; }
    .footer-gp-box .logo img {
      width: 27rem; }
    .footer::before {
      width: 30rem;
      height: 41.4rem;
      bottom: -13.6rem; }

  .menu_right_fix {
    left: 0;
    bottom: 0;
    z-index: 10;
    transform: inherit;
    display: flex;
    width: 100%;
    position: fixed;
    border-top: #FFF solid 1px; }
    .menu_right_fix li {
      width: 50%;
      border-right: #FFFFFF solid 1px; }
      .menu_right_fix li:last-child {
        border-right: 0; }
      .menu_right_fix li a {
        display: flex;
        align-items: center;
        justify-content: center;
        height: 6rem;
        background: #0e7ebe;
        color: #FFFFFF; }

  .copyright {
    padding: 1.5rem .5rem 7.5rem; } }
@media (max-width: 767px) {
  .copyright .logo {
    padding-left: 0;
    padding-right: 1rem; }
    .copyright .logo img {
      width: 14rem; }
  .copyright .txt {
    padding-left: 1rem; } }
.title-default-01 {
  text-align: center;
  position: relative;
  padding-bottom: 1.7rem;
  color: #3e0f2a;
  font-size: 2.4rem;
  font-weight: 600;
  line-height: 160%;
  letter-spacing: 0.2rem; }
  .title-default-01::before {
    content: "";
    position: absolute;
    width: 21.1rem;
    height: 1.4rem;
    bottom: 0;
    left: 50%;
    background: url(assets/img/icon-title-01.png) no-repeat center;
    background-size: cover;
    transform: translateX(-50%); }
.title-default-02 {
  margin-bottom: 2.2rem; }
  .title-default-02 p {
    padding-left: 2rem;
    color: #eb7d78;
    font-size: 1.4rem;
    font-weight: 500;
    line-height: 165%;
    letter-spacing: 0.04rem;
    font-family: "Montserrat", sans-serif;
    background: url(assets/img/icon-title-02.png) no-repeat center left;
    background-size: 1.5rem; }
  .title-default-02 h4 {
    color: #3e0f2a;
    font-size: 2.4rem;
    font-weight: 400;
    line-height: 165%;
    letter-spacing: 0.1rem; }
.title-default-03 {
  margin-bottom: .5rem; }
  .title-default-03 p span {
    color: #0e7ebe;
    font-size: 2.4rem;
    font-weight: 400;
    line-height: 150%;
    letter-spacing: 0;
    font-family: "Montserrat", sans-serif;
    opacity: 0.53; }
    .title-default-03 p span:first-child {
      position: relative;
      top: -0.3rem; }
    .title-default-03 p span:last-child {
      margin-left: .7rem;
      font-size: 4rem;
      opacity: 0.28; }
  .title-default-03 h4 {
    color: #eb7d78;
    font-size: 2.8rem;
    font-weight: 700;
    line-height: 150%;
    letter-spacing: 0.2rem; }
.title-default-04 {
  color: #3e0f2a;
  font-size: 2.3rem;
  font-weight: 500;
  line-height: 150%;
  letter-spacing: 0.17rem;
  margin-bottom: 1.2rem; }

.btn-default-01 a {
  color: #FFFFFF;
  font-size: 1.5rem;
  font-weight: 500;
  line-height: 150%;
  letter-spacing: 0.05rem;
  background: #e6837e;
  border: #e6837e solid 1px;
  display: flex;
  width: 100%;
  height: 6.4rem;
  align-items: center;
  justify-content: center;
  border-radius: 6.4rem;
  min-width: 25.4rem;
  position: relative;
  padding-left: 3rem;
  padding-right: 4.2rem;
  transition: all 0.35s; }
  .btn-default-01 a::before {
    content: "";
    position: absolute;
    width: 0.6rem;
    height: 0.73rem;
    top: 50%;
    right: 1.7rem;
    transform: translateY(-50%);
    -webkit-mask: url(assets/img/arrow-right-02.svg) center/100% no-repeat;
    mask: url(assets/img/arrow-right-02.svg) center/100% no-repeat;
    background: #FFFFFF;
    transition: all 0.35s; }
  .btn-default-01 a:hover {
    background: #FFFFFF;
    color: #e6837e; }
    .btn-default-01 a:hover::before {
      background: #e6837e; }
.btn-default-01.vs-02 a {
  background: #FFFFFF;
  color: #e6837e; }
  .btn-default-01.vs-02 a::before {
    background: #e6837e; }
  .btn-default-01.vs-02 a:hover {
    background: #e6837e;
    color: #FFFFFF; }
    .btn-default-01.vs-02 a:hover::before {
      background: #FFFFFF; }
.btn-default-02 .phone {
  padding-left: 6.5rem;
  color: #3c2f2f;
  font-size: 4.1rem;
  font-weight: 700;
  line-height: 140%;
  letter-spacing: 0.4rem;
  background: url(assets/img/icon-tel-02.svg) no-repeat center left;
  background-size: 3rem; }
  .btn-default-02 .phone.fax {
    background-image: url(assets/img/icon-fax.svg);
    background-size: 3.4rem; }
.btn-gp-01 li {
  margin-right: 1.5rem; }
  .btn-gp-01 li:last-child {
    margin-right: 0; }
.btn-gp-01.vs-02 {
  padding: 0 2rem; }
  .btn-gp-01.vs-02 .btn-default-01 a {
    width: 27.5rem; }
.btn-gp-01.vs-03 {
  padding: 0 2rem; }
  .btn-gp-01.vs-03 .btn-default-01 a {
    width: 33.5rem; }
.btn-gp-01.vs-04 li {
  margin-right: 2rem; }
  .btn-gp-01.vs-04 li:last-child {
    margin-right: 0; }

.table-default-01 {
  background: #FFFFFF;
  padding: 4rem 1.8rem 2.2rem; }
  .table-default-01 table {
    width: 100%;
    border-spacing: 0;
    border-collapse: collapse;
    border-bottom: #929292 solid 1px;
    margin-bottom: 1.2rem; }
    .table-default-01 table td {
      padding: .5rem 0;
      color: #262c34;
      font-size: 1.6rem;
      font-weight: 400;
      line-height: 150%;
      letter-spacing: 0;
      width: 4.2rem; }
      .table-default-01 table td:first-child {
        width: 15.5rem; }
      .table-default-01 table td:last-child {
        width: 8rem; }
    .table-default-01 table tr:first-child td {
      padding-bottom: 1.4rem;
      border-bottom: #929292 solid 1px; }
    .table-default-01 table tr:nth-child(2) td {
      padding-top: 1.5rem; }
    .table-default-01 table tr:last-child td {
      padding-bottom: 1.3rem; }
  .table-default-01 p {
    color: #262c34;
    font-size: 1.4rem;
    font-weight: 400;
    line-height: 170%;
    letter-spacing: 0.13rem; }

.cl-eb7 {
  color: #eb7d78; }

.cl-e8e {
  color: #e8e1e0; }

.no_scroll {
  overflow: hidden; }

@media (max-width: 960px) {
  .title-default-01 {
    font-size: 2rem; }
  .title-default-02 {
    margin-bottom: 1.5rem; }
  .title-default-03 h4 {
    font-size: 2.2rem; }
  .title-default-04 {
    font-size: 2rem; }

  .btn-default-01 a {
    letter-spacing: 0; }
  .btn-default-02 .phone {
    font-size: 2.5rem;
    background-size: 2rem;
    padding-left: 3.5rem; }
    .btn-default-02 .phone.fax {
      background-size: 2.4rem; }
  .btn-gp-01 li {
    margin-bottom: 1.5rem; }
    .btn-gp-01 li:last-child {
      margin-bottom: 0; }

  .table-default-01 {
    padding: 2rem 1.5rem; }
    .table-default-01 table td {
      font-size: 1.5rem; }
    .table-default-01 p {
      letter-spacing: 0; } }
@media (max-width: 767px) {
  .btn-gp-01 li {
    margin-right: 0; }
  .btn-gp-01.vs-04 li {
    margin-right: 0; } }
:root {
  --px-11px: 1.1rem;
  --px-13px: 1.3rem;
  --px-15px: 1.5rem;
  --px-16px: 1.6rem;
  --px-18px: 1.8rem;
  --px-20px: 2rem;
  --px-22px: 2.2rem;
  --px-25px: 2.5rem;
  --px-30px: 3rem;
  --px-32px: 3.2rem;
  --px-41px: 4.1rem;
  --px-50px: 5rem;
  --px-60px: 6rem;
  --px-77px: 7.7rem;
  --px-102px: 10.2rem;
  --px-110px: 11.0rem;
  --px-111px: 11.1rem;
  --px-120px: 12.0rem;
  --px-131px: 13.1rem;
  --px-137px: 13.7rem;
  --px-140px: 14rem;
  --px-205px: 20.5rem;
  --px-250px: 25rem;
  --px-422px: 42.2rem;
  --px--5px: -0.5rem;
  --px--27px: -2.7rem;
  --px--30px: -3rem;
  --main-color: #90785f; }
  @media (max-width: 960px) {
    :root {
      --px-140px: 8rem;
      --px-50px: 2.5rem;
      --px-20px: 1.8rem;
      --px-110px: 8rem;
      --px-102px: 7.5rem;
      --px-32px: 2.2rem; } }

.mg-b-30 {
  margin-bottom: 3rem !important; }

.mb-15 {
  margin-bottom: 1.5rem; }

.mb-30 {
  margin-bottom: 3rem; }

.mb-50 {
  margin-bottom: 5rem; }

.mb-60 {
  margin-bottom: 6rem; }

.mb-143 {
  margin-bottom: 14.3rem !important; }

.mb-150 {
  margin-bottom: 15rem  !important; }

.pt-50 {
  padding-top: var(--px-50px); }

.pb-70 {
  padding-bottom: 7rem; }

@media (max-width: 960px) {
  .mb-50 {
    margin-bottom: 3rem; }

  .mb-sp-100 {
    margin-bottom: 10rem !important; }

  .mb-sp-92 {
    margin-bottom: 9.2rem !important; }

  .mb-sp-72 {
    margin-bottom: 7.2rem !important; }

  .mb-sp-65 {
    margin-bottom: 6.5rem !important; }

  .mb-sp-25 {
    margin-bottom: 2.5rem !important; }

  .mt-sp-10 {
    margin-top: 1rem !important; }

  .mb-60 {
    margin-bottom: 3rem; } }
.mt--30 {
  margin-top: -3rem; }

.mt-100 {
  margin-top: 10rem; }

.mt-15 {
  margin-top: 1.5rem; }

.mt-20 {
  margin-top: 2rem; }

.mt-30 {
  margin-top: 3rem; }

@media (min-width: 1000.5px) {
  .mt-pc--30 {
    margin-top: -3rem; } }
@media (max-width: 960px) {
  .mt-30 {
    margin-top: 2rem; }

  .mb-30 {
    margin-bottom: 2rem; } }
.noimg {
  border: 1px solid #eeeeee; }

.banner {
  width: calc(100% - var(--banner-width-xrem));
  border-radius: 0 0 2rem 2rem;
  margin-left: auto;
  margin-right: auto;
  position: relative;
  overflow: hidden; }
  .banner::before {
    content: "";
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    background: rgba(0, 0, 0, 0.35); }
  .banner-images img {
    width: 100%;
    height: var(--banner-img-height-xrem);
    object-fit: cover;
    aspect-ratio: auto; }
  .banner-title {
    position: absolute;
    z-index: 3;
    left: var(--banner-title-left-xrem);
    right: var(--banner-title-right-xrem);
    top: var(--banner-title-top-xrem);
    bottom: var(--banner-title-bottom-xrem);
    transform: translate(var(--banner-title-translateX-xrem), var(--banner-title-translateY-xrem));
    text-align: center;
    border-top-left-radius: var(--banner-border-radius-xrem);
    border-top-right-radius: var(--banner-border-radius-xrem);
    letter-spacing: 0.3rem;
    height: var(--banner-title-height-xrem);
    padding: var(--banner-title-pdtop-xrem) var(--banner-title-pdleftright-xrem) var(--banner-title-pdbottom-xrem);
    min-width: var(--banner-title-minwidth-xrem);
    display: flex;
    align-items: center;
    justify-content: center; }
    .banner-title::before, .banner-title::after {
      content: var(--banner-title-before-xrem);
      position: absolute;
      width: 4rem;
      height: 2rem;
      border: 4px double var(--banner-title-color-xrem); }
    .banner-title::before {
      left: 0.5rem;
      top: 0.5rem;
      border-bottom: 0;
      border-right: 0; }
    .banner-title::after {
      right: 0.5rem;
      bottom: 0.5rem;
      border-top: 0;
      border-left: 0; }
    .banner-title .ja {
      font-size: var(--banner-title-fzja-xrem);
      line-height: 120%;
      font-weight: bold;
      font-family: "Outfit", sans-serif;
      color: var(--banner-title-color-xrem); }

.grits_meta_h1 {
  position: absolute;
  opacity: 0;
  top: 0;
  left: 0;
  pointer-events: none; }

@media (max-width: 960px) {
  .banner {
    border-radius: 0; } }
.breadcrumbs {
  width: 100%;
  text-align: var(--breadcrumb-text-align-xrem);
  position: relative;
  padding: 0 var(--breadcrumb-padding-lr-xrem); }
  .breadcrumbs-content {
    text-align: var(--breadcrumb-content-text-align-xrem);
    display: inline-block;
    width: 100%;
    max-width: 120.001rem;
    margin-top: var(--breadcrumb-padding-top-xrem);
    margin-bottom: var(--breadcrumb-padding-bottom-xrem);
    margin-left: auto;
    margin-right: auto; }
    .breadcrumbs-content li {
      position: relative;
      display: inline; }
      .breadcrumbs-content li:not(:last-child) {
        padding-right: 1.5rem;
        margin-right: 1.5rem; }
        .breadcrumbs-content li:not(:last-child)::before {
          content: "";
          position: absolute;
          right: 0;
          top: 50%;
          width: 0.8rem;
          aspect-ratio: 1 / 1;
          transform: translateY(-47%) rotate(45deg);
          position: absolute;
          content: "";
          border-top: 1px solid #353535;
          border-right: 1px solid #353535; }
      .breadcrumbs-content li a {
        transition: ease all 0.35s; }
        .breadcrumbs-content li a:hover {
          opacity: 0.7; }

.mv {
  position: relative; }
  .mv-slide img {
    width: 100%; }
  .mv-cont {
    position: absolute;
    top: 46%;
    left: 0;
    width: 100%;
    transform: translateY(-50%); }
    .mv-cont h2 {
      color: #3e0f2a;
      font-size: 3rem;
      font-weight: 600;
      line-height: 160%;
      letter-spacing: 0.3rem;
      margin-bottom: 3.8rem; }
      .mv-cont h2 span {
        font-size: 3.8rem;
        font-weight: 700;
        color: #eb7d78; }
    .mv-cont p {
      color: #27121e;
      font-size: 1.6rem;
      font-weight: 500;
      line-height: 180%;
      letter-spacing: 0.15rem;
      max-width: 29rem; }
  .mv .top-news {
    position: absolute;
    bottom: 4.7rem;
    left: 50%;
    transform: translateX(-50%);
    width: 100%;
    max-width: 134rem; }
    .mv .top-news-wrap {
      border-radius: .5rem;
      background: rgba(255, 255, 255, 0.75);
      width: 41rem;
      padding: .8rem 1.6rem .5rem 1.8rem; }
    .mv .top-news h3 {
      color: #9e8a95;
      font-size: 1.5rem;
      font-weight: 500;
      line-height: 180%;
      letter-spacing: 0; }
  .mv .news-list {
    margin-bottom: -0.6rem; }

.top-news-btn {
  text-align: right; }
  .top-news-btn a {
    color: #9e8a95;
    font-size: 1.3rem;
    font-weight: 500;
    line-height: 180%;
    letter-spacing: 0;
    position: relative;
    padding-right: 2.4rem; }
    .top-news-btn a::before {
      content: "";
      position: absolute;
      width: 1.5rem;
      height: 1.5rem;
      top: 50%;
      right: 0;
      transform: translateY(-50%);
      background: #e6837e;
      border-radius: 100%; }
    .top-news-btn a::after {
      content: "";
      position: absolute;
      width: 0.4rem;
      height: 0.5rem;
      top: 50%;
      right: .5rem;
      transform: translateY(-50%);
      background: #FFFFFF;
      clip-path: polygon(0 0, 0% 100%, 100% 50%); }
  .top-news-btn.vs-02 a {
    color: #eb7d78;
    font-size: 1.8rem;
    padding-right: 4.5rem; }
    .top-news-btn.vs-02 a::before {
      width: 2.5rem;
      height: 2.5rem;
      background-image: url(assets/img/arrow-right-02.svg);
      background-size: .6rem;
      background-repeat: no-repeat;
      background-position: center;
      box-shadow: 0 0.4rem 0.6rem rgba(38, 42, 42, 0.14); }
    .top-news-btn.vs-02 a::after {
      content: none; }

.news-list {
  background: url(assets/img/icon-border.png) repeat-x top left;
  width: 29.5rem; }
  .news-list li {
    background: url(assets/img/icon-border.png) repeat-x bottom left; }
    .news-list li a {
      color: #eb7d78;
      font-size: 1.4rem;
      font-weight: 500;
      line-height: 175%;
      letter-spacing: 0;
      display: flex;
      padding: .33rem 0; }
      .news-list li a .date {
        color: #9e8a95;
        width: 9.5rem; }
      .news-list li a .txt {
        width: calc(100% - 9.5rem); }

.position-item {
  position: relative; }

.title-page {
  position: absolute;
  top: 7.8rem;
  left: -1rem;
  opacity: 0.4;
  color: #e3dbda;
  font-size: 6.5rem;
  font-weight: 300;
  line-height: 175%;
  letter-spacing: 0.8rem;
  font-family: "Montserrat", sans-serif;
  writing-mode: sideways-lr; }
  .title-page::first-letter {
    color: #0e7ebe; }

.concept {
  padding-top: 7.6rem;
  position: relative; }
  .concept::before {
    content: "";
    position: absolute;
    width: 91.5rem;
    height: 41.1rem;
    top: 53.5%;
    left: 62%;
    transform: translate(-50%, -50%);
    background: url(assets/img/concept-bg.png) no-repeat center;
    background-size: contain;
    z-index: -1; }
  .concept-wrap {
    position: relative;
    padding-bottom: 26rem; }
    .concept-wrap .icon-img {
      position: absolute;
      z-index: -1; }
      .concept-wrap .icon-img.vs-01 {
        top: 0;
        left: -3rem; }
        .concept-wrap .icon-img.vs-01 img {
          width: 33.1rem; }
      .concept-wrap .icon-img.vs-02 {
        bottom: 2rem;
        left: -2rem; }
        .concept-wrap .icon-img.vs-02 img {
          width: 41.9rem; }
      .concept-wrap .icon-img.vs-03 {
        top: -0.7rem;
        right: -7.7rem; }
        .concept-wrap .icon-img.vs-03 img {
          width: 48.1rem; }
    .concept-wrap p {
      color: #27121e;
      font-size: 1.6rem;
      font-weight: 500;
      line-height: 200%;
      letter-spacing: 0.2rem;
      writing-mode: vertical-lr;
      margin-right: 8.2rem;
      word-break: keep-all; }
      .concept-wrap p:nth-child(2) {
        margin-right: 6.2rem; }
      .concept-wrap p:nth-child(3) {
        margin-right: 3.8rem; }
      .concept-wrap p:last-child {
        margin-right: 0; }
      .concept-wrap p .item {
        position: relative;
        padding-top: 1.9rem;
        padding-bottom: 1.8rem;
        writing-mode: vertical-lr; }
        .concept-wrap p .item::before {
          content: "";
          position: absolute;
          width: 1.1rem;
          height: 1.1rem;
          top: 1.2rem;
          right: 0;
          border: #ccbfc6 solid 2px;
          border-bottom: 0;
          border-left: 0; }
        .concept-wrap p .item::after {
          content: "";
          position: absolute;
          width: 1.1rem;
          height: 1.1rem;
          bottom: .4rem;
          left: 0;
          border: #ccbfc6 solid 2px;
          border-top: 0;
          border-right: 0; }
      .concept-wrap p .item-01 {
        font-size: 2.1rem; }
      .concept-wrap p .item-02 {
        font-size: 2rem; }
  .concept-banner {
    position: absolute;
    right: 0;
    bottom: 6rem;
    width: 60rem; }
    .concept-banner li {
      width: calc((100% - 1.501rem) / 2);
      margin-right: 1.5rem; }
      .concept-banner li:nth-child(2n) {
        margin-right: 0; }
      .concept-banner li a {
        position: relative;
        display: block; }
        .concept-banner li a::before {
          content: "";
          position: absolute;
          width: 100%;
          height: 100%;
          top: 0;
          left: 0;
          background: rgba(0, 0, 0, 0.5);
          transition: all 0.35s; }
        .concept-banner li a:hover::before {
          background: rgba(0, 0, 0, 0.8); }
        .concept-banner li a img {
          object-fit: cover;
          width: 100%;
          aspect-ratio: 4/2; }
      .concept-banner li .txt {
        position: absolute;
        top: 50%;
        left: 0;
        width: 100%;
        text-align: center;
        transform: translateY(-50%);
        color: #FFFFFF; }
  .concept .title-default-01 {
    margin-bottom: 3.6rem; }

.trouble {
  padding-top: 7.4rem;
  padding-bottom: 8rem;
  background: linear-gradient(180deg, #fdf9fa 0%, #edd2d9 100%);
  position: relative; }
  .trouble::before {
    content: "";
    position: absolute;
    width: 38rem;
    height: 40.5rem;
    top: 3.3rem;
    right: -5.8rem;
    background: url(assets/img/trouble-bg.png) no-repeat center;
    background-size: cover; }
  .trouble-wrap {
    padding-left: 2.8rem; }
  .trouble-list li {
    width: calc((100% - 8.401rem) / 4);
    margin-right: 2.8rem;
    margin-bottom: 2.1rem; }
    .trouble-list li:nth-child(4n), .trouble-list li:last-child {
      margin-right: 0; }
    .trouble-list li a {
      position: relative;
      overflow: hidden;
      display: block;
      box-shadow: 0 0 24px rgba(168, 165, 167, 0.1); }
      .trouble-list li a .img {
        display: block;
        border-radius: .6rem;
        box-shadow: 0 0 2.4rem rgba(168, 165, 167, 0.1);
        transition: all 0.35s; }
        .trouble-list li a .img img {
          border-radius: .6rem;
          width: 100%;
          transition: all 0.35s; }
      .trouble-list li a .txt {
        position: absolute;
        bottom: 0;
        left: 0;
        width: 100%;
        text-align: center;
        display: flex;
        align-items: center;
        justify-content: center;
        min-height: 5.7rem;
        padding-bottom: .2rem;
        border-radius: 0 0 .6rem .6rem;
        color: #2a121f;
        font-size: 1.6rem;
        font-weight: 500;
        line-height: 130%;
        letter-spacing: 0;
        transition: all 0.35s; }
        .trouble-list li a .txt::before {
          content: "";
          position: absolute;
          width: 2.6rem;
          height: 2.6rem;
          background: url(assets/img/arrow-right.svg) no-repeat center;
          background-size: cover;
          top: 50%;
          transform: translateY(-50%);
          right: 1.2rem;
          transition: all 0.35s;
          border-radius: 100%; }
      .trouble-list li a .desc {
        position: absolute;
        width: 100%;
        padding: 2rem 2.8rem;
        top: 0;
        left: 0;
        border-radius: .6rem .6rem 0 0;
        opacity: 0;
        transition: all 0.35s;
        color: #3e0f2a;
        font-size: 1.5rem;
        font-weight: 500;
        line-height: 140%;
        letter-spacing: 0.1rem; }
        .trouble-list li a .desc.vs-02 {
          padding-top: 1rem; }
      .trouble-list li a:hover .txt {
        min-height: 5rem;
        background: #FFFFFF; }
        .trouble-list li a:hover .txt::before {
          opacity: 0; }
      .trouble-list li a:hover .img {
        background: #eff9ff; }
        .trouble-list li a:hover .img img {
          opacity: 0; }
      .trouble-list li a:hover .desc {
        opacity: 1; }
    .trouble-list li.vs-02 a .desc {
      padding-top: 1.5rem;
      padding-bottom: 1.5rem; }
    .trouble-list li.vs-02 a .txt {
      min-height: 5.7rem; }
  .trouble .title-default-01 {
    margin-bottom: 5.5rem; }

.symptom {
  padding-top: 7.4rem; }
  .symptom-list li {
    width: calc((100% - 9.2rem) / 3);
    margin-right: 4.6rem; }
    .symptom-list li:nth-child(3n) {
      margin-right: 0; }
    .symptom-list li a {
      background: #edd2d9;
      display: block;
      text-align: center;
      border-radius: .6rem;
      padding: 1.65rem 0;
      position: relative;
      color: #3e0f2a;
      font-size: 2.4rem;
      font-weight: 400;
      line-height: 175%;
      letter-spacing: 0.1rem; }
      .symptom-list li a::before {
        content: "";
        position: absolute;
        width: 2.7rem;
        height: 1.6rem;
        bottom: -1rem;
        left: 50%;
        transform: translateX(-50%);
        background: #79b9d6;
        opacity: 0;
        clip-path: polygon(100% 0, 0 0, 50% 100%); }
    .symptom-list li.active a {
      background: #79b9d6;
      color: #1b1e1f; }
      .symptom-list li.active a::before {
        opacity: 1; }
  .symptom-tab-head {
    margin-bottom: 4.2rem; }
  .symptom-tab-main {
    padding-top: 4.2rem;
    padding-bottom: 6.4rem;
    background: url(assets/img/symptom.jpg) no-repeat center;
    background-size: cover; }
  .symptom-tab-gp {
    display: none;
    flex-wrap: wrap; }
    .symptom-tab-gp .wrap {
      padding-left: 3.5rem;
      padding-right: 4rem;
      margin-bottom: 8rem; }
    .symptom-tab-gp .box {
      opacity: 0;
      -webkit-transform: translate(0, 35px);
      transform: translate(0, 35px);
      transition: all 0.5s ease; }
      .symptom-tab-gp .box:first-child {
        width: calc(100% - 40.5rem);
        padding-right: 7rem; }
      .symptom-tab-gp .box:last-child {
        padding-top: .8rem;
        width: 40.5rem; }
        .symptom-tab-gp .box:last-child img {
          width: 100%;
          box-shadow: 0 0 2.4rem rgba(168, 165, 167, 0.1); }
    .symptom-tab-gp .desc p {
      color: #3e0f2a;
      font-size: 1.6rem;
      font-weight: 400;
      line-height: 180%;
      letter-spacing: 0.1rem; }
    .symptom-tab-gp.active {
      display: flex; }
      .symptom-tab-gp.active .box {
        animation: fade_in_0 500ms 500ms ease-in-out;
        animation-fill-mode: forwards; }
      .symptom-tab-gp.active .symptom-tab-list li {
        animation: fade_in_0 500ms 500ms ease-in-out;
        animation-fill-mode: forwards; }
  .symptom-tab-list {
    padding: 0 1.3rem; }
    .symptom-tab-list li {
      width: calc((100% - 2.001rem) / 3);
      margin-right: 1rem;
      opacity: 0;
      -webkit-transform: translate(0, 35px);
      transform: translate(0, 35px);
      transition: all 0.5s ease; }
      .symptom-tab-list li:nth-child(3n) {
        margin-right: 0; }
      .symptom-tab-list li a {
        position: relative;
        z-index: 0;
        display: block; }
        .symptom-tab-list li a .txt {
          position: absolute;
          left: 0;
          width: 100%;
          top: 50%;
          text-align: center;
          transform: translateY(-50%);
          color: #FFFFFF;
          font-size: 2rem;
          font-weight: 500;
          line-height: 175%;
          letter-spacing: 0.1rem;
          display: block; }
        .symptom-tab-list li a::before {
          content: "";
          position: absolute;
          width: 100%;
          height: 100%;
          top: 0;
          left: 0;
          background: rgba(62, 15, 42, 0.29);
          pointer-events: none;
          transition: all 0.35s; }
        .symptom-tab-list li a::after {
          content: "";
          position: absolute;
          width: 2.6rem;
          height: 2.6rem;
          bottom: 1.2rem;
          right: .9rem;
          background: url(assets/img/arrow-right.svg) no-repeat center;
          background-size: cover; }
        .symptom-tab-list li a:hover::before {
          opacity: 0; }
        .symptom-tab-list li a:hover .txt {
          text-shadow: 0 0 0.4rem #3e0f2a, 0 0 0.4rem #3e0f2a; }
        .symptom-tab-list li a .img {
          display: block; }
        .symptom-tab-list li a img {
          width: 100%;
          aspect-ratio: 4 / 1.98;
          object-fit: cover; }
  .symptom .title-default-01 {
    margin-bottom: 5rem; }

.feature {
  padding-top: 9.5rem; }
  .feature .title-default-01 {
    margin-bottom: 2rem; }
  .feature-gp {
    width: 100%;
    max-width: 120rem;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 8.8rem; }
    .feature-gp:last-child {
      margin-bottom: 0; }
    .feature-gp-box:first-child {
      margin-right: -12.201rem;
      width: calc(100% - 76.2rem + 12.2rem);
      position: relative;
      z-index: 1;
      padding-left: 4.5rem;
      padding-right: 4.5rem; }
      .feature-gp-box:first-child::before {
        content: "";
        position: absolute;
        width: 100%;
        height: calc(100% - 7.4rem);
        top: 3.2rem;
        left: 0;
        border-radius: .6rem;
        z-index: -1;
        background: #FFFFFF;
        box-shadow: 0 0 2.4rem rgba(168, 165, 167, 0.5); }
    .feature-gp-box:last-child {
      width: calc(76.2rem + 12rem);
      margin-right: -12rem; }
      .feature-gp-box:last-child img {
        width: 100%; }
    .feature-gp-box > p {
      color: #3e0f2a;
      font-size: 1.6rem;
      font-weight: 400;
      line-height: 164%;
      letter-spacing: 0.05rem;
      margin-bottom: 3rem; }
    .feature-gp-box .btn-gp-01 {
      margin-left: -4.5rem;
      margin-right: -4.5rem;
      width: calc(100% + 9rem); }
    .feature-gp:nth-child(2n) .feature-gp-box:first-child {
      order: 1;
      margin-left: -12.201rem;
      margin-right: 0; }
    .feature-gp:nth-child(2n) .feature-gp-box:last-child {
      margin-right: 0;
      margin-left: -12rem; }
  .feature-wrap {
    position: relative;
    z-index: 0; }
    .feature-wrap::before {
      content: "";
      position: absolute;
      width: 118.4rem;
      height: calc(100% - 45rem);
      z-index: -1;
      top: 23.5rem;
      left: calc(50% + 12.8rem);
      transform: translateX(-50%);
      background: rgba(237, 210, 217, 0.46) url(assets/img/feature-bg.png) no-repeat top 14.5rem right 11rem;
      background-size: 85.7rem; }

.greeting {
  position: relative;
  z-index: 0;
  padding-top: 7rem; }
  .greeting::before {
    content: "";
    position: absolute;
    width: 100%;
    height: 57.8rem;
    bottom: 0;
    left: 0;
    z-index: -1;
    background: url(assets/img/greeting-bg.png) no-repeat center bottom;
    background-size: cover; }
  .greeting-gp-box {
    position: relative; }
    .greeting-gp-box:first-child {
      width: calc(100% - 55.1rem);
      padding-top: 7.5rem;
      padding-left: 9rem;
      padding-right: 7rem; }
    .greeting-gp-box:last-child {
      width: 55.1rem; }
    .greeting-gp-box .desc {
      position: absolute;
      top: 2.2rem;
      right: 12.2rem;
      display: flex;
      padding-top: 7rem; }
      .greeting-gp-box .desc::before {
        content: "";
        position: absolute;
        width: 4.3rem;
        height: 5.1rem;
        top: 0;
        left: 50%;
        transform: translateX(-50%);
        background: url(assets/img/logo-02.png) no-repeat center;
        background-size: contain; }
      .greeting-gp-box .desc p {
        font-size: 1.4rem;
        font-weight: 500;
        letter-spacing: .3rem;
        color: #3e0f2a;
        writing-mode: vertical-lr; }
        .greeting-gp-box .desc p .item {
          font-size: 1.5rem; }
          .greeting-gp-box .desc p .item:last-child {
            margin-top: 1.7rem;
            font-size: 2rem; }
        .greeting-gp-box .desc p .last {
          font-size: 1.5rem; }
    .greeting-gp-box > p {
      padding-left: 5.3rem;
      color: #3e0f2a;
      font-size: 1.6rem;
      font-weight: 400;
      line-height: 186%;
      letter-spacing: 0.08rem;
      margin-bottom: 6.8rem; }
  .greeting .title-default-01 {
    margin-bottom: 7.5rem; }

.info {
  padding-top: 12.5rem;
  padding-bottom: 14rem;
  background: url(assets/img/info-bg.png) no-repeat center;
  background-size: cover; }
  .info-gp-box:first-child {
    padding-right: 7rem;
    width: calc(100% - 49.6rem); }
  .info-gp-box:last-child {
    padding-top: 8.5rem;
    width: 49.6rem; }
    .info-gp-box:last-child p {
      color: #3e0f2a;
      font-size: 1.7rem;
      font-weight: 400;
      line-height: 175%;
      letter-spacing: 0.17rem;
      margin-bottom: 3.4rem; }
  .info-gp-box iframe {
    width: 100%;
    height: 26rem;
    border: 0;
    vertical-align: top;
    margin-bottom: -0.9rem; }
  .info-gp-box .logo {
    margin-bottom: 2.5rem; }
    .info-gp-box .logo img {
      width: 31rem; }
  .info-gp-box .btn-default-01 a {
    margin-top: 4.2rem;
    height: 5rem;
    max-width: 25.5rem; }
  .info-subject {
    background: #e6837e;
    border-radius: .7rem;
    margin-top: 3.7rem;
    margin-bottom: 3rem;
    padding: .7rem 1.8rem;
    color: #FFFFFF;
    font-size: 1.8rem;
    font-weight: 700;
    line-height: 150%;
    letter-spacing: 0.17rem; }
  .info .title-default-01 {
    margin-bottom: 6.8rem; }

.top-column {
  padding-top: 13.6rem;
  padding-bottom: 22.2rem;
  background: url(assets/img/column-bg.png) no-repeat top 8rem left 12.5rem;
  background-size: 160.9rem;
  position: relative; }
  .top-column-wrap {
    padding: 6.3rem 3.2rem 3.2rem 8rem;
    border: #ef9490 solid 1px;
    background: #FFFFFF;
    box-shadow: 0 0 1.6rem rgba(230, 131, 126, 0.28);
    border-radius: 1.7rem / .9rem; }
  .top-column .top-news-btn {
    padding-right: 3rem; }
  .top-column .title-default-01 {
    margin-bottom: 4rem; }

.column-list li {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  padding: 1rem 0;
  background: url(assets/img/icon-border-02.png) repeat-x center bottom; }
  .column-list li:last-child {
    background: transparent; }
  .column-list li .img {
    width: 12.1rem; }
    .column-list li .img img {
      width: 100%;
      border-radius: .4rem; }
  .column-list li .column-title-01 {
    padding-left: 2rem;
    width: calc(100% - 12.1rem); }
.column-title-01 {
  color: #eb7d78;
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 175%;
  letter-spacing: 0; }

.slide-list {
  width: 100%;
  overflow: hidden;
  margin-bottom: 7.5rem; }
  .slide-list ul {
    display: flex;
    width: calc(34.2rem * 6);
    animation: slideAnimation 25s linear infinite; }
    .slide-list ul li {
      width: 33.2rem;
      flex-shrink: 0;
      margin: 0 .5rem; }
      .slide-list ul li img {
        width: 100%; }

@keyframes slideAnimation {
  0% {
    transform: translateX(0); }
  100% {
    transform: translateX(-100%); } }
@media (max-width: 960px) {
  .mv-slide img {
    height: 36.5rem;
    object-fit: cover; }
  .mv-cont {
    top: 32%; }
    .mv-cont h2 {
      font-size: 2rem;
      margin-bottom: 2rem; }
      .mv-cont h2 span {
        font-size: 2.4rem; }
    .mv-cont p {
      font-size: 1.5rem;
      max-width: 100%; }
  .mv .top-news {
    padding: 0 1.5rem;
    bottom: 1.5rem; }
  .mv .news-list {
    margin-bottom: 0; }

  .news-list {
    width: 100%; }

  .top-news-btn.vs-02 a {
    font-size: 1.5rem; }

  .title-page {
    top: 0;
    font-size: 3rem;
    left: 1.5rem;
    writing-mode: initial; }

  .concept {
    padding-top: 5rem; }
    .concept-wrap {
      padding-top: 18rem;
      padding-bottom: 23rem; }
      .concept-wrap p {
        font-size: 1.5rem;
        line-height: 175%;
        margin-right: 0; }
        .concept-wrap p:nth-child(2) {
          margin-right: 0; }
        .concept-wrap p:nth-child(3) {
          margin-right: 0; }
        .concept-wrap p .item-01 {
          font-size: 1.7rem; }
        .concept-wrap p .item-02 {
          font-size: 1.6rem; }
      .concept-wrap .desc {
        justify-content: space-between;
        max-width: 42rem;
        margin-left: auto;
        margin-right: auto; }
      .concept-wrap .icon-img.vs-01 img {
        width: 20rem; }
      .concept-wrap .icon-img.vs-02 {
        bottom: 2rem;
        left: -9rem; }
        .concept-wrap .icon-img.vs-02 img {
          width: 26rem; }
      .concept-wrap .icon-img.vs-03 {
        right: -2rem;
        top: auto;
        bottom: 0; }
        .concept-wrap .icon-img.vs-03 img {
          width: 28rem; }
    .concept-banner {
      position: relative;
      margin-right: auto;
      margin-left: auto;
      bottom: 0;
      margin-top: 5rem;
      width: 100%;
      max-width: 60rem; }

  .trouble {
    padding-bottom: 4.5rem; }
    .trouble-wrap {
      padding-left: 0; }
    .trouble-list li {
      width: calc((100% - 1.501rem) / 2);
      margin-right: 1.5rem;
      margin-bottom: 1.5rem; }
      .trouble-list li:nth-child(2n) {
        margin-right: 0; }
      .trouble-list li a .txt {
        font-size: 1.5rem; }
        .trouble-list li a .txt::before {
          width: 2rem;
          height: 2rem;
          right: .8rem; }
      .trouble-list li a .img img {
        height: 15rem;
        object-fit: cover; }
      .trouble-list li a .desc {
        padding: 1rem; }
      .trouble-list li a:hover .txt {
        min-height: 4rem; }

  .symptom {
    padding-top: 5.4rem; }
    .symptom-list li {
      width: calc((100% - 2.001rem) / 3);
      margin-right: 1rem; }
      .symptom-list li a {
        font-size: 1.3rem;
        letter-spacing: -0.1rem; }
    .symptom-tab-main {
      padding-top: 3rem;
      padding-bottom: 2rem; }
    .symptom-tab-gp .wrap {
      padding-left: 0;
      padding-right: 0;
      margin-bottom: 3.5rem; }
    .symptom-tab-gp .box:first-child {
      width: 100%;
      order: 1;
      padding-right: 0; }
    .symptom-tab-gp .box:last-child {
      width: 100%;
      padding-top: 0;
      margin-bottom: 2.4rem; }
    .symptom-tab-gp .box p {
      font-size: 1.5rem;
      letter-spacing: 0;
      line-height: 175%; }
    .symptom-tab-list {
      padding: 0;
      justify-content: center; }
      .symptom-tab-list li {
        width: calc((100% - 1.001rem) / 2);
        margin-bottom: 1rem; }
        .symptom-tab-list li:nth-child(2n) {
          margin-right: 0; }
        .symptom-tab-list li a::after {
          width: 2rem;
          height: 2rem;
          bottom: .8rem; }
        .symptom-tab-list li a .txt {
          font-size: 1.7rem; }
    .symptom .title-default-01 {
      margin-bottom: 3rem; }

  .feature {
    padding-top: 5rem; }
    .feature-gp {
      margin-bottom: 6rem; }
      .feature-gp-box:first-child {
        width: 100%;
        order: 1;
        margin-right: 0;
        padding-left: 1.5rem;
        padding-right: 1.5rem;
        padding-bottom: 1.5rem; }
        .feature-gp-box:first-child::before {
          top: 0;
          height: 100%; }
      .feature-gp-box:last-child {
        width: 100%; }
      .feature-gp-box > p {
        font-size: 1.5rem;
        line-height: 175%;
        margin-bottom: 2.5rem; }
      .feature-gp-box .btn-gp-01 {
        margin-left: 0;
        margin-right: 0;
        width: 100%;
        justify-content: center; }
      .feature-gp:nth-child(2n) .feature-gp-box:first-child {
        margin-left: 0; }
      .feature-gp:nth-child(2n) .feature-gp-box:last-child {
        margin-left: 0; }
    .feature .title-default-01 {
      margin-bottom: 2.5rem; }

  .greeting {
    padding-top: 5.5rem;
    padding-bottom: 1.5rem; }
    .greeting-gp-box:first-child {
      width: 100%;
      padding-left: 0;
      padding-right: 0;
      order: 1;
      padding-top: 2.5rem; }
    .greeting-gp-box:last-child {
      width: 100%;
      text-align: center; }
    .greeting-gp-box > p {
      padding-left: 0;
      font-size: 1.5rem;
      line-height: 175%;
      margin-bottom: 2.4rem; }
    .greeting-gp-box .desc {
      right: 0; }
    .greeting-gp .btn-gp-01 {
      justify-content: center; }
    .greeting .title-default-01 {
      margin-bottom: 1.5rem; }

  .info {
    padding-top: 5.2rem;
    padding-bottom: 6rem; }
    .info-gp-box:first-child {
      width: 100%;
      padding-right: 0; }
    .info-gp-box:last-child {
      width: 100%; }
      .info-gp-box:last-child p {
        font-size: 1.5rem;
        margin-bottom: 1.5rem; }
    .info-gp-box .btn-default-01 a {
      margin-top: 2.4rem;
      margin-left: auto;
      margin-right: auto; }
    .info-gp-box iframe {
      height: 24rem; }
    .info-gp-box .logo img {
      width: 27rem; }
    .info-subject {
      font-size: 1.5rem;
      margin-top: 2.5rem; }
    .info .title-default-01 {
      margin-bottom: 3rem; }

  .top-column {
    padding-top: 5rem;
    padding-bottom: 6rem; }
    .top-column-wrap {
      padding: 1.5rem; }
    .top-column .top-news-btn {
      padding-right: 0; }

  .column-title-01 {
    font-size: 1.5rem; }
  .column-list li {
    padding-top: 1.5rem; }
    .column-list li .img {
      margin-bottom: .8rem; }

  .slide-list {
    margin-bottom: 6rem; }
    .slide-list ul {
      width: calc(26rem * 6); }
      .slide-list ul li {
        width: 25rem; } }
@media (max-width: 767px) {
  .mv .top-news-wrap {
    width: 100%; }

  .column-list li .img {
    width: 100%; }
    .column-list li .img img {
      border-radius: 1.2rem; }
  .column-list li .column-title-01 {
    padding-left: 0;
    width: 100%; }

  .trouble-list li {
    width: 100%;
    margin-right: 0; } }
.mt-60 {
  margin-top: 6rem; }

.mt-50 {
  margin-top: 5rem; }

.mb-70 {
  margin-bottom: 7rem; }

.mb-100,
.mb-101 {
  margin-bottom: 10rem; }

.mb150 {
  margin-bottom: 15rem; }

.catalogue {
  margin-top: 2.5rem;
  margin-bottom: 10rem; }
  .catalogue-title {
    display: none; }
  .catalogue-gp {
    max-width: 120.001rem;
    margin-left: auto;
    margin-right: auto; }
    .catalogue-gp:not(.style-4button) {
      padding: 2rem 5rem 3.9rem;
      background-color: rgba(255, 255, 255, 0.2);
      border-radius: 1rem;
      border: 1px solid #353535;
      box-shadow: 0 0.4rem 1rem rgba(0, 0, 0, 0.08); }
  .catalogue-list ul {
    display: flex;
    flex-wrap: wrap; }
    .catalogue-list ul li {
      margin-right: 3rem; }
      .catalogue-list ul li:last-child {
        margin-right: 0; }
      .catalogue-list ul li a {
        font-size: 1.8rem;
        font-weight: 500;
        line-height: 175%;
        color: #333333;
        letter-spacing: .1rem;
        transition: ease all 500ms;
        position: relative;
        padding-top: 1.1rem;
        padding-bottom: 0.9rem;
        display: block;
        letter-spacing: 0;
        border-bottom: #333333 solid 0.1rem;
        padding-right: 3rem; }
        .catalogue-list ul li a::before {
          content: "";
          display: block;
          position: absolute;
          top: 50%;
          right: 1rem;
          width: 1.1rem;
          aspect-ratio: 1/1;
          z-index: 5;
          -webkit-mask: url(assets/img/icon_arrow.svg) center/100% no-repeat;
          mask: url(assets/img/icon_arrow.svg) center/100% no-repeat;
          background: #333333;
          transform: translateY(-50%); }
        .catalogue-list ul li a::after {
          content: "";
          display: block;
          position: absolute;
          bottom: -1px;
          left: 0;
          width: 0;
          height: 1px;
          z-index: 1;
          pointer-events: none;
          background: #e28787;
          transition: 0.5s; }
        .catalogue-list ul li a:hover {
          padding-left: 1rem;
          color: #e28787;
          font-weight: bold; }
          .catalogue-list ul li a:hover::before {
            animation: arrowMove 0.6s ease 0s 1 both;
            background: #e28787; }
          .catalogue-list ul li a:hover::after {
            width: 100%; }
  .catalogue-list.style-1columns li {
    width: 100%;
    margin-right: 0; }
  .catalogue-list.style-2columns li {
    width: calc((100% - 3.001rem) / 2); }
    .catalogue-list.style-2columns li:nth-child(2n) {
      margin-right: 0; }
  .catalogue-list.style-3columns li {
    width: calc((100% - 6.001rem) / 3); }
    .catalogue-list.style-3columns li:nth-child(3n) {
      margin-right: 0; }
  .catalogue-list.style-4button ul {
    justify-content: center;
    margin-bottom: -1.5rem; }
    .catalogue-list.style-4button ul li {
      margin-bottom: 1.5rem;
      margin-right: 1.5rem; }
      .catalogue-list.style-4button ul li:last-child {
        margin-right: 0; }
      .catalogue-list.style-4button ul li.current-menu-item a, .catalogue-list.style-4button ul li:hover a {
        background: #0e7ebe;
        color: #ffffff;
        font-weight: 500; }
      .catalogue-list.style-4button ul li a {
        border-bottom: 0;
        color: #0e7ebe;
        position: relative;
        transition: all 0.35s;
        padding: 1rem 2rem; }
        .catalogue-list.style-4button ul li a::before, .catalogue-list.style-4button ul li a::after {
          content: none; }
        @media (min-width: 767.5px) {
          .catalogue-list.style-4button ul li a {
            background: rgba(14, 126, 190, 0.3);
            border: #0e7ebe solid 1px; } }
        @media (max-width: 767px) {
          .catalogue-list.style-4button ul li a {
            display: flex;
            justify-content: center;
            align-items: center;
            width: 100%;
            height: 100%;
            padding: 1rem; } }

.sitemap-wrap {
  padding: 6.5rem 0 8.5rem; }
.sitemap-title {
  color: #0e7ebe;
  font-size: 3.2rem;
  font-weight: 700;
  line-height: 150%;
  letter-spacing: 0;
  margin-bottom: 3.5rem; }
.sitemap-list {
  margin-bottom: 8.5rem; }
  .sitemap-list li {
    width: calc((100% - 3rem) / 3);
    margin-right: 1.5rem;
    margin-bottom: 2rem;
    position: relative;
    padding-left: 2rem; }
    .sitemap-list li::before {
      content: "";
      position: absolute;
      top: 1.2rem;
      left: 0;
      width: .6rem;
      height: .6rem;
      background: #0e7ebe;
      border-radius: 100%; }
    @media (min-width: 960.5px) {
      .sitemap-list li:nth-child(3n) {
        margin-right: 0; } }
    .sitemap-list li a {
      color: #333;
      font-size: 1.6rem;
      font-weight: 500;
      line-height: 150%;
      letter-spacing: 0;
      transition: all 0.35s; }
      .sitemap-list li a:hover {
        color: #0e7ebe; }

.news-gp {
  padding: 5.5rem 0 6rem; }
  .news-gp-item:first-child {
    width: calc(100% - 30rem); }
  .news-gp-item:last-child {
    width: 30rem;
    padding-left: 5rem; }
  .news-gp .news-list {
    margin-bottom: 6rem;
    width: 100%; }
    .news-gp .news-list li a {
      font-size: 1.6rem; }

.pagenavi-wrap {
  margin-bottom: 6rem; }
  .pagenavi-wrap ul {
    display: flex;
    justify-content: center; }
    .pagenavi-wrap ul li {
      margin: 0 .8rem; }
      .pagenavi-wrap ul li * {
        height: 4rem;
        border: #e28787 solid 0.1rem;
        display: flex;
        align-items: center;
        justify-content: center;
        padding: 0 1.55rem;
        color: #727272;
        transition: all 0.35s; }
      .pagenavi-wrap ul li .current, .pagenavi-wrap ul li a:hover {
        background: #e28787;
        color: #FFFFFF; }

.archive-gp {
  border: #e28787 solid 0.1rem;
  margin-bottom: 5rem; }
  .archive-gp:last-child {
    margin-bottom: 0; }
.archive-title {
  color: #fff;
  font-size: 2rem;
  font-weight: 700;
  line-height: 150%;
  letter-spacing: 0;
  background: #e28787;
  text-align: center;
  padding: 1rem;
  cursor: pointer;
  position: relative; }
  .archive-title::before {
    content: "";
    position: absolute;
    right: 1.5rem;
    top: 50%;
    width: 0.8rem;
    height: .8rem;
    transform: translateY(-50%) rotate(135deg);
    position: absolute;
    content: "";
    border-top: .1rem solid #FFFFFF;
    border-right: .1rem solid #FFFFFF;
    transition: all 0.35s; }
  .archive-title.active::before {
    transform: translateY(-50%) rotate(315deg); }
.archive-list {
  padding: 0 1.5rem;
  max-height: 32rem;
  overflow: auto; }
  .archive-list li {
    border-bottom: #333 solid .1rem; }
    .archive-list li:last-child {
      border-bottom: 0; }
    .archive-list li a {
      color: #333;
      font-size: 1.6rem;
      font-weight: 700;
      line-height: 150%;
      letter-spacing: 0;
      display: block;
      padding: 1.3rem;
      transition: all 0.35s; }
      .archive-list li a:hover {
        color: #e28787; }

.single-gp .date {
  margin-bottom: 2.8rem; }
.single-gp .image {
  margin-bottom: 1.5rem; }
.single-wrap :is(h1, h2, h3, h4, h5, h6) {
  font-weight: 700;
  line-height: 150%;
  letter-spacing: 0;
  color: #000000; }
.single-wrap :is(h1, h2, h3, h4, h5, h6, p, ul, ol, .wp-block-image) {
  margin-bottom: 1.5rem; }
.single-wrap ul li {
  position: relative;
  padding-left: 1.5rem; }
  .single-wrap ul li::before {
    content: '';
    position: absolute;
    left: 0;
    top: .5rem;
    width: 1rem;
    height: 1rem;
    border-radius: 100%;
    background: #00c0ff; }
    @media (max-width: 960px) {
      .single-wrap ul li::before {
        top: .75rem; } }
.single-wrap a {
  color: #233b5b;
  text-decoration: underline;
  transition: all 0.35s; }
  .single-wrap a:hover {
    text-decoration: none; }
.single-wrap ol {
  padding-left: 1.5rem; }
  .single-wrap ol li {
    list-style: decimal; }
.single-wrap blockquote {
  background: #EEEEEE;
  padding: 5rem;
  border-radius: 1.5rem;
  position: relative;
  margin: 5rem 0; }
  .single-wrap blockquote::before {
    content: "";
    width: 3.4rem;
    height: 3rem;
    position: absolute;
    left: 2rem;
    top: -1.2rem;
    background-image: url(assets/img/quote.svg);
    background-position: left top;
    background-repeat: no-repeat;
    background-size: contain; }
  .single-wrap blockquote p:last-child {
    margin-bottom: 0; }
.single-wrap :is(p, li, blockquote) {
  font-size: 1.6rem;
  line-height: 170%;
  letter-spacing: 0;
  color: #000000;
  font-weight: 500; }
.single-wrap h1 {
  font-size: 3.2rem; }
.single-wrap h2 {
  font-size: 2.4rem; }
.single-wrap h3 {
  font-size: 2.2rem; }
.single-wrap h4 {
  font-size: 2rem; }
.single-wrap h5 {
  font-size: 1.8rem; }
.single-wrap h6 {
  font-size: 1.6rem; }

.nextpre_area-item a,
.nextpre_area-item span {
  transition: all 0.35s;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 25.5rem;
  font-size: 1.6rem;
  color: #262c34;
  height: 6.5rem;
  border: #e28787 solid 0.1rem;
  border-radius: 3.3rem;
  font-family: "Outfit", sans-serif;
  background: #FFF; }
.nextpre_area-item span {
  opacity: 0.5; }
.nextpre_area-item a:hover {
  color: #FFF;
  background: #e28787; }

.nextpre_area.vs-02 .nextpre_area-item a,
.nextpre_area.vs-02 .nextpre_area-item span {
  border-color: #e28787; }
.nextpre_area.vs-02 .nextpre_area-item a:hover {
  background: #e28787; }

.single-title-01 {
  color: #000000;
  font-size: 3.2rem;
  font-weight: 700;
  line-height: 150%;
  letter-spacing: 0; }

.column-gp {
  padding: 5.5rem 0 6rem; }

.wp-column {
  padding: 2.4rem 0 4rem; }

.column-gp-01 {
  margin-bottom: 5rem; }
  .column-gp-01 li {
    width: calc((100% - 4.501rem) / 4);
    margin-right: 1.5rem;
    margin-bottom: 1.5rem;
    padding: 1.5rem;
    box-shadow: 0 0 1rem rgba(0, 0, 0, 0.2); }
    .column-gp-01 li:nth-child(4n) {
      margin-right: 0; }
    .column-gp-01 li .img {
      margin-bottom: 1.5rem; }
      .column-gp-01 li .img img {
        width: 100%;
        aspect-ratio: 4 / 2.8;
        object-fit: cover; }
    .column-gp-01 li h4 {
      color: #333;
      font-size: 1.8rem;
      font-weight: 700;
      line-height: 140%;
      letter-spacing: 0;
      margin-bottom: .7rem; }
      .column-gp-01 li h4 a {
        display: block;
        display: -webkit-box;
        max-width: 100%;
        -webkit-line-clamp: 2;
        -webkit-box-orient: vertical;
        overflow: hidden;
        text-overflow: ellipsis; }
    .column-gp-01 li p {
      color: #333;
      font-size: 1.6rem;
      font-weight: 400;
      line-height: 170%;
      letter-spacing: 0; }

.column-cate-list {
  margin-bottom: 3rem; }
  .column-cate-list li {
    margin-right: 1.7rem;
    margin-bottom: 1.7rem; }
    .column-cate-list li a {
      background: #FFFFFF;
      display: block;
      padding: .9rem 3.2rem;
      font-size: 1.2rem;
      color: #777777;
      transition: all 0.35s;
      border: #3b4148 solid .1rem; }
      .column-cate-list li a.active, .column-cate-list li a:hover {
        background: #3b4148;
        color: #FFFFFF; }

.main_page .title-default-01 {
  font-size: 3rem;
  font-weight: 700;
  margin-bottom: 4rem; }
.main_page h4 {
  color: #ffffff;
  font-size: 2.6rem;
  font-weight: 700;
  line-height: 140%;
  letter-spacing: 0.3rem;
  padding: 1.5rem 2rem;
  margin-bottom: 2.4rem;
  background: linear-gradient(270deg, rgba(226, 135, 135, 0.5) 0%, #e28787 100%); }
  .main_page h4.title-01 {
    color: #3e0f2a;
    background: transparent;
    padding-left: 0;
    padding-right: 0;
    border-bottom: #3e0f2a solid 1px; }
.main_page h5 {
  color: #e28787;
  font-size: 2.4rem;
  font-weight: 700;
  line-height: 140%;
  letter-spacing: 0;
  border-bottom: 1px solid #e28787;
  padding-bottom: 1.5rem;
  margin-bottom: 2rem; }
.main_page table {
  width: 100%;
  border-spacing: 0;
  border-collapse: collapse; }
  .main_page table td {
    border-top: #cccccc solid 1px;
    border-bottom: #cccccc solid 1px;
    padding: 1.5rem 2rem;
    font-size: 1.6rem;
    line-height: 185%;
    color: #333333;
    font-weight: 500;
    letter-spacing: 0;
    vertical-align: middle; }
    .main_page table td:first-child {
      width: 32rem;
      color: #ffffff;
      font-weight: bold;
      background-color: #e28787; }
  .main_page table.vs-02 td:first-child {
    background: transparent;
    color: #333333; }
  .main_page table.vs-03 td {
    border-top: 0;
    border-right: #cccccc solid 1px;
    border-left: #cccccc solid 1px; }
    .main_page table.vs-03 td:first-child {
      background: transparent;
      color: #333333; }
  .main_page table.vs-03 tr:first-child td {
    background: #e28787;
    color: #FFFFFF;
    border-top: 0;
    border-bottom: 0; }
  .main_page table.vs-04 td {
    border-top: 0; }
    .main_page table.vs-04 td:first-child {
      background: transparent;
      color: #333333;
      width: 50%; }
  .main_page table.vs-04 tr:first-child td {
    background: #e28787;
    color: #FFFFFF;
    border-bottom: 0; }
  .main_page table.profile tr:last-child td:first-child::before {
    height: 60%; }
  .main_page table.profile td {
    position: relative;
    border: 0;
    padding-top: 1rem;
    padding-bottom: 1rem; }
    .main_page table.profile td:first-child {
      letter-spacing: .1rem;
      font-weight: bold;
      width: 12rem;
      background-color: transparent;
      font-family: "Montserrat", sans-serif;
      padding-left: 0;
      color: #333333; }
      .main_page table.profile td:first-child::before {
        content: "";
        position: absolute;
        width: 1px;
        height: 125%;
        background-color: rgba(226, 135, 135, 0.3);
        right: 0rem;
        top: 40%; }
    .main_page table.profile td:last-child {
      padding-left: 3rem;
      padding-right: 0;
      font-size: 1.6rem; }
      .main_page table.profile td:last-child::before {
        content: "";
        position: absolute;
        width: 1.5rem;
        height: 1.5rem;
        background-color: #e28787;
        border-radius: 100%;
        left: -0.8rem;
        top: 50%;
        transform: translateY(-50%); }
.main_page .group-before {
  position: relative;
  padding-bottom: 10rem;
  border-bottom: #cec9c6 solid 1px;
  margin-bottom: 9rem; }
.main_page ul {
  display: flex;
  flex-wrap: wrap;
  border: 0.4rem solid #e28787;
  padding: 2rem 3rem;
  margin-bottom: 3rem; }
  @media (max-width: 767px) {
    .main_page ul {
      border: 0.3rem solid #e28787; } }
  .main_page ul li {
    width: calc((100% - 1.501rem) / 2);
    margin-right: 1.5rem;
    margin-bottom: 1rem;
    padding-left: 2rem;
    position: relative;
    font-size: 1.6rem;
    color: #333333; }
    .main_page ul li::before {
      content: "";
      position: absolute;
      width: 1.2rem;
      height: 1.2rem;
      top: .9rem;
      left: 0;
      border-radius: 100%;
      background: #e28787; }
    .main_page ul li:nth-child(2n) {
      margin-right: 0; }
    .main_page ul li.last {
      padding-left: 0; }
      .main_page ul li.last::before {
        content: none; }
    @media (min-width: 960.5px) {
      .main_page ul li:nth-last-child(2), .main_page ul li:last-child {
        margin-bottom: 0; } }
  .main_page ul.vs-02 li {
    padding-left: 2.5rem; }
    .main_page ul.vs-02 li::before {
      width: 2rem;
      height: 2rem;
      top: .4rem;
      -webkit-mask: url(assets/img/check.svg) center/100% no-repeat;
      mask: url(assets/img/check.svg) center/100% no-repeat; }
    .main_page ul.vs-02 li.last {
      padding-left: 0; }
.main_page .gp-p p {
  margin-bottom: 3rem; }
  .main_page .gp-p p:last-child {
    margin-bottom: 0; }
.main_page .group-maps--iframe iframe {
  width: 100%;
  height: 56.5rem;
  border: 0;
  vertical-align: top; }

.column-assign {
  border-top: #cccccc solid 1px;
  border-left: #cccccc solid 1px; }
  .column-assign .item {
    width: 50%;
    border-bottom: #cccccc solid 1px;
    border-right: #cccccc solid 1px;
    padding: 1.5rem; }

.inchou {
  display: block;
  text-align: right;
  font-size: 2rem;
  color: #0e7ebe;
  line-height: 150%;
  margin-top: 3rem; }
  .inchou strong {
    font-size: 3rem;
    font-weight: 500;
    display: inline-block;
    margin-left: 1rem; }
    @media (max-width: 767px) {
      .inchou strong {
        font-size: 2.4rem; } }

.column-img-right {
  display: flex;
  flex-wrap: wrap; }
  .column-img-right > div:first-child {
    width: calc(100% - 42rem);
    padding-right: 5rem; }
  .column-img-right > div:last-child {
    width: 42rem; }
    .column-img-right > div:last-child img {
      width: 100%;
      object-fit: cover;
      border-radius: .5rem;
      aspect-ratio: 4 / 2.7; }
  @media (max-width: 960px) {
    .column-img-right > div:first-child {
      width: 100%;
      padding-right: 0;
      order: 1; }
    .column-img-right > div:last-child {
      order: 0;
      width: 100%;
      margin-bottom: 1.5rem; } }
  .column-img-right.vs-02 > div:last-child img {
    aspect-ratio: 4 / 4.6; }
.column-img-left {
  display: flex;
  flex-wrap: wrap; }
  .column-img-left > div:first-child {
    width: 42rem; }
    .column-img-left > div:first-child img {
      width: 100%;
      object-fit: cover;
      border-radius: .5rem;
      aspect-ratio: 4 / 2.7; }
      .column-img-left > div:first-child img.img-full {
        aspect-ratio: initial; }
  .column-img-left > div:last-child {
    padding-left: 5rem;
    width: calc(100% - 42rem); }
  @media (max-width: 960px) {
    .column-img-left > div:first-child {
      width: 100%;
      margin-bottom: 1.5rem; }
    .column-img-left > div:last-child {
      padding-left: 0;
      width: 100%; } }
  .column-img-left.vs-02 > div:first-child img {
    aspect-ratio: 4 / 4.6; }
.column-default-30 {
  margin-top: 4rem; }
  @media (max-width: 960px) {
    .column-default-30 {
      margin-top: 2rem; } }
  .column-default-30 .item {
    width: calc((100% - 4.001rem) / 3);
    margin-right: 2rem;
    margin-bottom: 2rem; }
    .column-default-30 .item:nth-child(3n) {
      margin-right: 0; }
    .column-default-30 .item .img {
      margin-bottom: 1.5rem; }
    .column-default-30 .item img {
      border-radius: 1rem;
      width: 100%;
      aspect-ratio: 4 / 2.8;
      object-fit: cover; }
      @media (max-width: 960px) {
        .column-default-30 .item img {
          border-radius: 0.5rem; } }
    @media (max-width: 960px) {
      .column-default-30 .item {
        width: calc((100% - 2.001rem) / 3);
        margin-right: 1rem; } }
  .column-default-30.mb--item {
    margin-bottom: -2rem; }
    .column-default-30.mb--item .item {
      margin-bottom: 2rem; }

@keyframes arrowMove {
  0% {
    opacity: 1;
    transform: translate(0%, -50%); }
  50% {
    opacity: 0;
    transform: translate(120%, -50%); }
  64% {
    opacity: 0;
    transform: translate(-120%, -50%); }
  100% {
    opacity: 1;
    transform: translate(0%, -50%); } }
@media (max-width: 960px) {
  .mb-100, .mb-101 {
    margin-bottom: 6rem; }

  .catalogue {
    margin-bottom: 5rem; }
    .catalogue-gp:not(.style-4button) {
      padding: 1.5rem; }
    .catalogue-list ul li a {
      font-size: 1.4rem; }

  .sitemap-wrap {
    padding: 1rem 0 5.6rem; }
  .sitemap-list {
    margin-bottom: 2.7rem; }
    .sitemap-list li {
      width: calc((100% - 1.501rem) / 2);
      margin-bottom: 1rem; }
      .sitemap-list li:nth-child(2n) {
        margin-right: 0; }
      .sitemap-list li a {
        font-size: 1.5rem; }

  .news-gp-item:first-child {
    width: 100%; }
  .news-gp-item:last-child {
    padding-left: 0;
    width: 100%; }

  .archive-gp {
    margin-bottom: 3rem; }

  .nextpre_area-item a,
  .nextpre_area-item span {
    width: 20rem; }

  .single-title-01 {
    font-size: 2.2rem;
    text-align: justify;
    display: block;
    margin-bottom: 1rem; }

  .single-wrap {
    margin-bottom: 5.4rem; }
    .single-wrap h1 {
      font-size: 2.2rem; }
    .single-wrap h2 {
      font-size: 2.0rem; }
    .single-wrap h3 {
      font-size: 1.8rem; }
    .single-wrap h4 {
      font-size: 1.6rem; }
    .single-wrap h5 {
      font-size: 1.4rem; }
    .single-wrap h6 {
      font-size: 1.3rem; }
    .single-wrap :is(p, li, blockquote) {
      font-size: 1.5rem;
      line-height: 175%; }
    .single-wrap blockquote {
      padding: 2rem;
      margin: 3rem 0; }
      .single-wrap blockquote::before {
        top: -0.5rem;
        width: 2rem;
        height: 1.8rem; }
  .single-title-01 {
    font-size: 2.2rem;
    text-align: justify;
    margin-bottom: 1rem; }

  .nextpre_area-item a,
  .nextpre_area-item span {
    width: 20rem; }

  .column-gp {
    padding-bottom: 0; }

  .wp-column {
    padding: 0 0 1rem; }

  .column-gp-01 {
    margin-bottom: 3rem; }
    .column-gp-01 li {
      width: calc((100% - 1.501rem) / 2); }
      .column-gp-01 li:nth-child(2n) {
        margin-right: 0; }

  .column-cate-list li {
    margin-right: 1.5rem;
    margin-bottom: 1rem; }
    .column-cate-list li a {
      padding: .9rem 1.5rem; }

  .main_page .title-default-01 {
    font-size: 2.4rem;
    margin-bottom: 2rem; }
  .main_page h4 {
    font-size: 2rem;
    padding: 1.5rem; }
  .main_page h5 {
    font-size: 1.8rem; }
  .main_page table {
    border: #e28787 solid 1px; }
    .main_page table td {
      float: left;
      width: 100%;
      border: 0;
      font-size: 1.5rem;
      padding: 1.2rem 1.5rem; }
      .main_page table td:first-child {
        width: 100%; }
    .main_page table.vs-02 td {
      float: initial;
      padding: .8rem 0;
      width: calc((100% - 10rem) / 8); }
      .main_page table.vs-02 td:first-child {
        width: 10rem; }
    .main_page table.vs-03 {
      border: 0; }
      .main_page table.vs-03 td {
        border: #e28787 solid 1px;
        margin-bottom: 4rem;
        position: relative; }
        .main_page table.vs-03 td::before {
          content: attr(data-txt);
          position: absolute;
          background: #e28787;
          color: #FFFFFF;
          top: -3rem;
          left: -1px;
          padding: .1rem .7rem; }
        .main_page table.vs-03 td:first-child {
          background: #e28787;
          color: #FFFFFF; }
          .main_page table.vs-03 td:first-child::before {
            content: none; }
        .main_page table.vs-03 td:last-child {
          margin-bottom: 1rem; }
      .main_page table.vs-03 tr:first-child {
        display: none; }
    .main_page table.vs-032 td {
      margin-bottom: 1rem;
      text-align: center; }
      .main_page table.vs-032 td:first-child {
        margin-bottom: 1rem;
        text-align: center; }
      .main_page table.vs-032 td:last-child {
        margin-bottom: 5rem; }
      .main_page table.vs-032 td:not(:first-child) {
        padding-left: 43rem; }
      .main_page table.vs-032 td::before {
        top: 0;
        height: 100%;
        width: 43rem;
        display: flex;
        align-items: center;
        justify-content: center;
        color: #333333;
        background: transparent;
        border-right: #e28787 solid 1px; }
    .main_page table.vs-04 td {
      width: 35%;
      border-bottom: #cccccc solid 1px;
      float: inherit;
      padding: 1rem .5rem; }
      .main_page table.vs-04 td:first-child {
        width: 65%; }
    .main_page table.vs-04 tr:last-child td {
      border-bottom: 0; }
    .main_page table.profile {
      border: 0; }
      .main_page table.profile td:first-child {
        width: 100%;
        padding-left: 2rem;
        padding-right: 0;
        padding-bottom: 0; }
        .main_page table.profile td:first-child::before {
          right: auto;
          left: -1px;
          height: 100%;
          top: 0; }
      .main_page table.profile td:last-child {
        padding-left: 2rem; }
        .main_page table.profile td:last-child::before {
          top: -2.2rem;
          transform: initial; }
        .main_page table.profile td:last-child::after {
          content: "";
          position: absolute;
          width: 1px;
          height: 100%;
          background-color: rgba(226, 135, 135, 0.3);
          left: -1px;
          top: 0%; }
      .main_page table.profile tr:last-child td:first-child::before {
        height: 100%; }
  .main_page .group-before {
    padding-bottom: 6rem;
    margin-bottom: 5rem; }
  .main_page ul {
    padding: 1.5rem 1.5rem .7rem; }
    .main_page ul li {
      font-size: 1.5rem;
      margin-bottom: .8rem; }
      .main_page ul li::before {
        width: 1rem;
        height: 1rem; }
  .main_page .group-maps--iframe iframe {
    height: 26rem; } }
@media (max-width: 767px) {
  .catalogue-list.style-2columns li, .catalogue-list.style-3columns li {
    width: 100%;
    margin-right: 0; }
  .catalogue-list.style-4button ul {
    margin-bottom: -1rem; }
    .catalogue-list.style-4button ul li {
      width: calc((100% - 1.01rem) / 2);
      margin-right: 1rem;
      margin-bottom: 1rem;
      background: rgba(226, 135, 135, 0.1);
      border: #e28787 solid 1px; }
      .catalogue-list.style-4button ul li:nth-child(2n) {
        margin-right: 0; }

  .sitemap-list li {
    width: 100%;
    margin-right: 0; }
    .sitemap-list li:last-child {
      margin-bottom: 0; }

  .wp-news-gp {
    flex-wrap: wrap !important; }
    .wp-news-gp-item:first-child {
      width: 100%;
      margin-bottom: 5rem; }
    .wp-news-gp-item:last-child {
      width: 100%;
      padding-left: 0; }

  .nextpre_area-item {
    width: calc((100% - 1.501rem) / 2);
    margin-right: 1.5rem; }
    .nextpre_area-item:nth-child(2) {
      width: 100%;
      margin-right: 0;
      margin-top: 1.5rem;
      order: 1; }
    .nextpre_area-item:nth-child(3n) {
      margin-right: 0; }
    .nextpre_area-item a,
    .nextpre_area-item span {
      width: 100%;
      height: 5rem; }

  .column-gp-01 li {
    width: 100%;
    margin-right: 0; }
    .column-gp-01 li:last-child {
      margin-bottom: 0; }

  .main_page ul li {
    width: 100%;
    margin-right: 0; }
  .main_page table.vs-032 td:not(:first-child) {
    padding-left: 21rem;
    padding-right: 0; }
  .main_page table.vs-032 td::before {
    width: 21rem; } }

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