@charset "UTF-8"; @media screen and (min-width: 768px), print {
 /* common */
  .post-more-btn { height: 60px; border-radius: 1000px; display: flex; justify-content: center; align-items: center; background-image: linear-gradient(135deg, #54c2f0 0%, #1a77bc 50%, #54c2f0 100%); background-size: 200% 100%; background-position: 0%; transition: background-position 0.2s ease 0s; }
.post-more-btn:hover { background-position: -100%; text-decoration: none; }
.post-more-btn:hover .post-more-btn__arrow { transform: translateX(4px); }
.post-more-btn__text { display: block; color: white; font-size: 16px; font-weight: 600; line-height: 1; margin-right: 1em; }
.post-more-btn__arrow { display: block; transition: transform 0.2s ease 0s; }
.post-more-btn__arrow > svg { display: block; width: 15px; height: 15px; }
.post-more-btn__arrow > svg > use { fill: #fff; }
/* common ここまで */
  .top-page-navi { margin-bottom: 15px; position: relative; left: 16px; }
.top-page-navi__inner > ul { display: flex; align-items: center; justify-content: center; }
.top-page-navi__inner > ul > li { border-right: 1px solid #1a1a1a; line-height: 1; }
.top-page-navi__inner > ul > li.ext { border: none; }
.top-page-navi__inner > ul > li.ext > a { display: flex; align-items: center; color: #808080; padding-right: 0; }
.top-page-navi__inner > ul > li.ext > a > .ext-icon { margin-left: 12px; }
.top-page-navi__inner > ul > li.ext > a > .ext-icon > svg { display: block; }
.top-page-navi__inner > ul > li.ext > a > .ext-icon > svg > use { fill: #808080; }
.top-page-navi__inner > ul > li.bg { border: none; margin-right: 10px; }
.top-page-navi__inner > ul > li.bg > a { display: block; background-color: #1a1a1a; color: white; font-size: 14px; padding: 8px 16px; }
.top-page-navi__inner > ul > li > a { display: block; font-size: 16px; color: #1a1a1a; padding-left: 24px; padding-right: 24px; line-height: 1; }
.mv { position: relative; display: flex; z-index: 2; max-width: 1920px; margin-left: auto; margin-right: auto; }
.mv__scroll { display: flex; flex-direction: column; align-items: center; justify-content: flex-end; gap: 22px; width: 80px; padding-bottom: clamp(135px, (100vw - 1280px) / (640) * 45 + 135px, 180px); }
.mv__scroll > span { line-height: 1; font-size: 13px; font-weight: normal; writing-mode: vertical-rl; letter-spacing: 0.05em; }
.mv__scroll::after { content: ""; display: block; width: 1px; height: 80px; background-color: #1a1a1a; }
.mv__slider { flex: 1; background-color: #1a1a1a; }
.mv__slider .bx-wrapper { margin-bottom: 0; }
.mv-slider-item > img { max-width: 100%; }
/* lifespan -------------------------------------*/
  .lifespan { position: relative; background-color: #1a1a1a; margin-top: calc(0px - clamp(135px, (100vw - 1280px) / (640) * 45 + 135px, 180px)); padding-top: calc(50px + clamp(135px, (100vw - 1280px) / (640) * 45 + 135px, 180px)); padding-bottom: 50px; padding-left: 10px; padding-right: 10px; z-index: 1; }
.lifespan-inner { display: flex; flex-direction: column; justify-content: flex-start; align-items: center; width: clamp(1200px, (100vw - 1280px) / (640) * 300 + 1200px, 1500px); height: clamp(540px, (100vw - 1280px) / (640) * 20 + 540px, 560px); padding-left: 10px; padding-right: 10px; padding-top: clamp(96px, (100vw - 1280px) / (640) * 4 + 96px, 100px); margin-left: auto; margin-right: auto; background-image: url(../images/index/lifespan-bg.jpg); background-size: cover; background-position: center center; background-repeat: no-repeat; }
.lifespan-h { position: relative; width: 760px; margin-left: auto; margin-right: auto; margin-bottom: 50px; }
.lifespan-h > img { position: relative; display: block; max-width: 100%; filter: drop-shadow(0 20px 30px rgba(0, 0, 0, 0.7)); z-index: 1; }
.lifespan-h::before { content: ""; display: block; position: absolute; bottom: calc(100% - 24px); left: 50%; transform: translateX(-50%); width: 70px; height: 64px; background-image: url(../images/index/lifespan-h-icon.png); background-repeat: no-repeat; background-size: contain; background-position: center bottom; z-index: 2; }
.lifespan-text { max-width: clamp(1100px, (100vw - 1280px) / (640) * 180 + 1100px, 1280px); margin-left: auto; margin-right: auto; }
.lifespan-text > img { display: block; max-width: 100%; }
/* suppot -------------------------------------*/
  .support { padding-top: 184px; padding-bottom: 182px; background-color: #E5E8EA; }
.support-inner { .txt-sub { width: 714px; margin: 0 auto; margin-bottom: 105px; }
.bg-wap { background-image: url(../images/index/n-bg.png); background-repeat: no-repeat; background-position: center 0; padding-top: 63px; padding-bottom: 59px; .in { width: 1100px; margin: 0 auto; .flex { display: flex; flex-wrap: wrap; .box-l { width: 574px; position: relative; top: 0; left: -7px; margin-right: 104px; }
.box-r { width: 413px; padding-top: 59px; position: relative; left: -6px; .kiiro { margin-top: 40px; .soudan-link { position: relative; display: flex; align-items: center; justify-content: center; width: 360px; height: 60px; background-color: #FFEE00; border-radius: 10000px; transition: background-color 0.2s ease 0s; color: #1A1A1A; z-index: 2; }
.soudan-link:hover { background-color: #FFF23A; text-decoration: none; }
.soudan-link:hover .soudan-link__arrow { transform: translateX(4px); }
.soudan-link__text { display: block; font-weight: 600; margin-left: 7px; margin-right: 17px; padding-bottom: 4px; letter-spacing: 0px; font-size: 16px; line-height: 42px; }
.soudan-link__mail { width: 22px; height: 14px; }
.soudan-link__mail >
    svg { display: block; }
.soudan-link__mail >
    svg > use { fill: #1A1A1A; }
.soudan-link__arrow { transition: transform 0.2s ease 0s; width: 16px; height: 16px; position: relative; left: -5px; }
.soudan-link__arrow >
    svg { display: block; width: 100%; height: 100%; }
.soudan-link__arrow >
    svg > use { fill: #1A1A1A; }
 }
.ttl { font-weight: bold; font-size: 22px; letter-spacing: 0.05em; line-height: 42px; text-align: left; color: #1a1a1a; margin-bottom: 11px; }
.txt-box { font-weight: normal; font-size: 16px; line-height: 34px; text-align: left; color: #1a1a1a; .p-mb { margin-bottom: 8px; }
 }
 }
 }
 }
 }
 }
.support-header { width: -moz-fit-content; width: fit-content; margin-left: auto; margin-right: auto; position: relative; padding-bottom: 12px; }
.support-h { font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Sawarabi Mincho", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; position: relative; /* padding-left: 0.8em; */
    font-weight: 500; font-size: 54px; letter-spacing: -0.05em; line-height: 1.4814814815; /* text-align: center; */
    z-index: 2; left: 3px; text-align: left; letter-spacing: 1px; .ss { margin-right: 14px; letter-spacing: 1px; }
 }
.support-header-bg { position: absolute; z-index: 1; width: 1175px; bottom: calc(100% - 27px); left: 50%; right: 0; transform: translateX(calc(-50% + 1px)); margin-left: auto; margin-right: auto; }
.support-header-bg > img { display: block; max-width: 100%; }
.support-ansin { position: relative; margin-right: 40px; margin-bottom: 136px; }
.support-ansin__img { overflow: hidden; position: relative; width: 840px; z-index: 1; }
.support-ansin__img > img { position: relative; display: block; max-width: 100%; margin-left: -110px; transform: translateX(clamp(0px, (100vw - 1280px) / (220) * 110 + 0px, 110px)); }
.support-ansin__text { position: absolute; width: 700px; top: 60px; right: 0; transform: translateX(clamp(0px, (100vw - 1280px) / (220) * 40 + 0px, 40px)); z-index: 2; box-shadow: 0 20px 40px rgba(0, 0, 0, 0.16); background-color: #fff; padding: 68px 70px 80px 70px; }
.support-ansin__text > p { font-size: 16px; line-height: 2.375; }
.support-ansin__h { font-size: 22px; font-weight: 600; letter-spacing: 0.05em; line-height: 1; margin-bottom: 20px; }
.support-doctor__h { font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Sawarabi Mincho", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; margin-bottom: 42px; text-align: center; font-size: 32px; font-weight: 500; line-height: 1; letter-spacing: -0.05em; }
.support-doctor__banner { display: block; background-color: #fff; }
.support-doctor__banner > img { display: block; max-width: 100%; transition: opacity 0.2s ease 0s; }
.support-doctor__banner:hover > img { opacity: 0.7; }
.support-doctor__text { width: 820px; margin-top: 24px; margin-left: auto; margin-right: auto; font-size: 16px; line-height: 1.6875; }
.service { margin-top: 138px; .service-inner { .service-h-en { font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Sawarabi Mincho", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; font-weight: normal; font-size: 18px; line-height: 26.25px; text-align: center; color: #008fd1; margin-bottom: 3px; }
.service-h { font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Sawarabi Mincho", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; font-weight: bold; font-size: 45px; line-height: 78.75px; text-align: center; color: #1a1a1a; margin-bottom: 59px; }
.b-bg-box { background-image: url(../images/index/n-bg-02.png); background-repeat: no-repeat; background-position: center 0; padding-top: 352px; margin-bottom: 100px; .in-img { width: 1200px; margin: 0 auto; }
 }
.n-list { width: 1400px; margin: 0 auto; display: flex; flex-wrap: wrap; margin-bottom: 80px;
li { width: 460px; margin-right: 10px; position: relative;
&:hover{
    text-decoration: none;
    opacity: 0.8;
    .deco1{
                                     transform: translateX(4px);
    }
  }

  a:hover{
    text-decoration: none;
  }
  &:nth-child(3n) { margin-right: 0px; }
 }
.n-pic { }
.n-li-box { height: 310px; background-color: #E5E8EA; padding: 31px 45px 24px 51px; }
.n-li-box .n-li-ttl { font-weight: bold; font-size: 25px; line-height: 42px; text-align: left; color: #1a1a1a; margin-bottom: 14px; }
.n-li-box .n-txt-box { font-weight: normal; font-size: 16px; line-height: 27px; text-align: left; color: #1a1a1a; }
.deco1 { position: absolute; bottom: 21px; right: 20px; transition: transform 0.2s ease 0s;}
.deco2 { position: absolute; bottom: 20px; right: 16px; }
 }
 }
 }
/*============================
#plan
============================*/
#plan { margin-bottom: 135.5px; .inner { .en { font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Sawarabi Mincho", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; font-weight: 600; font-size: 18px; line-height: 26.25px; text-align: center; color: #008fd1; }
.ttl { font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Sawarabi Mincho", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; font-weight: 600; font-size: 45px; line-height: 78.75px; text-align: center; color: #1a1a1a; margin-bottom: 49px; }
.list { width: 1400px; margin: 0 auto; display: flex; flex-wrap: wrap; -webkit-box-pack: justify; -ms-flex-pack: justify; -webkit-justify-content: space-between; justify-content: space-between; li { width: 690px; }
 }
 }
 }
/*============================
#after
============================*/
#after { .inner { .ttl-bg-box { background-image: url(../images/index/n-bg-03.png); background-repeat: no-repeat; background-position: center 0; height: 240px; padding-top: 104px; .ttl { width: 244px; margin: 0 auto; }
 }
.bg-wap { background-image: url(../images/index/n-bg-04.png); background-repeat: no-repeat; background-position: center 0; height: 415px; .flex { width: 1100px; margin: 0 auto; display: flex; flex-wrap: wrap; padding-top: 58px; .box-l { width: 494px; margin-right: 53px; .ttl { font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Sawarabi Mincho", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; font-weight: 600; font-size: 40px; letter-spacing: -0.05em; line-height: 61px; text-align: left; color: #fff; /* border: 1px solid rgba(0, 0, 0, 0); */
  position: relative; left: 27px; .ss { position: relative; }
.ss.ano { position: relative; }
 }
 }
.box-r { width: 497px; .txt-box { font-weight: normal; font-size: 16px; line-height: 27px; text-align: left; color: #fff; position: relative; top: -10px; left: 28px; }
 }
 }
 }
 }
.shiro { .soudan-link { position: relative; display: flex; align-items: center; justify-content: center; width: 640px; height: 80px; margin: 0 auto; margin-top: 55px; background-color: #FFFFFF; border-radius: 10000px; transition: background-color 0.2s ease 0s; color: #1a1a1a; z-index: 2; box-shadow: 4px 6px 23px rgba(0, 0, 0, 0.04); }
.soudan-link:hover { text-decoration: none; }
.soudan-link:hover .soudan-link__arrow { transform: translateX(4px); }
.soudan-link__text { display: block; font-size: 18px; font-weight: 600; margin-left: 1px; margin-right: 20px; padding-bottom: 4px; line-height: 1; }
.soudan-link__mail { width: 22px; height: 14px; }
.soudan-link__mail > svg { display: block; }
.soudan-link__mail > svg > use { fill: #1a1a1a; }
.soudan-link__arrow { transition: transform 0.2s ease 0s; width: 16px; height: 16px; }
.soudan-link__arrow > svg { display: block; width: 100%; height: 100%; fill: #1a1a1a; }
.soudan-link__arrow > svg > use { fill: #1a1a1a; }
 }
 }
.soudan-link { position: relative; display: flex; align-items: center; justify-content: center; width: 100%; height: 80px; background-color: #EF7E10; border-radius: 10000px; transition: background-color 0.2s ease 0s; color: white; z-index: 2; }
.soudan-link:hover { background-color: #F2973F; text-decoration: none; }
.soudan-link:hover .soudan-link__arrow { transform: translateX(4px); }
.soudan-link__text { display: block; font-size: 18px; font-weight: 600; margin-left: 16px; margin-right: 20px; padding-bottom: 4px; line-height: 1; }
.soudan-link__mail { width: 22px; height: 14px; }
.soudan-link__mail > svg { display: block; }
.soudan-link__mail > svg > use { fill: #fff; }
.soudan-link__arrow { transition: transform 0.2s ease 0s; width: 16px; height: 16px; }
.soudan-link__arrow > svg { display: block; width: 100%; height: 100%; }
.soudan-link__arrow > svg > use { fill: #fff; }
/* works -------------------------------------*/
  .works { padding-top: 134px; padding-bottom: 160px; padding-left: 40px; padding-right: 40px; }
.works-inner { max-width: 1500px; margin-left: auto; margin-right: auto; }
.works-h-en { font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Sawarabi Mincho", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; margin-bottom: 27px; text-align: center; font-size: 18px; font-weight: 500; line-height: 1; color: #008FD1; }
.works-h { font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Sawarabi Mincho", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; font-size: 45px; font-weight: 500; line-height: 1; text-align: center; margin-bottom: 56px; }
.works-list { display: flex; flex-wrap: wrap; align-items: flex-start; gap: clamp(60px, (100vw - 1280px) / (640) * 19 + 60px, 79px) clamp(25px, (100vw - 1280px) / (640) * 35 + 25px, 60px); }
.works-item { width: calc((100% - clamp(25px, (100vw - 1280px) / (640) * 35 + 25px, 60px) * 2) / 3); }
.works-item__link { display: block; transition: opacity 0.2s ease 0s; }
.works-item__link:hover { text-decoration: none; opacity: 0.7; }
.works-item__link:hover .works-item__title { text-decoration: underline; text-underline-offset: 0.25em; text-decoration-thickness: 1px; }
.works-item__pic { width: 100%; aspect-ratio: 460/320; margin-bottom: 19px; }
.works-item__pic > img { display: block; width: 100%; height: 100%; -o-object-fit: cover; object-fit: cover; -o-object-position: center center; object-position: center center; }
.works-item__area { display: flex; align-items: center; justify-content: center; height: 30px; width: -moz-fit-content; width: fit-content; min-width: 80px; margin-bottom: 15px; color: #42AAE1; line-height: 1; font-size: 13px; padding-left: 1em; padding-right: 1em; border: 1px solid #42AAE1; }
.works-item__title { font-size: 16px; line-height: 1.6875; }
.works-more { width: 360px; margin-left: auto; margin-right: auto; margin-top: 71px; }
/* reason -------------------------------------*/
  .reason { position: relative; height: 880px; margin-top: 80px; margin-bottom: 120px; }
.reason::after { content: ""; display: block; position: absolute; bottom: 0; left: 0; width: max(1100px, (100vw - 1280px) / (640) * 460 + 1100px); height: 600px; z-index: 1; background-color: #E5E8EA; }
.reason-inner { position: relative; max-width: 1920px; margin-left: auto; margin-right: auto; height: 100%; z-index: 2; }
.reason-header { position: absolute; top: clamp(-17px, (100vw - 1280px) / (640) * 22 - 17px, 5px); left: clamp(54px, (100vw - 1280px) / (640) * 48 + 54px, 102px); z-index: 2; }
.reason-h-bg { position: absolute; top: -8px; left: -5px; transform: translate(-6.7%, -58%); width: clamp(603.7px, (100vw - 1280px) / (640) * 258.7 + 603.7px, 862.4px); z-index: 1; }
.reason-h-bg > img { display: block; max-width: 100%; }
.reason-h-sub { font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Sawarabi Mincho", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; position: relative; margin-bottom: 20px; font-size: 23px; font-weight: 500; line-height: 1; z-index: 2; position: relative; top: -9px; left: -8px; }
.reason-h { font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Sawarabi Mincho", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; position: relative; font-size: clamp(54px, (100vw - 1280px) / (640) * 13 + 54px, 67px); font-weight: 500; line-height: 1; z-index: 2; position: relative; top: -9px; left: -8px; }
.reason-select { position: relative; width: auto; height: 100%; z-index: 3; margin-left: clamp(50px, (100vw - 1280px) / (640) * 20 + 50px, 70px); }
.reason-list { position: absolute; width: clamp(560px, (100vw - 1280px) / (640) * 190 + 560px, 750px); left: -7px; bottom: 259px; }
.reason-list:has(.reason-item:nth-child(n+2):hover) > .reason-item:first-child { background-color: #fff; }
.reason-list:has(.reason-item:nth-child(n+2):hover) > .reason-item:first-child::after { transform: translateY(-50%); }
.reason-item { position: relative; display: flex; align-items: center; justify-content: flex-start; width: 100%; height: 140px; padding-bottom: 8px; background-color: #fff; padding-left: 52px; transition: background-color 0.4s ease 0s; }
.reason-item:nth-child(1) .reason-item-content { top: -210px; pointer-events: all; }
.reason-item:nth-child(2) .reason-item-content { opacity: 0; top: -350px; }
.reason-item:nth-child(3) .reason-item-content { opacity: 0; top: -490px; }
.reason-item:nth-child(4) .reason-item-content { opacity: 0; top: -630px; }
.reason-item:hover, .reason-item:first-child { background-color: #E5E8EA; }
.reason-item:hover::after, .reason-item:first-child::after { transform: translateX(50%) translateY(-50%); }
.reason-item:hover .reason-item-content, .reason-item:first-child .reason-item-content { opacity: 1; pointer-events: all; }
.reason-item::after { content: ""; display: block; position: absolute; top: 50%; right: 0; width: 60px; height: 1px; transform: translateY(-50%); background-color: #1A1A1A; transition: transform 0.4s ease 0s; }
.reason-item + .reason-item::before { content: ""; display: block; position: absolute; top: 0; left: 0; width: 100%; height: 1px; background-color: #DEE1E3; }
.reason-item__num { color: #42AAE1; font-size: 16px; line-height: 1; margin-right: 46px; }
.reason-item__title { font-size: 25px; line-height: 1; font-weight: 600; font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3","Sawarabi Mincho","Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; font-weight: 600; font-size: 40px; line-height: 42px; text-align: left; color: #1a1a1a; &.ano1 { position: relative; left: 0px; top: -3px; }
&.ano2 { position: relative; top: 2px; left: -7px; }
&.ano3 { position: relative; left: -7px; top: 4px; }
.ss1 { font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3","Sawarabi Mincho","Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; font-weight: 600; font-size: 64px; line-height: 67px; color: #1b6a8c; position: relative; left: 7px; top: 8px; margin-right: 12px; &.ano1 { font-size: 46px; line-height: 42px; color: #1b6a8c; position: relative; top: 2px; }
&.ano2 { font-size: 46px; line-height: 42px; color: #1b6a8c; position: relative; top: 0px; margin-right: 15px; }
 }
 }
.reason-item-content { position: absolute; top: 0; left: clamp(360px, (100vw - 1280px) / (640) * 300 + 360px, 660px); width: clamp(870px, (100vw - 1280px) / (640) * 320 + 870px, 1190px); height: 700px; transition: opacity 0.4s ease 0s; pointer-events: none; z-index: -1; }
.reason-item-content__image { width: 100%; height: 100%; }
.reason-item-content__image > img { display: block; width: 100%; height: 100%; -o-object-fit: cover; object-fit: cover; -o-object-position: center center; object-position: center center; }
.reason-item-content__text { position: absolute; bottom: 0; right: 0; width: 100%; max-width: 860px; height: 220px; padding-top: clamp(25px, (100vw - 1280px) / (640) * 27 + 25px, 52px); padding-right: 70px; background-image: linear-gradient(90deg, rgba(0, 0, 0, 0) 0%, rgb(19, 36, 54)); }
.reason-item-content__text > div { width: 440px; margin-left: auto; }
.reason-item-content__text > div > h3 { display: flex; align-items: center; justify-content: flex-start; font-size: 15px; line-height: 1; margin-bottom: 18px; color: #42AAE1; }
.reason-item-content__text > div > h3::after { content: ""; display: block; width: 80px; height: 1px; background-color: #42AAE1; margin-left: 16px; }
.reason-item-content__text > div > p { font-size: 15px; line-height: 1.7333333333; color: white; }
.reason-link { position: absolute; width: 360px; bottom: 79px; right: 62px; z-index: 4; }
.reason-link > .post-more-btn__text { margin-right: 6px; padding-bottom: 4px; }
/* renovation -------------------------------------*/
  .renovation { margin-top: 143px; margin-bottom: 151px; padding-left: 40px; padding-right: 40px; }
.renovation-inner { max-width: 1500px; margin-left: auto; margin-right: auto; }
.renovation-h { font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Sawarabi Mincho", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; font-size: 32px; line-height: 1.2; font-weight: 500; text-align: center; margin-bottom: 48px; }
.renovation-banner { display: block; transition: opacity 0.2s ease 0s; }
.renovation-banner > img { display: block; max-width: 100%; }
.renovation-banner:hover { opacity: 0.8; }
/* faq -------------------------------------*/
  .faq { background-color: #F5F6F7; padding-left: 60px; padding-right: 60px; padding-top: 90px; padding-bottom: 78px; }
.faq-inner { width: 1160px; margin-left: auto; margin-right: auto; }
.faq-h { background-image: linear-gradient(90deg, #54C2F0 0%, #1A77BC 100%); height: 70px; display: flex; align-items: center; justify-content: space-between; margin-bottom: 20px; padding: 0 19px 0 36px; line-height: 1; color: white; }
.faq-h__text { font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Sawarabi Mincho", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; font-size: 25px; font-weight: 500; padding-top: 5px; }
.faq-h__link { display: flex; align-items: center; font-size: 16px; font-weight: 500; padding: 10px 15px; border-radius: 1000px; gap: 10px; transition: background-color 0.2s ease 0s, color 0.2s ease 0s; color: white; }
.faq-h__link > span:nth-child(2) { transition: transform 0.2s ease 0s; }
.faq-h__link > span:nth-child(2) > svg { display: block; }
.faq-h__link > span:nth-child(2) > svg > use { transition: fill 0.2s ease 0s; fill: #fff; }
.faq-h__link:hover { background-color: #fff; color: #1A78BD; text-decoration: none; }
.faq-h__link:hover > span:nth-child(2) { transform: translateX(4px); }
.faq-h__link:hover > span:nth-child(2) > svg > use { fill: #1A78BD; }
.faq-item { position: relative; background-color: #fff; border-bottom: 2px solid #DEE1E3; }
.faq-item + .faq-item { margin-top: 18px; }
.faq-item__q { position: relative; display: flex; align-items: flex-start; justify-content: flex-start; gap: 30px; min-height: 90px; padding-left: 41px; padding-right: 80px; cursor: pointer; }
.faq-item__q::after { content: ""; display: block; position: absolute; border-top: 15.6px solid #1A77BC; border-left: 9px solid transparent; border-right: 9px solid transparent; right: 31px; bottom: 36px; transform-origin: center center; transition: transform 0.4s ease 0s; }
.faq-item__q > .faq-icon { margin-top: 28px; }
.faq-item__q > .faq-text { margin-top: 24px; font-size: 21px; font-weight: bold; line-height: 2; flex: 1; margin-bottom: 24px; }
.faq-item__q.onOpen::after { transform: rotate(180deg); }
.faq-item__a { position: relative; display: flex; align-items: flex-start; justify-content: flex-start; gap: 30px; min-height: 90px; padding-left: 41px; padding-right: 50px; }
.faq-item__a > .faq-icon { margin-top: 30px; }
.faq-item__a > .faq-text { font-size: 15px; line-height: 1.7333333333; flex: 1; margin-top: 31px; margin-bottom: 42px; }
.faq-item__a::after { content: ""; display: block; position: absolute; top: 0; left: 0; right: 0; margin-left: 30px; margin-right: 30px; height: 1px; width: auto; background-image: repeating-linear-gradient(90deg, #999999, #999999 1px, transparent 1px, transparent 4px); background-position: left top; background-repeat: repeat-x; background-size: 100% 100%; }
.faq-icon { display: block; width: 40px; height: 40px; }
.faq-icon > img { display: block; max-width: 100%; }
/* link-banners -------------------------------------*/
  .link-banners { background-color: #F5F6F7; padding-left: 60px; padding-right: 60px; }
.link-banners-inner { width: 860px; margin-left: auto; margin-right: auto; }
.link-banner-list { display: flex; justify-content: space-between; }
.link-banner { display: flex; width: 340px; height: 120px; background-color: #fff; transition: opacity 0.2s ease 0s; }
.link-banner:hover { opacity: 0.7; text-decoration: none; }
.link-banner:hover img { opacity: 1; }
.link-banner.imgonly .link-banner__pic { width: 100%; }
.link-banner.ext { position: relative; }
.link-banner.ext .link-banner__exticon { position: absolute; right: 11px; bottom: 9px; }
.link-banner.ext .link-banner__exticon > svg { display: block; }
.link-banner.ext .link-banner__exticon > svg > use { fill: #1a1a1a; }
.link-banner.ext--white .link-banner__exticon > svg > use { fill: #fff; }
.link-banner__pic { width: 140px; }
.link-banner__pic > img { display: block; max-width: 100%; }
.link-banner__text { flex: 1; display: flex; flex-direction: column; align-items: flex-start; justify-content: center; padding-left: 18px; gap: 12px; color: #1a1a1a; line-height: 1; }
.link-banner__title-en { font-size: 12px; letter-spacing: 0.05em; }
.link-banner__title { padding-bottom: 10px; font-size: 20px; font-weight: 600; letter-spacing: 0.05em; }
.seo-text { max-width: 1160px; margin-left: auto; margin-right: auto; margin-top: 77px; color: #808080; font-size: 13px; line-height: 2; }
/* blog -------------------------------------*/
  .blog { padding-top: 117px; padding-bottom: 130px; padding-left: 50px; padding-right: 50px; background-color: #F5F6F7; }
.blog-inner { max-width: 1180px; margin-left: auto; margin-right: auto; }
.blog-h-en { font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Sawarabi Mincho", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; margin-bottom: 22px; text-align: center; font-size: 18px; font-weight: 500; line-height: 1; color: #008FD1; }
.blog-h { font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Sawarabi Mincho", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; font-size: 45px; font-weight: 500; line-height: 1; text-align: center; margin-bottom: 36px; }
.blog-list { display: flex; flex-wrap: wrap; justify-content: flex-start; align-items: stretch; gap: 20px; }
.blog-item { width: 280px; min-height: 340px; background-color: #fff; }
.blog-item__link { display: block; height: 100%; padding: 10px 10px 20px 10px; transition: opacity 0.2s ease 0s; }
.blog-item__link:hover { text-decoration: none; opacity: 0.7; }
.blog-item__link:hover .blog-item__title { text-decoration: underline; text-underline-offset: 0.25em; text-decoration-thickness: 1px; }
.blog-item__pic { width: 100%; aspect-ratio: 260/180; margin-bottom: 15px; }
.blog-item__pic > img { display: block; width: 100%; height: 100%; -o-object-fit: cover; object-fit: cover; -o-object-position: center center; object-position: center center; }
.blog-item__date { margin-bottom: 11px; color: #42AAE1; line-height: 1; font-size: 13px; }
.blog-item__title { font-size: 16px; line-height: 1.6875; }
.blog-more { width: 360px; margin-left: auto; margin-right: auto; margin-top: 40px; }
.blog-more > .post-more-btn__text { padding-bottom: 4px; }
 }

@media screen and (min-width: 766px) and (max-width: 1580px) {

    .service {
        & .service-inner {
            .n-list {
                width: 1200px;
                margin: 0 auto;
                display: flex;
                flex-wrap: wrap;
                margin-bottom: 80px;
                                            li {
                    width: 384px;
                    margin-right: 23px;
                    position: relative;
                    img{
                      width: 100%;
                    }
                }
            }
        }
    }

        #plan {
        & .inner {
            .list {
                width: 1200px;
                margin: 0 auto;
                display: flex;
                flex-wrap: wrap;
                -webkit-box-pack: justify;
                -ms-flex-pack: justify;
                -webkit-justify-content: space-between;
                justify-content: space-between;
                li{
                  width: 591px;
                  img{
                    width: 100%;
                  }
                }
            }
        }
    }

        .reason-item__title {
        font-size: 30px;
    }
    .reason-item__title {
        .ss1 {
            font-size: 48px;
        &.ano1 {
                font-size: 42px;
            }
            &.ano2 {
                font-size: 42px;
            }
          }
    }

}


 @media screen and (max-width: 767px) {
 /* common */
  .post-more-btn { height: 14.4927536232vw; border-radius: 241.5458937198vw; display: flex; justify-content: center; align-items: center; background-image: linear-gradient(135deg, #54c2f0 0%, #1a77bc 50%, #54c2f0 100%); background-size: 200% 100%; background-position: 0%; transition: background-position 0.2s ease 0s; }
.post-more-btn:hover { background-position: -100%; text-decoration: none; }
.post-more-btn:hover .post-more-btn__arrow { transform: translateX(25%); }
.post-more-btn__text { padding-left: 1em; display: block; color: white; font-size: 3.8647342995vw; font-weight: 600; line-height: 1; margin-right: 1em; }
.post-more-btn__arrow { display: block; transition: transform 0.2s ease 0s; }
.post-more-btn__arrow > svg { display: block; width: 3.6231884058vw; height: 3.6231884058vw; }
.post-more-btn__arrow > svg > use { fill: #fff; }
/* common ここまで */
  .top-page-navi { display: none; }
.mv { position: relative; z-index: 2; width: 100%; aspect-ratio: 414/640; }
.mv__scroll { display: none; }
.mv__slider { width: 100%; background-color: #1a1a1a; }
.mv__slider .bx-wrapper { margin-bottom: 0; }
.mv__slider .bx-controls > .bx-pager { bottom: -7.729468599vw; display: flex; justify-content: center; align-items: center; padding-top: 0; gap: 4.8309178744vw; line-height: 0; }
.mv__slider .bx-controls > .bx-pager > .bx-pager-item > a.bx-pager-link { display: block; width: 2.8985507246vw; height: 2.8985507246vw; border-radius: 50%; margin: 0; background-color: #6A6A6A; }
.mv__slider .bx-controls > .bx-pager > .bx-pager-item > a.bx-pager-link.active { background-color: #fff; }
.mv-slider-item > img { max-width: 100%; }
/* lifespan -------------------------------------*/
  .lifespan { position: relative; background-color: #1a1a1a; margin-top: 0; padding-top: 19.3236714976vw; padding-bottom: 9.6618357488vw; padding-left: 2.8985507246vw; padding-right: 2.8985507246vw; z-index: 1; }
.lifespan-inner { display: flex; flex-direction: column; justify-content: flex-start; align-items: center; width: 100%; padding-top: 15.7004830918vw; padding-bottom: 11.5942028986vw; margin-left: auto; margin-right: auto; background-image: url(../images/index/lifespan-bg-sp.jpg); background-size: cover; background-position: center center; background-repeat: no-repeat; }
.lifespan-h { position: relative; width: 86.9565217391vw; margin-left: auto; margin-right: auto; margin-bottom: 5.7971014493vw; z-index: 1; }
.lifespan-h > img { position: relative; display: block; max-width: 100%; filter: drop-shadow(0 4.8309178744vw 7.2463768116vw rgba(0, 0, 0, 0.7)); z-index: 1; }
.lifespan-h::before { content: ""; display: block; position: absolute; bottom: calc(100% - 5.3140096618vw); left: 50%; transform: translateX(-50%); width: 16.9082125604vw; height: 15.4589371981vw; background-image: url(../images/index/lifespan-h-icon.png); background-repeat: no-repeat; background-size: contain; background-position: center bottom; z-index: 2; }
.lifespan-text { position: relative; width: 82.1256038647vw; margin-left: auto; margin-right: auto; z-index: 2; }
.lifespan-text > img { display: block; max-width: 100%; }
/* suppot -------------------------------------*/
  .support { padding-top: 12.077294686vw; padding-bottom: 26.5700483092vw; background-color: #E5E8EA; }
.support-header { display: flex; flex-direction: column-reverse; align-items: center; margin-bottom: 0vw; }
.support-h { font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Sawarabi Mincho", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; position: relative; font-weight: 500; font-size: 7.4879227053vw; letter-spacing: -0.05em; line-height: 1.4838709677; text-align: center; z-index: 2; margin-left: 0.5em; }
.support-header-bg { z-index: 1; width: 85.5072463768vw; margin-left: auto; margin-right: auto; margin-bottom: 7.0048309179vw; }
.support-header-bg > img { display: block; max-width: 100%; }
.support-ansin { position: relative; }
.support-ansin__img { overflow: hidden; position: relative; width: 100%; z-index: 1; }
.support-ansin__img > img { display: block; max-width: 100%; }
.support-ansin__text { position: relative; width: 94.2028985507vw; margin-left: auto; margin-right: auto; transform: translateY(-4.8309178744vw); z-index: 2; box-shadow: 0 4.8309178744vw 9.6618357488vw rgba(0, 0, 0, 0.16); background-color: #fff; padding: 10.8695652174vw 6.038647343vw 13.2850241546vw 6.038647343vw; }
.support-ansin__text > p { font-size: 3.8647342995vw; line-height: 1.875; }
.support-ansin__h { font-size: 4.347826087vw; font-weight: 600; letter-spacing: 0.05em; line-height: 1; margin-bottom: 5.3140096618vw; }
.support-doctor { margin-top: 17.3913043478vw; }
.support-doctor__h { font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Sawarabi Mincho", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; margin-bottom: 8.6956521739vw; text-align: center; font-size: 5.7971014493vw; font-weight: 500; line-height: 1.5833333333; }
.support-doctor__banner { display: block; width: 91.7874396135vw; margin-left: auto; margin-right: auto; background-color: #fff; }
.support-doctor__banner > img { display: block; max-width: 100%; transition: opacity 0.2s ease 0s; }
.support-doctor__banner:hover > img { opacity: 0.7; }
.support-doctor__text { width: 91.7874396135vw; margin-top: 7.2463768116vw; margin-left: auto; margin-right: auto; font-size: 3.8647342995vw; line-height: 1.6875; }
/* suppot -------------------------------------*/
  .support { padding-top: 23.913vw; padding-bottom: 21.981vw; background-color: #E5E8EA; }
.support-inner { .txt-sub { width: 67.15vw; margin: 0 auto; margin-bottom: 12.319vw; }
.bg-wap { width: 94.203vw; margin: 0 auto; background-repeat: no-repeat; background-position: center 0; padding-top: 7.729vw; padding-bottom: 12.077vw; background-color: #FFFFFF; .in { width: 100%; margin: 0 auto; .flex { display: flex; flex-wrap: wrap; .box-l { width: 79.71vw; margin: 0 auto; position: relative; top: 0; }
.box-r { width: 82.126vw; margin: 0 auto; padding-top: 7.729vw; position: relative; /* left: -1.449vw; */
.kiiro { margin-top: 6.039vw; .soudan-link { position: relative; display: flex; align-items: center; justify-content: center; width: 100%; height: 14.493vw; background-color: #FFEE00; border-radius: 2415.459vw; transition: background-color 0.2s ease 0s; color: #1A1A1A; z-index: 2; }
.soudan-link:hover { background-color: #FFF23A; text-decoration: none; }
.soudan-link:hover .soudan-link__arrow { transform: translateX(4px); }
.soudan-link__text { display: block; font-weight: 600; margin-left: 1.691vw; margin-right: 4.106vw; padding-bottom: 0.966vw; letter-spacing: 0px; font-size: 3.865vw; line-height: 10.145vw; }
.soudan-link__mail { width: 100%; height: 3.382vw; }
.soudan-link__mail >
    svg { display: block; }
.soudan-link__mail >
    svg > use { fill: #1A1A1A; }
.soudan-link__arrow { transition: transform 0.2s ease 0s; width: 3.382vw; height: 3.382vw; position: relative; left: -1.208vw; }
.soudan-link__arrow >
    svg { display: block; width: 100%; height: 100%; }
.soudan-link__arrow >
    svg > use { fill: #1A1A1A; }
 }
.ttl { font-weight: bold; text-align: left; color: #1a1a1a; margin-bottom: 1.208vw; font-size: 4.348vw; letter-spacing: 0.05em; line-height: 10.145vw; position: relative; left: 0.966vw; }
.txt-box { font-weight: normal; font-size: 3.865vw; line-height: 8.213vw; text-align: left; color: #1a1a1a; .p-mb { margin-bottom: 0.966vw; }
 }
 }
 }
 }
 }
 }
.support-header { width: -moz-fit-content; width: fit-content; margin-left: auto; margin-right: auto; position: relative; padding-bottom: 2.899vw; }
.support-h { font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Sawarabi Mincho", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; position: relative; font-weight: 500; z-index: 2; left: 0px; font-size: 7.971vw; letter-spacing: -0.05em; line-height: 11.836vw; text-align: center; color: #1a1a1a; margin-left: 0; .ss { /* margin-right: 3.382vw; */
      /* letter-spacing: 0.242vw; */
      display: block; }
 }
.support-header-bg { position: absolute; z-index: 1; width: 100%; bottom: calc(100% - 0.966vw); left: 50%; right: 0; transform: translateX(calc(-50% + 1px)); margin-left: auto; margin-right: auto; }
.support-header-bg > img { display: block; max-width: 100%; }
.support-ansin { position: relative; margin-right: 9.662vw; margin-bottom: 32.85vw; }
.support-ansin__img { overflow: hidden; position: relative; width: 100%; z-index: 1; }
.support-ansin__img > img { position: relative; display: block; max-width: 100%; margin-left: -26.57vw; transform: translateX(clamp(0px, (100vw - 1280px) / (220) * 110 + 0px, 110px)); }
.support-ansin__text { position: absolute; width: 100%; top: 14.493vw; right: 0; transform: translateX(clamp(0px, (100vw - 1280px) / (220) * 40 + 0px, 40px)); z-index: 2; box-shadow: 0 20px 40px rgba(0, 0, 0, 0.16); background-color: #fff; padding: 16.425vw 16.908vw 19.324vw 16.908vw; }
.support-ansin__text > p { font-size: 3.865vw; line-height: 2.375; }
.support-ansin__h { font-size: 5.314vw; font-weight: 600; letter-spacing: 0.05em; line-height: 1; margin-bottom: 4.831vw; }
.support-doctor__h { font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Sawarabi Mincho", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; margin-bottom: 10.145vw; text-align: center; font-size: 7.729vw; font-weight: 500; line-height: 1; letter-spacing: -0.05em; }
.support-doctor__banner { display: block; background-color: #fff; }
.support-doctor__banner > img { display: block; max-width: 100%; transition: opacity 0.2s ease 0s; }
.support-doctor__banner:hover > img { opacity: 0.7; }
.support-doctor__text { width: 100%; margin-top: 5.797vw; margin-left: auto; margin-right: auto; font-size: 3.865vw; line-height: 1.6875; }
.service { margin-top: 12.802vw; .service-inner { .service-h-en { font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Sawarabi Mincho", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; font-weight: 600; font-size: 4.348vw; line-height: 6.341vw; text-align: center; color: #008fd1; margin-bottom: 3.623vw; font-size: 4.348vw; line-height: 6.341vw; }
.service-h { font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Sawarabi Mincho", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; font-weight: bold; text-align: center; color: #1a1a1a; margin-bottom: 8.937vw; font-size: 7.729vw; line-height: 10.628vw; }
.b-bg-box { background-image: url(../images/index/sp-n-bg-02.png); background-repeat: no-repeat; background-position: center 0;
  background-size: contain;
  padding-top: 43.478vw; margin-bottom: 7.729vw; .in-img { width: 94.203vw; margin: 0 auto; }
 }
.n-list { width: 94.203vw; margin: 0 auto; display: flex; flex-wrap: wrap; margin-bottom: 9.662vw; li { width: 100%; position: relative; margin-bottom: 9.662vw; &:nth-child(3n) { margin-right: 0px; }
 }
.n-pic { }
.n-li-box { /* height: 74.879vw; */
          background-color: #E5E8EA; padding: 3.865vw 6.039vw 15.942vw; }
.n-li-box .n-li-ttl { font-weight: bold; text-align: left; color: #1a1a1a; margin-bottom: 2.174vw; font-size: 4.348vw; line-height: 10.145vw; }
.n-li-box .n-txt-box { font-weight: normal; font-size: 3.865vw; line-height: 6.522vw; text-align: left; color: #1a1a1a; }
.deco1 { position: absolute; bottom: 4.348vw; right: 4.348vw; }
.deco2 { position: absolute; bottom: 4.348vw; right: 3.865vw; width: 4.348vw; }
 }
 }
 }
/*============================
#plan
============================*/
#plan { margin-bottom: 22.343vw; .inner { .en { font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Sawarabi Mincho", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; font-weight: 600; font-size: 4.348vw; line-height: 6.341vw; text-align: center; color: #008fd1; margin-bottom: 3.865vw; }
.ttl { font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Sawarabi Mincho", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; font-weight: 600; color: #1a1a1a; margin-bottom: 8.937vw; font-size: 7.729vw; line-height: 10.628vw; text-align: center; }
.list { width: 86.957vw; margin: 0 auto; display: flex; flex-wrap: wrap; -webkit-box-pack: justify; -ms-flex-pack: justify; -webkit-justify-content: space-between; justify-content: space-between; li { width: 100%; margin-bottom: 4.831vw; }
 }
 }
 }
/*============================
#after
============================*/
#after { .inner { .ttl-bg-box { background-image: url(../images/index/sp-n-bg-03.png); background-repeat: no-repeat; background-position: center 0; background-size: 100%; height: 57.971vw; padding-top: 12.077vw; .ttl { width: 71.014vw; margin: 0 auto; }
 }
.bg-wap { background-image: url(../images/index/sp-n-bg-04.png); background-repeat: no-repeat; background-position: center 0; background-size: cover; padding-bottom: 20.29vw; .flex { width: 100%; margin: 0 auto; display: flex; flex-wrap: wrap; padding-top: 14.01vw; .box-l { width: 83.575vw; margin-left: 3.623vw; .ttl { font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Sawarabi Mincho", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; font-weight: 600; text-align: left; color: #fff; position: relative; left: 6.522vw; font-size: 6.763vw; letter-spacing: -0.05em; line-height: 10.386vw; margin-bottom: 7.488vw; .ss { position: relative; display: block; margin-bottom: 0.483vw; /* position: relative; */
              /* left: 1.208vw; */ }
.ss.ano { position: relative; left: 1.208vw; }
 }
 }
.box-r { width: 82.126vw; margin: 0 auto; .txt-box { font-weight: normal; font-size: 3.865vw; line-height: 6.522vw; text-align: left; color: #fff; position: relative; /* top: -2.415vw; *//* left: 6.763vw; */ }
 }
 }
 }
 }
.shiro { .soudan-link { position: relative; display: flex; align-items: center; justify-content: center; width: 86.957vw; height: 19.324vw; margin: 0 auto; margin-top: 14.01vw; background-color: #FFFFFF; border-radius: 2415.459vw; transition: background-color 0.2s ease 0s; color: #1a1a1a; z-index: 2; box-shadow: 4px 6px 23px rgba(0, 0, 0, 0.04); }
.soudan-link:hover { text-decoration: none; }
.soudan-link:hover .soudan-link__arrow { transform: translateX(4px); }
.soudan-link__text { display: block; font-weight: 600; margin-left: 0.242vw; margin-right: 4.831vw; padding-bottom: 0.966vw; font-size: 3.865vw; line-height: 10.145vw; }
.soudan-link__mail { width: 100%; height: 3.382vw; }
.soudan-link__mail > svg { display: block; }
.soudan-link__mail > svg > use { fill: #1a1a1a; }
.soudan-link__arrow { transition: transform 0.2s ease 0s; width: 3.865vw; height: 3.865vw; }
.soudan-link__arrow > svg { display: block; width: 100%; height: 100%; fill: #1a1a1a; }
.soudan-link__arrow > svg > use { fill: #1a1a1a; }
 }
 }
/* soudan -------------------------------------*/
  .soudan { width: 100%; aspect-ratio: 414/580; margin-left: auto; margin-right: auto; background-image: url(../images/index/soudan-bg-sp.jpg); background-repeat: no-repeat; background-size: cover; background-position: center center; }
.soudan-content { position: relative; display: flex; flex-direction: column; justify-content: space-between; align-items: center; width: 100%; height: 100%; padding-top: 29.7101449275vw; padding-bottom: 13.2850241546vw; }
.soudan-content::after { content: ""; display: block; position: absolute; bottom: 32.6086956522vw; left: 50%; transform: translateX(-50%); width: 23.1884057971vw; aspect-ratio: 350/335; background-image: url(../images/index/soudan-person.png); background-repeat: no-repeat; background-size: contain; background-position: center bottom; z-index: 1; }
.soudan-content-upper { display: flex; flex-direction: column; align-items: center; }
.soudan-content-upper .soudan-p01 { margin-bottom: 7.729468599vw; font-size: 4.5893719807vw; font-weight: bold; line-height: 1; color: white; }
.soudan-content-upper .soudan-h { position: relative; font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Sawarabi Mincho", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; display: flex; flex-direction: column; align-items: center; margin-bottom: 5.3140096618vw; font-size: 12.077294686vw; font-weight: 500; line-height: 1; z-index: 2; letter-spacing: -0.05em; gap: 7.2463768116vw; }
.soudan-content-upper .soudan-h .soudan-h01 { position: relative; display: block; width: 77.2946859903vw; color: #FFE100; text-align: center; }
.soudan-content-upper .soudan-h .soudan-h01::after { content: ""; display: block; position: absolute; left: 0; bottom: -1.4492753623vw; background-color: #EF7E10; width: 100%; height: 3.8647342995vw; z-index: -1; }
.soudan-content-upper .soudan-h .soudan-h02 { position: relative; display: block; width: 88.8888888889vw; color: #fff; text-align: center; }
.soudan-content-upper .soudan-h .soudan-h02::after { content: ""; display: block; position: absolute; left: 0; bottom: -1.4492753623vw; background-color: #EF7E10; width: 100%; height: 3.8647342995vw; z-index: -1; }
.soudan-content-upper .soudan-p02 { font-size: 3.3816425121vw; font-weight: 500; line-height: 1; color: white; }
.soudan-link { display: flex; align-items: center; justify-content: center; width: 86.9565217391vw; height: 19.3236714976vw; background-color: #EF7E10; border-radius: 2415.459vw; transition: background-color 0.2s ease 0s; color: white; }
.soudan-link:hover { background-color: #F2973F; text-decoration: none; }
.soudan-link:hover .soudan-link__arrow { transform: translateX(25%); }
.soudan-link__text { display: block; font-size: 4.347826087vw; font-weight: 600; margin-left: 2.8985507246vw; margin-right: 2.4154589372vw; padding-bottom: 0.4830917874vw; line-height: 1; }
.soudan-link__mail { width: 5.3140096618vw; height: 3.3816425121vw; }
.soudan-link__mail > svg { display: block; width: 100%; height: 100%; -o-object-fit: contain; object-fit: contain; -o-object-position: center center; object-position: center center; }
.soudan-link__mail > svg > use { fill: #fff; }
.soudan-link__arrow { transition: transform 0.2s ease 0s; width: 3.8647342995vw; height: 3.8647342995vw; }
.soudan-link__arrow > svg { display: block; width: 100%; height: 100%; -o-object-fit: contain; object-fit: contain; -o-object-position: center center; object-position: center center; }
.soudan-link__arrow > svg > use { fill: #fff; }
/* works -------------------------------------*/
  .works { padding-top: 18.3574879227vw; padding-bottom: 16.9082125604vw; }
.works-inner { width: 94.2028985507vw; margin-left: auto; margin-right: auto; }
.works-h-en { font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Sawarabi Mincho", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; margin-bottom: 5.3140096618vw; text-align: center; font-size: 4.347826087vw; font-weight: 500; line-height: 1; color: #008FD1; }
.works-h { font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Sawarabi Mincho", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; font-size: 7.729468599vw; font-weight: 500; line-height: 1; text-align: center; margin-bottom: 10.6280193237vw; }
.works-list { display: flex; flex-wrap: wrap; align-items: flex-start; gap: 12.077294686vw 2.4154589372vw; }
.works-item { width: calc((100% - 2.4154589372vw) / 2); }
.works-item__link { display: block; transition: opacity 0.2s ease 0s; }
.works-item__link:hover { text-decoration: none; opacity: 0.7; }
.works-item__link:hover .works-item__title { text-decoration: underline; text-underline-offset: 0.25em; text-decoration-thickness: 0.242vw; }
.works-item__pic { width: 100%; aspect-ratio: 460/320; margin-bottom: 2.8985507246vw; }
.works-item__pic > img { display: block; width: 100%; height: 100%; -o-object-fit: cover; object-fit: cover; -o-object-position: center center; object-position: center center; }
.works-item__area { display: flex; align-items: center; justify-content: center; height: 7.2463768116vw; width: -moz-fit-content; width: fit-content; min-width: 19.3236714976vw; margin-bottom: 3.8647342995vw; color: #42AAE1; line-height: 1; font-size: 3.1400966184vw; padding-left: 1.5em; padding-right: 1.5em; border: 1px solid #42AAE1; }
.works-item__title { font-size: 3.6231884058vw; line-height: 1.4; }
.works-more { width: 86.9565217391vw; margin-left: auto; margin-right: auto; margin-top: 14.4927536232vw; }
/* reason -------------------------------------*/
  .reason { position: relative; padding-top: 23.1884057971vw; padding-bottom: 24.154589372vw; }
.reason::after { content: ""; display: block; position: absolute; bottom: 0; left: 0; width: 100%; height: calc(100% - 67.6328502415vw); z-index: 1; background-color: #E5E8EA; }
.reason-inner { position: relative; z-index: 2; }
.reason-header { position: relative; display: flex; flex-direction: column; align-items: center; margin-bottom: 6.2801932367vw; }
.reason-h-bg { position: absolute; top: -14.0096618357vw; left: 0; width: 100%; z-index: 1; overflow: hidden; }
.reason-h-bg > img { display: block; max-width: initial; width: 104.1062801932vw; margin-left: -2.0531400966vw; }
.reason-h-sub { font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Sawarabi Mincho", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; position: relative; margin-bottom: 3.3816425121vw; font-size: 5.5555555556vw; font-weight: 500; line-height: 1; z-index: 2; }
.reason-h { font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Sawarabi Mincho", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; position: relative; font-size: 10.1449275362vw; font-weight: 500; line-height: 1; z-index: 2; }
.reason-select { width: 86.9565217391vw; margin-left: auto; margin-right: auto; }
.reason-item { position: relative; display: flex; flex-direction: column; align-items: center; justify-content: flex-start; width: 100%; background-color: #fff; border-top: 1px solid #DEE1E3; padding: 9.1787439614vw 4.8309178744vw 11.3526570048vw; }
.reason-item + .reason-item { margin-top: 7.2463768116vw; }
.reason-item__num { display: none; }
.reason-item__title { font-size: 5.5555555556vw; margin-bottom: 4.347826087vw; line-height: 1; font-weight: 600; order: 2; font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Sawarabi Mincho", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; font-weight: 600; font-size: 5.556vw; line-height: 10.145vw; text-align: center; color: #1a1a1a; .ss1 { color: #1B6A8C; }
 }
.reason-item-content { display: contents; }
.reason-item-content__image { width: 100%; aspect-ratio: 320/200; order: 3; margin-bottom: 4.347826087vw; }
.reason-item-content__image > img { display: block; width: 100%; height: 100%; -o-object-fit: cover; object-fit: cover; -o-object-position: center center; object-position: center center; }
.reason-item-content__text { display: contents; }
.reason-item-content__text > div { display: contents; }
.reason-item-content__text > div > h3 { order: 1; font-size: 3.6231884058vw; line-height: 1; margin-bottom: 3.3816425121vw; color: #42AAE1; }
.reason-item-content__text > div > p { order: 4; font-size: 3.6231884058vw; line-height: 1.6; }
.reason-link { width: 86.9565217391vw; margin-left: auto; margin-right: auto; margin-top: 16.9082125604vw; }
/* renovation -------------------------------------*/
  .renovation { margin-top: 19.3236714976vw; margin-bottom: 31.4009661836vw; }
.renovation-inner { max-width: 91.7874396135vw; margin-left: auto; margin-right: auto; }
.renovation-h { font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Sawarabi Mincho", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; font-size: 5.7971014493vw; line-height: 1.5833333333; font-weight: 500; text-align: center; margin-bottom: 10.8695652174vw; }
.renovation-banner { display: block; transition: opacity 0.2s ease 0s; }
.renovation-banner > img { display: block; max-width: 100%; }
.renovation-banner:hover { opacity: 0.8; }
/* faq -------------------------------------*/
  .faq { background-color: #F5F6F7; padding-top: 19.3236714976vw; padding-bottom: 14.4927536232vw; }
.faq-inner { width: 94.2028985507vw; margin-left: auto; margin-right: auto; }
.faq-h { background-image: linear-gradient(90deg, #54C2F0 0%, #1A77BC 100%); height: 16.9082125604vw; display: flex; align-items: center; justify-content: space-between; padding: 0 0.9661835749vw 0 4.347826087vw; line-height: 1; color: white; }
.faq-h__text { font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Sawarabi Mincho", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; font-size: 4.8309178744vw; font-weight: 500; }
.faq-h__link { display: flex; align-items: center; font-size: 3.8647342995vw; font-weight: 500; padding: 1.4492753623vw 2.4154589372vw; border-radius: 241.5458937198vw; gap: 2.4154589372vw; transition: background-color 0.2s ease 0s, color 0.2s ease 0s; color: white; }
.faq-h__link > span:nth-child(2) { transition: transform 0.2s ease 0s; }
.faq-h__link > span:nth-child(2) > svg { display: block; }
.faq-h__link > span:nth-child(2) > svg > use { transition: fill 0.2s ease 0s; fill: #fff; }
.faq-h__link:hover { background-color: #fff; color: #1A78BD; text-decoration: none; }
.faq-h__link:hover > span:nth-child(2) { transform: translateX(25%); }
.faq-h__link:hover > span:nth-child(2) > svg > use { fill: #1A78BD; }
.faq-item { position: relative; background-color: #fff; border-bottom: 0.4830917874vw solid #DEE1E3; }
.faq-item + .faq-item { margin-top: 2.4154589372vw; }
.faq-item__q { position: relative; display: flex; align-items: flex-start; justify-content: flex-start; gap: 1.690821256vw; min-height: 21.7391304348vw; padding-left: 2.1739130435vw; padding-right: 13.0434782609vw; cursor: pointer; }
.faq-item__q::after { content: ""; display: block; position: absolute; border-top: 3.768115942vw solid #1A77BC; border-left: 2.1739130435vw solid transparent; border-right: 2.1739130435vw solid transparent; right: 5.0724637681vw; top: 50%; transform: translateY(-50%); transform-origin: center center; transition: transform 0.4s ease 0s; }
.faq-item__q > .faq-icon { margin-top: 6.7632850242vw; }
.faq-item__q > .faq-text { margin-top: 5.7971014493vw; font-size: 4.1062801932vw; font-weight: bold; line-height: 1.4705882353; flex: 1; margin-bottom: 5.7971014493vw; }
.faq-item__q.onOpen::after { transform: translateY(-50%) rotate(180deg); }
.faq-item__a { position: relative; display: flex; align-items: flex-start; justify-content: flex-start; gap: 1.690821256vw; min-height: 21.7391304348vw; padding-left: 2.1739130435vw; padding-right: 3.1400966184vw; }
.faq-item__a > .faq-icon { margin-top: 5.0724637681vw; }
.faq-item__a > .faq-text { margin-top: 5.0724637681vw; font-size: 3.6231884058vw; line-height: 1.7333333333; flex: 1; margin-bottom: 8.9371980676vw; }
.faq-item__a::after { content: ""; display: block; position: absolute; top: 0; left: 0; right: 0; margin-left: 2.6570048309vw; margin-right: 2.6570048309vw; height: 0.242vw; width: auto; background-image: repeating-linear-gradient(90deg, #999999, #999999 1px, transparent 1px, transparent 0.9661835749vw); background-position: left top; background-repeat: repeat-x; background-size: 100% 100%; }
.faq-icon { display: block; width: 9.6618357488vw; height: 9.6618357488vw; }
.faq-icon > img { display: block; max-width: 100%; }
/* link-banners -------------------------------------*/
  .link-banners { background-color: #F5F6F7; }
.link-banners-inner { width: 82.1256038647vw; margin-left: auto; margin-right: auto; }
.link-banner-list { display: flex; flex-direction: column; gap: 7.2463768116vw; }
.link-banner { display: flex; width: 82.1256038647vw; height: 28.9855072464vw; background-color: #fff; transition: opacity 0.2s ease 0s; }
.link-banner:hover { opacity: 0.7; text-decoration: none; }
.link-banner:hover img { opacity: 1; }
.link-banner.imgonly .link-banner__pic { width: 100%; }
.link-banner.ext { position: relative; }
.link-banner.ext .link-banner__exticon { position: absolute; width: 3.6231884058vw; height: 3.6231884058vw; right: 2.6570048309vw; bottom: 2.1739130435vw; }
.link-banner.ext .link-banner__exticon > svg { display: block; width: 100%; height: 100%; -o-object-fit: contain; object-fit: contain; -o-object-position: center top; object-position: center top; }
.link-banner.ext .link-banner__exticon > svg > use { fill: #1a1a1a; }
.link-banner.ext--white .link-banner__exticon > svg > use { fill: #fff; }
.link-banner__pic { width: 33.8164251208vw; }
.link-banner__pic > img { display: block; max-width: 100%; }
.link-banner__text { flex: 1; display: flex; flex-direction: column; align-items: flex-start; justify-content: center; padding-left: 4.347826087vw; gap: 2.8985507246vw; color: #1a1a1a; line-height: 1; }
.link-banner__title-en { font-size: 2.8985507246vw; letter-spacing: 0.05em; }
.link-banner__title { font-size: 4.8309178744vw; font-weight: 600; letter-spacing: 0.05em; }
.seo-text { width: 94.2028985507vw; margin-left: auto; margin-right: auto; margin-top: 14.4927536232vw; color: #808080; font-size: 3.1400966184vw; line-height: 2; }
/* blog -------------------------------------*/
  .blog { padding-top: 19.3236714976vw; padding-bottom: 26.0869565217vw; background-color: #F5F6F7; }
.blog-inner { max-width: 94.2028985507vw; margin-left: auto; margin-right: auto; }
.blog-h-en { font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Sawarabi Mincho", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; margin-bottom: 5.3140096618vw; text-align: center; font-size: 4.347826087vw; font-weight: 500; line-height: 1; color: #008FD1; }
.blog-h { font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Sawarabi Mincho", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; font-size: 10.8695652174vw; font-weight: 500; line-height: 1; text-align: center; margin-bottom: 6.7632850242vw; }
.blog-list { display: flex; flex-wrap: wrap; justify-content: flex-start; align-items: stretch; gap: 2.4154589372vw; }
.blog-item { width: 45.8937198068vw; background-color: #fff; }
.blog-item__link { display: block; height: 100%; padding: 2.4154589372vw 2.4154589372vw 7.2463768116vw 2.4154589372vw; transition: opacity 0.2s ease 0s; }
.blog-item__link:hover { text-decoration: none; opacity: 0.7; }
.blog-item__link:hover .blog-item__title { text-decoration: underline; text-underline-offset: 0.25em; text-decoration-thickness: 0.242vw; }
.blog-item__pic { width: 100%; aspect-ratio: 260/180; margin-bottom: 3.8647342995vw; }
.blog-item__pic > img { display: block; width: 100%; height: 100%; -o-object-fit: cover; object-fit: cover; -o-object-position: center center; object-position: center center; }
.blog-item__date { margin-bottom: 3.1400966184vw; color: #42AAE1; line-height: 1; font-size: 3.1400966184vw; }
.blog-item__title { font-size: 3.6231884058vw; line-height: 1.3125; }
.blog-more { width: 86.9565217391vw; margin-left: auto; margin-right: auto; margin-top: 7.2463768116vw; }
 }
