@charset "utf-8";

/* ---------------------------------------------
セクション毎の調整
--------------------------------------------- */
.sec01 {
    background:url(./img/sec01-bk.png) no-repeat right top 10rem, url(./img/sec01-bk2.png) no-repeat left bottom #F3F3F3;
}
#index .sec01 {
    margin-top: -10rem;
}
#low-page .sec01 {
    margin-top: 4rem;
    margin-bottom: 4rem;
    background:#F3F3F3;
}
.sec01-l-center {
  padding-top: 0;
  padding-bottom: 10rem;
  max-width: 100rem;
  margin-right: auto;
  margin-left: auto;
}
#low-page .sec01-l-center {
  padding: 2rem;
}
.sec01-l-center .column-small{
  padding-top: 0;
  background:#fff;
  border:none;
}
.sec01-l-center .btn-web{
    margin: 0rem auto 2rem;
}
.sec01-l-center .caption{
    margin-bottom:1rem;
}
.sec01-l-center .caption-2{
    color:#4B4B4B;
}
.sec01-l-center .l-grid-three{
    margin-bottom:1rem;
}
.sec1_mh{
    text-align:center;
}
.sec02 {
    background: url(./img/sec02-bk.png) no-repeat center center;
    background-size: cover;
    background-attachment: fixed;
}
.sec02-l-center {
  padding-top: 10rem;
  padding-bottom: 10rem;
  max-width: 100rem;
  margin-right: auto;
  margin-left: auto;
}
.sec02-l-center .column-medium table{
    margin-top:2rem;
    margin-bottom:2rem;
}
.sec02-l-center .column-medium{
    position:relative;
    z-index:0;
    margin-bottom:5rem;
}
.sec02-l-center .l-grid-two .column-medium{
    margin-bottom:0rem;
}
.sec03 {
    background: url(./img/sec03-bk.png) no-repeat right top, url(./img/sec03-bk2.png) no-repeat left bottom;
	background-size: 620px auto, 425px auto;
}
.sec03-l-center {
  padding-top: 10rem;
  padding-bottom: 6rem;
  max-width: 100rem;
  margin-right: auto;
  margin-left: auto;
}
.sec04 {
    background: #F3F3F3;
}
.sec04-l-center {
  padding-top: 10rem;
  padding-bottom: 10rem;
  max-width: 100rem;
  margin-right: auto;
  margin-left: auto;
}
.sec05 {
    background: url(./img/sec05-bk.png) no-repeat right top, url(./img/sec05-bk2.png) no-repeat left bottom -50px;
	background-size: 550px auto, 500px auto;
}
.sec05-l-center {
  padding-top: 10rem;
  padding-bottom: 6rem;
  max-width: 100rem;
  margin-right: auto;
  margin-left: auto;
}
.sec06 {
    background: #F3F3F3;
    background-size:cover;
}
.sec06-l-center {
  padding-top: 10rem;
  padding-bottom: 10rem;
  max-width: 100rem;
  margin-right: auto;
  margin-left: auto;
}
.sec07 {
    background: url(./img/sec07-bk.png) no-repeat center bottom;
}
.sec07-l-center {
  padding-top: 10rem;
  padding-bottom:20rem;
  max-width: 100rem;
  margin-right: auto;
  margin-left: auto;
}

@media screen and (max-width: 767px) {
  .sec01 {
    padding-right: 1rem;
    padding-left: 1rem;
    background-size: 150px auto, 150px auto;
  }
  .sec01-l-center {
    padding-top: 4rem;
    padding-bottom: 4rem;
  }
  .sec01-l-center .column-small{
    margin-bottom: 3rem;
  }
  #low-page .sec01-l-center {
    padding: 1rem 0;
  }
  .sec02 {
    padding-right: 1rem;
    padding-left: 1rem;
  }
  .sec02-l-center {
    padding-top: 8rem;
    padding-bottom: 6rem;
  }
  .sec02-l-center .column-medium table{
    font-size:1.5rem;
  }
  .sec03 {
    padding-right: 1rem;
    padding-left: 1rem;
	background-size: 100vw auto, 100vw auto;
  }
  .sec03-l-center {
    padding-top: 6rem;
    padding-bottom: 4rem;
  }
  .sec04 {
    padding-right: 1rem;
    padding-left: 1rem;
  }
  .sec04-l-center {
    padding-top: 6rem;
    padding-bottom: 6rem;
  }
  .sec05 {
    padding-right: 1rem;
    padding-left: 1rem;
	background-size: 100vw auto, 100vw auto;
  }
  .sec05-l-center {
    padding-top: 6rem;
    padding-bottom: 4rem;
  }
  .sec06 {
    padding-right: 1rem;
    padding-left: 1rem;
  }
  .sec06-l-center {
    padding-top: 6rem;
    padding-bottom: 6rem;
  }
  .sec07 {
    padding-right: 1rem;
    padding-left: 1rem;
	background-size: 150vw auto;
  }
  .sec07-l-center {
    padding-top: 6rem;
    padding-bottom: 6rem;
  }
}


/* ---------------------------------------------
navigation02 ※TOP、下層共通
--------------------------------------------- */
.header-area-upper {
    padding: var(--s1);
    text-align: right;
}
.header-title {
    font-size: 1.2rem;
    display: inline-block;
    position: relative;
}
.header-title::before {
    content: "PR";
    padding: .2rem;
    color: #fff;
    background-color: #333;
    transform: translateY(-50%);
    position: absolute;
    top: 50%;
    left: -2.4rem;
}
.header-title a {
    text-decoration: none;
}
.header-title a:hover {
    text-decoration: underline;
}
.gnavi-btn-close {
    display: none;
}
.toggle-content {
    display: none;
}
.gnavi-ctrl {
    transition: opacity 0.6s, visibility 0.6s;
    opacity: 0;
    visibility: hidden;
}
.gnavi-ctrl.is-show {
    opacity: 1;
    visibility: visible;
}
#low-header .gnavi-ctrl {
    opacity: 1;
    visibility: visible;
}
.gnavi-btn {
    width: var(--s7);
    height: var(--s6);
    background: #333;
    display: block;
    position: fixed;
    top: var(--s4);
    right: 0;
    z-index: 200;
    cursor: pointer;
    border:1px solid #fff;
}
.gnavi-btn span {
    width: var(--s4);
    height: 0.2rem;
    display: inline-block;
    background: #fff;
    position: absolute;
    left: 1.2rem;
    transform: translate(0, -50%);
    transition: transform 0.4s, opacity 0.4s;
}
.gnavi-btn span:nth-of-type(1) {
    top: 1.7rem;
}
.gnavi-btn span:nth-of-type(2) {
    top: 2.4rem;
}
.gnavi-btn span:nth-of-type(3) {
    top: 3.1rem;
}
.gnavi-btn.is-active span:nth-of-type(1) {
    transform: translateY(0.7rem) rotate(-45deg);
}
.gnavi-btn.is-active span:nth-of-type(2) {
    opacity: 0;
}
.gnavi-btn.is-active span:nth-of-type(3) {
    transform: translateY(-0.7rem) rotate(45deg);
}
.gnavi-btn-close {
    width: 80%;
    margin: 0 auto;
    padding: var(--s2);
    background: #4B4B4B;
    display: block;
    text-align: center;
}
.gnavi-btn-close__inner {
    padding: 0 0 0 var(--s3);
    display: inline-block;
    color: #fff;
    font-weight: 700;
    position: relative;
}
.gnavi-btn-close__inner::before {
    content: "";
    width: 1em;
    height: 0.2rem;
    background: #fff;
    position: absolute;
    top: 50%;
    left: 0;
    transform: translate(0, -50%) rotate(45deg);
}
.gnavi-btn-close__inner::after {
    content: "";
    width: 1em;
    height: 0.2rem;
    background: #fff;
    position: absolute;
    top: 50%;
    left: 0;
    transform: translate(0, -50%) rotate(135deg);
}
.gnavi-area {
    width: 100%;
    max-width: 37.5rem;
    height: 100vh;
    padding: var(--s12) var(--s1) var(--s10);
    display: block;
    background: #F5F5F5;
    overflow-x: hidden;
    overflow-y: auto;
    position: fixed;
    top: 0;
    right: 0;
    z-index: 100;
    transform: translateX(100%);
    transition: transform 0.8s ease, opacity 0.8s ease;
    opacity: 0;
}
.gnavi-title {
    min-height: var(--s6);
    margin: 0 var(--s8);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.6rem;
    font-weight: 700;
    text-align: center;
    line-height: 1.5;
}
.gnavi-pc {
    display: none;
}
.gnavi-list {
    border-bottom: 1px solid #333;
    position: relative;
}
.gnavi-list li {
    padding-left: 0;
}
.gnavi-list__item::before {
    display: none;
}
.gnavi-list__link {
    width: 100%;
    margin: 0 auto;
    padding: var(--s2) var(--s4) var(--s2) var(--s2);
    border-top: 1px solid #333;
    display: block;
    font-weight: 700;
    line-height: 2;
    text-decoration: none;
    position: relative;
    font-size:1.5rem;
}
.gnavi-list__link::after {
    content: "";
    width: 1.4rem;
    height: 1.4rem;
    background: url("img/arrow-01-green-right.png") no-repeat center/70% auto;
    position: absolute;
    top: 50%;
    right: var(--s2);
    transform: translate(0, -50%) rotate(0);
    transition: transform 0.3s;
}
.gnavi-list__link--toggle::after {
    background-image: url("img/arrow-01-black-down.png");
    background-size:100% auto;
}
.gnavi-list__link--toggle.is-open::after {
    transform: translate(0, -50%) rotate(180deg);
}
.gnavi-list__sub {
    width: 100%;
    background: #fff;
}
.gnavi-list__low .gnavi-list__link {
    padding: var(--s2) var(--s4) var(--s2) var(--s4);
}
.gnavi-list__low .gnavi-list__link::after {
    content: "└";
    background: none;
    transform: translateY(-50%);
    position: absolute;
    top: 40%;
    left: 1rem;
}
.is-gnavi-open .gnavi-area {
    opacity: 1;
    transform: translateX(0);
}

/* ---------------------------------------------
index01(目次)
--------------------------------------------- */
.onb-index01-frame {
    width: 100%;
	margin-bottom:3rem;
}
.onb-index01-wrap {
    margin: 0 auto;
    padding: var(--s1) var(--s3);
    border: solid 0.1rem #D0D3E0;
    background-color: transparent;
    position: relative;
}
.onb-index01-title {
    padding: var(--s2) var(--s2) var(--s2) var(--s6);
    color: #333;
    font-size: 2.2rem;
    font-weight: bold;
    line-height: 1;
    background: url("./img/dummy-icon.png") no-repeat left center;
    background-size: 3rem auto;
    position: relative;
    cursor: pointer;
}
.onb-index01-title::before {
    content: "";
    width: 2rem;
    height: 0.3rem;
    background: #333;
    position: absolute;
    top: 50%;
    right: 2rem;
    transform: translate(0, -50%);
}
.onb-index01-title::after {
    content: "";
    width: 0.3rem;
    height: 2rem;
    background: #333;
    position: absolute;
    top: 50%;
    right: 2.9rem;
    transform: translate(0, -50%);
    transition: transform 0.3s;
}
.onb-index01-title.is-open::after {
    transform: translate(0, -50%) rotate(270deg);
}
.onb-index01-chapter {
    padding: var(--s2) var(--s2) var(--s2) var(--s4);
    font-weight: 700;
}
.onb-index01-chapter-h {
    margin: 0 0 0 var(--s2);
    font-size: 100%;
    line-height: 1.7;
    position: relative;
}
.onb-index01-chapter-h a {
    display: block;
    text-decoration: none;
}
.onb-index01-chapter-h a:hover {
    opacity: .6;
}
.onb-index01-chapter-h-two {
    margin-left: var(--s2);
    position: relative;
}
.onb-index01-chapter-h-three {
    margin-left: var(--s4);
    position: relative;
}
.onb-index01-chapter-h-two::before,
.onb-index01-chapter-h-three::before {
    position: absolute;
    top: 0;
    left: -1.5em;
}
.onb-index01-chapter-h-two::before {
    content: "";
    width: 1.2rem;
    height: 1.2rem;
    border-radius: 2rem;
    background-color: #50aaa0;
    transform: translateY(-50%);
    top: .8em;
}
.onb-index01-chapter-h-three::before {
    content: "└";
}
.more-content {
    display: none;
}
.onb-index01-content {
    background-color: #fff;
}

/* ---------------------------------------------
related-article01(関連記事)
--------------------------------------------- */
.related-article01-frame {
    border: 1px solid var(--site-color09);
    margin: var(--s6) auto;
    padding: var(--s1)  var(--s3)  var(--s4) var(--s3);
    background: #fff;
    position: relative;
}
.related-article01-title {
    padding: var(--s2) var(--s2) var(--s2) var(--s4);
    color: #333;
    font-size: 2.2rem;
    font-weight: bold;
    line-height: 1;
    background-size: 5rem auto;
    position: relative;
    border-bottom: 1px solid #D0D3E0;
}
.related-article01-list {
    padding: var(--s2) 0 var(--s2) var(--s2);
    font-weight: 700;
}
.related-article01-list li {
    margin: 0 0 0 var(--s2);
    padding-left: 1.5em;
    font-size: 100%;
    line-height: 1.7;
    position: relative;
}
.related-article01-list li + li {
    margin-top: 10px;
}
.related-article01-list li::before {
    content: "";
    width: 1.6rem;
    height: 1.6rem;
    border-radius: 50%;
    background-color: #50aaa0;
    position: absolute;
    top: .6rem;
    left: 0;
}
.related-article01-list a {
    display: block;
    text-decoration: none;
}
.related-article01-list a:hover {
    opacity: 0.6;
}
.relations-box.relations-box--column {
    display: flex;
    gap: 10px;
}
.relations-box__pic {
    flex: 0 0 150px;
}
/*------------------------------------------------------------
    SP settings
*/
@media screen and (max-width: 767px) {
    .related-article01-list {
        padding: 2rem 0 0 0;
    }
    .related-article01-list li {
        margin-left: 0;
    }
    .relations-box__pic {
        flex: 0 0 100px;
    }
    .header-area-upper {
    text-align: left;
    padding-left:3rem;
    }
    .related-article01-title {
    padding-left: 0;
    color: #333;
    font-size: 2.2rem;
    font-weight: bold;
    line-height: 1;
    background-size: 5rem auto;
    position: relative;
    border-bottom: 1px solid #D0D3E0;
    }
    .onb-index01-title {
    font-size: 2rem;
    }
    .onb-index01-chapter {
    padding: 1rem;
    }
}





.section-title06-frame {
    margin-top: 0rem;
    position: relative;
}
.section-title06-frame-p {
    margin-bottom: 3rem;
    line-height:2;
}
.sec03 .section-title06-frame-p,
.sec05 .section-title06-frame-p{
    background:#fff;
}
.section-title06-frame::after {
    content: "";
    width: 100vw;
    height: 100%;
    background-color: #50aaa0;
    position: absolute;
    top: 0;
    right: 0;
}
.sec01 .section-title06-frame-p{
    background-color: #f3f3f3;
}
.sec01 .section-title06-frame::after{
    background-color: #181818;
}
.sec02 .section-title06-frame::after{
    background-color: #181818;
}
.section-title06 {
    width: 100%;
    padding: var(--s3) 0;
    font-size: 4rem;
    font-weight: 700;
    color: #fff;
    line-height: 1.5;
    text-align: left;
    position: relative;
    margin-bottom:3rem;
    z-index:1;
}
.section-title06 a{
    color: #fff;
    text-decoration:none;
    background: url(./img/arrow-01-wht-right.svg) no-repeat center right / auto 0.5em;
    padding-right:3rem;
}
.section-title06 a:hover{
    opacity:0.6;
}
/*------------------------------------------------------------
    SP settings
*/
@media screen and (max-width: 767px) {
    .section-title06 {
        padding: var(--s2);
        font-size: 2.4rem;
    }
    .sec01 .section-title06-frame-p{
    }
    .sec03 .section-title06-frame-p,
    .sec05 .section-title06-frame-p{
    padding:1rem;
    }
    .section-title06 a{
    color: #fff;
    text-decoration:none;
    background: url(./img/arrow-01-wht-right.svg) no-repeat center right / auto 0.75em;
    padding-right:2rem;
    }
}



/*------------------------------------------
    3box column settings
*/
.column-small {
    padding: var(--s2);
    border: 1px solid #ccc;
    background:#fff;
}
.thb-box-full {
    width: calc(100% + var(--s4));
    margin-left: calc(var(--s2) * -1);
}





.arrow-title {
    margin-bottom: 1rem;
    padding: var(--s2);
    font-size: 1.9rem;
    font-weight: 700;
    color: #fff;
    background-color: #50AAA0;
    text-align: center;
    line-height: 1.5;
    position: relative;
}
.arrow-title img{
	max-width: 80px;
    display: block;
    margin: 0 auto 1rem;
}
#low-page .arrow-title {
    font-size: 1.5rem;
}
.arrow-title-sub {
    padding: var(--s1);
    margin-top: .4rem;
    background-color: #fff;
    font-size: 2.1rem;
    color: #438d85;
    line-height: 1;
    display: inline-block;
    margin-bottom: .8rem;
	margin-right:.4rem;
}
.arrow-title-small {
    color:#fff464;
}
#low-page .arrow-title-small {
    font-size:2rem;
}




.thb-listbox-bg-colored {
    padding-top: 3.5rem;
    padding-bottom:2rem;
}
.thb-listbox-area {
    padding: 4rem var(--s2) var(--s2) var(--s2);
    background-color: #ededed;
    position: relative;
}
.thb-listbox-title {
    margin-top: -5.5rem;
    padding: var(--s1);
    color: #fff;
    background-color:#4B4B4B;
    text-align: center;
    font-weight:bold;
}
.thb-listbox-subtitle {
    text-align: center;
    font-weight: 700;
}
.thb-listbox-list {
    width: 100%;
    padding-left: 2rem;
}
.thb-listbox-list li {
    padding: 0 var(--s1);
    line-height: 1.5;
    position: relative;
    font-weight:bold;
}
.thb-listbox-list li::before {
    content: "";
    width: 2rem;
    height: 2rem;
    background: url("./img/icon-check.png") no-repeat left top;
    background-size: contain;
    position: absolute;
    top: .2rem;
    left: -2rem;
}
.thb-listbox-list li span {
    margin-right: var(--s1);
    display: block;
    text-align: center;
}
/*------------------------------------------------------------
    SP settings
*/
@media screen and (max-width: 767px) {
    .thb-listbox-area {
        padding: var(--s5) var(--s2) var(--s2) var(--s2);
    }
    .thb-listbox-list li {
        font-size: 1.4rem;
    }
    .thb-listbox-list--three li {
        width: calc((100% - var(--s2)) / 2);
    }
    .thb-listbox-title {
        width: 80%;
        margin: -5rem auto 0 auto;
        padding: var(--s1);
        font-size: 1.4rem;
        text-align: center;
    }
    .arrow-title {
    font-size: 1.8rem;
    }
}



/*------------------------------------------
    1box column settings
*/
.column-medium {
    padding: var(--s4);
    border: 1px solid #ccc;
    background:#fff;
}
.onb-box-full {
    width: calc(100% + var(--s8));
    margin-left: calc(var(--s4) * -1);
}
/*------------------------------------------------------------
    SP settings
*/
@media screen and (max-width: 767px) {
    .column-medium {
        padding: var(--s2);
    }
    .onb-box-full {
        width: calc(100% + var(--s4));
        margin-left: calc(var(--s2) * -1);
    }
}



.onb-icon-title-frame {
    padding: var(--s3);
    background-color: #50AAA0;
    position: relative;
}
.onb-icon-title-icon {
    width: 12rem;
    height: 12rem;
    border-radius: 50%;
    overflow: hidden;
    position: absolute;
    top: -4rem;
    left: 0;
}
.onb-icon-title-icon img {
    width: 100%;
}
.onb-icon-title {
    text-align: center;
    font-size: 2.4rem;
    font-weight: 700;
    line-height: 1.5;
    color: #fff;
}
.onb-icon-title small {
    font-size: 2.1rem;
    border: none;
}
.onb-icon-title-catch {
    margin-top: .5rem;
    margin-right: .5rem;
    margin-bottom: .5rem;
    font-size: 3rem;
    display: inline-block;
    line-height: 1.5;
    border: none;
    background:#fff;
    color:#438D85;
    padding:0 1rem;
}
/*------------------------------------------------------------
    SP settings
*/
@media screen and (max-width: 767px) {
    .onb-icon-title-frame {
        padding: var(--s2);
    }
    .onb-icon-title {
        font-size: 1.8rem;
    }
    .onb-icon-title small {
        font-size: 1.6rem;
    }
    .onb-icon-title-catch {
        padding-left: var(--s1);
        font-size: 2.2rem;
    }
    .onb-icon-title-icon {
        width: 6rem;
        height: 6rem;
        position: absolute;
        top: -2rem;
        left: -.5rem;
    }
}

.center-img-box {
    display: flow-root;
    margin-top:5rem;
}
.center-img {
    max-width: 64%;
    margin: 0 auto;
    padding-bottom: var(--s2);
}
.center-img-catch {
    font-size: 1.8rem;
    font-weight: 700;
    color: var(--site-color03);
    line-height: 1.5;
}
/*------------------------------------------------------------
    SP settings
*/
@media screen and (max-width: 767px) {
    .center-img {
        max-width: 100%;
        padding-bottom: 0;
    }
    .center-img-box {
    margin-top:2.5rem;
    }
}


.section-title05 {
    width: 100%;
    margin-top: 5rem;
    margin-bottom: 2.5rem;
    padding: var(--s2);
    font-size: 2.4rem;
    font-weight: 700;
    color: #181818;
    line-height: 1.5;
    text-align: center;
    background-color: #F3F3F3;
    position: relative;
}
.section-title05::before,
.section-title05::after {
    content: "";
    width: 4rem;
    height: 4rem;
    background-color: #50aaa0;
    position: absolute;
    z-index:-1;
}
.section-title05::before {
    bottom: -0.5rem;
    left: -0.5rem;
}
.section-title05::after {
    top: -0.5rem;
    right: -0.5rem;
}
/*------------------------------------------------------------
    SP settings
*/
@media screen and (max-width: 767px) {
    .section-title05 {
        padding: var(--s2);
        font-size: 2.1rem;
        margin-top: 5rem;
    }
    .section-title05::before,
    .section-title05::after {
    content: "";
    width: 3rem;
    height: 3rem;
    }
}



.onb-casebox02-frame {
    padding: var(--s4);
    background-color: #F3F3F3;
    position: relative;
    justify-content: flex-start;
}
.onb-casebox02-sub {
    padding: var(--s1) var(--s3);
    background-color: var(--site-color03);
    color: #fff;
    font-size: 2.1rem;
    transform: translateX(-50%);
    position: absolute;
    top: -2rem;
    left: 50%;
}
.l-onb-casebox02 {
    display: flex;
    flex-wrap: wrap;
    gap: var(--s3);
	align-items: center; 
}
.l-onb-casebox02__side {
    width: calc((100% - var(--s3))*.25);
}
.l-onb-casebox02__main {
    width: calc((100% - var(--s3))*.75);
}
.onb-casebox02-imgcap {
    margin-top: 1rem;
    text-align: center;
    font-size: 1.2rem;
}
.onb-casebox02-catch {
    font-size: 2.1rem;
    font-weight: 700;
    color: #438d85;
    line-height: 1.5;
}
.onb-casebox02-caption {
    text-align: left;
}


/*------------------------------------------
    2box column settings
*/
.column-medium {
    padding: var(--s4);
    border: 1px solid #ccc;
}
.twb-box-full {
    width: calc(100% + var(--s8));
    margin-left: calc(var(--s4) * -1);
}
/*------------------------------------------------------------
    SP settings
*/
@media screen and (max-width: 767px) {
    .column-medium {
        padding: var(--s2);
    }
    .twb-box-full {
        width: calc(100% + var(--s4));
        margin-left: calc(var(--s2) * -1);
    }
    .onb-casebox02-frame {
    padding: 2rem;
    }
    .onb-casebox02-catch {
    font-size: 1.9rem;
    }
    .l-onb-casebox02 {
    gap: 1.5rem;
    }
    .l-onb-casebox02__side {
    width: calc((100% - var(--s2))*.25);
    }
.l-onb-casebox02__main {
    width: calc((100% - var(--s2))*.75);
    }
}



.twb-slider-container {
    position: relative;
	text-align:center;
}
.twb-slider {
    width: 100%;
    padding-bottom: 3rem;
}
.swiper-pagination-bullet-active {
    background-color: var(--site-color03);
}
.twb-slider-container .swiper-button-next,
.twb-slider-container .swiper-button-prev {
    width: 3rem;
    height: 3rem;
    top: 45%;
}
.twb-slider-container .swiper-button-prev {
    left: var(--swiper-navigation-sides-offset,-1.5rem);
}
.twb-slider-container .swiper-button-next {
    right: var(--swiper-navigation-sides-offset,-1.5rem);
}
.twb-slider-container .swiper-button-next:hover,
.twb-slider-container .swiper-button-prev:hover {
    opacity: .6;
}
.twb-slider-container .swiper-button-next::after,
.twb-slider-container .swiper-rtl .swiper-button-prev::after {
    content: "";
    width: 3rem;
    height: 3rem;
    background: url("./img/slider-arrow-right.png") no-repeat center center;
    background-size: contain;
}
.twb-slider-container .swiper-button-prev::after,
.twb-slider-container .swiper-rtl .swiper-button-next::after {
    content: "";
    width: 3rem;
    height: 3rem;
    background: url("./img/slider-arrow-left.png") no-repeat center center;
    background-size: contain;
}
/*------------------------------------------------------------
    SP settings
*/
@media screen and (max-width: 767px) {
    .twb-slider-container .swiper-button-prev {
        left: var(--swiper-navigation-sides-offset,-1rem);
    }
    .twb-slider-container .swiper-button-next {
        right: var(--swiper-navigation-sides-offset,-1rem);
    }
    .twb-slider-container .swiper-button-next,
    .twb-slider-container .swiper-button-prev {
        top: 38%;
    }
}


.twb-title-catch {
    font-size: 2.1rem;
    font-weight: 700;
    color: #438d85;
    text-align: center;
    line-height: 1.5;
    margin-bottom: 2rem;
}
.twb-title-catch span {
    font-size: 1.6rem;
}


.m-title01 {
    padding: var(--s1) var(--s1) var(--s2)var(--s1);
    font-size: 2.1rem;
    font-weight: 700;
    color: #181818;
    text-align: center;
    line-height: 1.5;
}
.sec03 .m-title01{
    text-align: center;
    padding-left:0;
}
.m-title01 a{
    text-decoration:none;
    background: url(./img/arrow-01-green-right.png) no-repeat center right / auto 0.7em;
    padding-right:2rem;
    color: #438d85;
}
.m-title01 a:hover{
    opacity:0.6;
}

.thb-table {
    line-height: 1.5;
    border-collapse: collapse;
    border: 1px solid #D3D3D3;
    margin-top:2rem;
    margin-bottom:2rem;
    font-size:1.4rem;
}
.thb-table th,
.thb-table td {
    padding: var(--s1);
    border: 1px solid #D3D3D3;
}
.thb-table th {
    width: 35%;
    background-color: #F3F3F3;
}


.acc-more-btn {
    max-width: 46rem;
  width: 100%;
    margin: var(--s5) auto;
    position: relative;
}
.acc-more-btn span {
    width: 100%;
    margin: var(--s5) auto;
    padding: 2rem 6rem 2rem 6rem;
    border: 1px solid #181818;
    border-radius: 4rem;
    background: url('./img/acc-off.svg') no-repeat 95% center #fff;
    display: block;
    text-align: center;
    transform: translate(0, 0);
    transition: transform 0.3s;
    cursor: pointer;
    z-index: 1;
    font-weight:bold;
}
.acc-more-btn::after {
    content: '';
    display: block;
    width: 100%;
    height: 100%;
    background-color: var(--site-color03);
    border-width: 0 1px 1px 0;
    transform: translate(.8rem, .8rem);
    border-radius: 4rem;
    position: absolute;
    left: 0;
    bottom: 0;
    z-index: -1;
}
.acc-more-btn:hover span {
    transform: translate(.8rem, .8rem);
}
.acc-more-btn.is-open span {
    background: url('./img/acc-on.svg') no-repeat 95% center #fff;
}
.more-content {
    display: none;
}
/*------------------------------------------------------------
    SP settings
*/
@media screen and (max-width: 767px) {
    .acc-more-btn {
        margin-right: var(--s1);
    }
    .acc-more-btn span {
        transition: inherit;
        transform: none;
    }
    .acc-more-btn:hover span {
        transform: none;
    }
    .twb-title-catch {
    font-size: 1.9rem;
    }
    .sec02 table th {
    min-width: 90px;
    }
}

.onb-iconbox03-frame {
    margin-top: 1.5rem;
    padding: var(--s2);
    background-color: #fff;
}
.onb-iconbox03-frame p {
    font-size: 1.4rem;
}
.onb-iconbox03-sub {
    margin-top: -3rem;
    text-align: center;
}
.onb-iconbox03-sub a span {
    padding: var(--s1) var(--s2);
    display: inline-block;
    color: #fff;
    font-size: 2.1rem;
    font-weight: bold;
    background: #292929 url(./img/arrow-01-wht-right.svg) no-repeat center right 10px/ auto 0.7em;
    padding-right: 3rem;
    line-height:1.4;
}
.onb-iconbox03-sub a:hover{
    opacity:0.6;
}
.onb-iconbox03-img img{
    max-height:200px;
    object-fit:cover;
}
.onb-iconbox03-catch {
    padding-bottom: 2rem;
    font-size: 1.8rem;
    font-weight: 700;
    color: var(--site-color03);
    line-height: 1.5;
    border-bottom: 2px solid var(--site-color17);
}
.onb-iconbox03-caption {
    text-align-last: left;
}







.twb-iconbox01-bg-colored {
    padding-top: 2rem;
}
.twb-iconbox01-area {
    padding: var(--s4) var(--s2) var(--s2) var(--s2);
    background-color: #F3F3F3;
    position: relative;
}
.twb-iconbox01-image {
    width: 7.5rem;
    height: 7.5rem;
    position: absolute;
    top: -1.5rem;
    left: 1rem;
}
.twb-iconbox01-title {
    padding-left: var(--s9);
    padding-bottom: var(--s2);
    font-size: 2.1rem;
    font-weight: 700;
    color: #181818;
    text-align: left;
    border-bottom: 1px solid var(--site-color03);
    line-height:1.4;
}
.twb-iconbox01-title a{
    text-decoration:none;
    color: #438d85;
    background: url(./img/arrow-01-green-right.png) no-repeat center right / auto 0.7em;
    padding-right: 2rem;
}
.twb-iconbox01-title a:hover{
    opacity:0.6;
}
.twb-iconbox01-title span {
    margin-bottom: var(--s1);
    font-size: 1.4rem;
    line-height: 1.5;
    display: block;
}
/*------------------------------------------------------------
    SP settings
*/
@media screen and (max-width: 767px) {
    .twb-iconbox01-image{
        width: 5rem;
        height: 5rem;
        top: -1rem;
    }
    .twb-iconbox01-title {
        padding-left: var(--s7);
    }
    .twb-iconbox01-area {
    padding: var(--s2);
    }
}

/*------------------------------------------
    4box column settings
*/
.column-xsmall {
    padding: var(--s1);
    background: #f3f3f3;
}
.column-xsmall .btn-link {
    text-align: center;
}
.column-xsmall .btn-link a{
    text-decoration:none;
}
.l-grid-four{
    margin-bottom:2rem;
}

.wr_img_center{
    text-align:center;
    margin:3rem auto 0;
	max-width:800px;
}
.wr_caption{
    font-size:1.0rem;
    margin-top:1rem;
    margin-bottom:1rem;
}



.conclusion-box-frame {
    margin-top: 5rem;
    padding: var(--s2) var(--s4) var(--s4) var(--s4);
    background: url('./img/conclusion-bg.svg') repeat-y top right var(--site-color07);
}
.conclusion-box-ttl {
    position: relative;
}
.conclusion-box-ttl__icon-frame {
    position: absolute;
    left: -4.8rem;
    bottom: 1rem;
    z-index: 10;
}
.conclusion-box-ttl__icon {
    width: 10rem;
    height: 10rem;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: #50AAA0;
}
.conclusion-box-ttl__icon::after {
    content: "";
    width: 100%;
    height: 100%;
    background-color: #707070;
    position: absolute;
    right: -1rem;
    bottom: -1rem;
    z-index: -1;
}
.conclusion-box-ttl__icon span {
    color: #fff;
    font-weight:bold;
    font-size:2.0rem;
}
.conclusion-box-ttl__text {
    padding-top: var(--s2);
    padding-bottom: var(--s3);
    margin-left: 10rem;
    font-size: 2.1rem;
    font-weight: 700;
    line-height: 1.5;
    border-bottom: 1px solid var(--site-color03);
}
.conclusion-box-content {
    z-index: 5;
}
/*------------------------------------------------------------
    SP settings
*/
@media screen and (max-width: 767px) {
    .conclusion-box-frame {
        background-size: 50% auto;
    }
    .conclusion-box-ttl__icon-frame {
        top: -3.2rem;
        left: -3.6rem;
        bottom: inherit;
    }
    .conclusion-box-ttl__icon {
        width: 6rem;
        height: 6rem;
    }
    .conclusion-box-ttl__text {
        margin-left: 0;
        padding-left: 5rem;
        padding-top: var(--s1);
        padding-bottom: var(--s2);
    }
    .l-onb-conclusion-img {
        width: 36%;
    }
    .conclusion-box-ttl__icon span {
    font-size:1.6rem;
    }
}


.pc-fix-banner01 {
    width: 23rem;
    background-color: #50AAA0;
    display:fixed;
    right: 0;
    bottom: 0;
    z-index: 50;
}
.pc-fix-banner01 a {
    color: #fff;
    text-decoration: none;
    display: block;
}
.pc-fix-banner01 a:hover {
    opacity: .7;
}
.pc-fix-banner01-img {
    position: relative;
}
.pc-fix-banner01-text {
    padding: var(--s2);
    color: #fff;
    position: relative;
}
.pc-fix-banner01-text::after {
    content: "";
    width: 0.1rem;
    height: 0.1rem;
    border-top: .5rem solid transparent;
    border-left: .5rem solid transparent;
    border-right: .5rem solid #fff;
    border-bottom: .5rem solid #fff;
    position: absolute;
    right: .5rem;
    bottom: .5rem;
}
.pc-fix-banner01-text::before {
    content: "";
    width: 80px;
    height: 25px;
    background: url("./img/banner_s.png") no-repeat center center;
    background-size: cover;
    position: absolute;
    top: -1.25rem;
    left: 1.5rem;
    z-index: 5;
}
.pc-fix-banner01-text p {
    margin: 0;
    font-size: 1.6rem;
    text-align: left;
    font-weight:bold;
    color: #fff464;
}
.pc-fix-banner01-text p.text-small {
    font-size: 1.4rem;
    line-height: 1.5;
    font-weight:bold;
    color: #fff;
}
/*------------------------------------------------------------
    SP settings
*/
@media screen and (max-width: 767px) {
    .pc-fix-banner01 {
        left:0;
    }
    .pc-fix-banner01-img {
        display: none;
    }
    .pc-fix-banner01-text {
    padding: 1rem;
    }
    .pc-fix-banner01-text p.text-small{
    line-height:1.4;
    }
    .pc-fix-banner01-text p{
    line-height:1.4;
    }
    .pc-fix-banner01-text::before {
    content: "";
    width: 60px;
    height: 19px;
    background: url("./img/banner_s.png") no-repeat center center;
    background-size: cover;
    position: absolute;
    top: -1.25rem;
    left: 1rem;
    z-index: 5;
}
}

.section-title04 {
    margin-top: 4rem;
    font-size: 3rem;
    font-weight: 700;
    color: #181818;
    text-align: center;
    position: relative;
}
/*------------------------------------------------------------
    SP settings
*/
@media screen and (max-width: 767px) {
    .section-title04 {
        font-size: 2.2rem;
        line-height: 1.5;
        margin-top: 2rem;
    }
    .pc-fix-banner01 {
    width: 22rem;
    }
}




.section-title02-frame {
    margin-top: 5rem;
    text-align: center;
    position: relative;
}
.section-title02 {
    font-size: 3.6rem;
    font-weight: 700;
    color: #fff;
    text-align: center;
    background:#181818;
    line-height:1.4;
    margin-bottom:2.5rem;
    padding:1rem;
}
.section-title02-sub {
    width: 100%;
    margin-bottom: 1rem;
    font-size: 2.6rem;
    font-weight: 700;
    color: #50AAA0;
    text-align: center;
    position: absolute;
    top: -1.5em;
    left: 0;
}
/*------------------------------------------------------------
    SP settings
*/
@media screen and (max-width: 767px) {
    .section-title02 {
        font-size: 2.4rem;
        line-height: 1.5;
    }
}



.mainvisual h2 {
    font-size: 5rem;
    font-weight: bold;
    line-height: 75px;
    min-width: 560px;
    margin-right: 3rem;
	text-shadow: -1px -1px 0 #fff, 1px -1px 0 #fff, -1px 1px 0 #fff, 1px 1px 0 #fff;
}


.mainvisual h2 span {
background-image: radial-gradient(circle at center, #4bcba7 15%, transparent 15%); /* 点の色とサイズ調整 */
  background-position: top right; /* 点の位置 */
  background-repeat: repeat-x; /* 横方向に繰り返し */
  background-size: 1em 0.3em; /* 点の間隔とサイズ調整 */
  padding-top: .4em; /* 縦方向の位置調整 */

}


.mainvisual  .mv_text {
    display: flex;
    max-width: 1200px;
    margin: 0 auto;
}

.mainvisual .mv_text p{
    max-width:700px;
	text-shadow:-1px -1px 0 #fff, 1px -1px 0 #fff, -1px  1px 0 #fff, 1px  1px 0 #fff;
}
.mainvisual {
    background: url(img/mv_pc.jpg) no-repeat bottom center;
    background-size: 100%;
    padding: 3rem 0 35vw;
    position: relative;
    bottom: -1px;
}

.mainvisual .sp {
    display:none;
}

.mv-lower {
    height: 170px;
    background: #efeee0 url(img/mv_lower.jpg) no-repeat center;
    background-size: cover;
    display: flex;
    justify-content: center;
    align-items: center;
}
.mv-lower .mv-inner {
    max-width: 420px;
    padding-top: 2rem;
}
.mv-lower .mv-logo {
    width: 210px;
    padding: 1rem 0;
    background: #f3f3f3;
}

.mv-lower a:hover {
    opacity: .6;
}   

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

    .mainvisual .sp {
        display:block;
        margin-top: -2rem;
        position: relative;
        z-index: -1;
    }

    .mainvisual {
        padding: 0;
        background: no-repeat;
        bottom: 0;
    }

    .mainvisual .mv_text {
        display: block;
    }

    .mainvisual h2 {
        min-width: auto;
        font-size: 3rem;
        line-height: 4.5rem;
        padding: 20px 0 0 5%;
    }

    .mainvisual .mv_text p {
        padding: 10px 5% 120px 5%;
    }

    .mv-lower {
        height: 130px;
    }

    .mv-lower a {
        width:150px;
    }
            

}




.onb-icon-title-frame {
	padding: var(--s4);
	background-color: #50aaa0;
	position: relative;
}
.sec02 .onb-icon-title-icon {
	width: 10rem;
	height: 10rem;
	border-radius: 50%;
	overflow: hidden;
	position: absolute;
	top: -4rem;
	left: 1rem;
}
.onb-icon-title-icon img {
	width: 100%;
}
.onb-icon-title {
	text-align: center;
	font-size: 3rem;
	font-weight: 700;
	line-height: 1.5;
	color: #fff;
}
.onb-icon-title .underline {
	padding: var(--s1);
    margin-top: .4rem;
    background-color: #fff;
    font-size: 3.6rem;
    color: #438d85;
    line-height: 1;
    display: inline-block;
    margin-bottom: .8rem;
    margin-right: .4rem;
}
.onb-icon-title small {
	font-size: 2.1rem;
	border: none;
}
.onb-icon-title-catch {
	margin-bottom: .8rem;
	font-size: 1.8rem;
	display: block;
	line-height: 1.5;
	border: none;
}
/*------------------------------------------------------------
    SP settings
*/
@media screen and (max-width: 767px) {
	.onb-icon-title-frame {
		padding: var(--s2);
	}
	.onb-icon-title {
		font-size: 2rem;
	}
	.onb-icon-title small {
		font-size: 1.6rem;
	}
	.onb-icon-title-catch {
		padding-left: var(--s4);
		font-size: 1.4rem;
	}
	.sec02 .onb-icon-title-icon {
		width: 6rem;
		height: 6rem;
		position: absolute;
		top: -4rem;
		left: -.5rem;
	}
	.onb-icon-title .underline {
	font-size:2.4rem;
	}
}

#low-page .float-img.ct{
	text-align:center;
}
#low-page .float-wrap.ct{
	text-align:center;
}
#low-page .building_img{
	text-align:center;
}




.sp-scroll-table {
    display: none;
}
/*------------------------------------------------------------
    SP settings
*/
@media screen and (max-width: 767px) {
    .sp-scroll-table {
        margin-top: 3rem;
        display: block;
        padding: var(--s1);
        border: 1px solid #ccc;
        text-align: center;
        font-size: 1.2rem;
        border-radius: 2rem;
    }    
}