.home_page .key {
    position: relative;
    z-index: 2;
}

.home_page .key .key-fx-mvs {
    display: flex;
    justify-content: center;
    max-width: 1280px;
    margin: 0 auto;
    position: relative;
}

.home_page .key .key-fx-mvs:before {
    content: "";
    position: absolute;
    left: -52px;
    bottom: -30px;
    background: url(../images/idx-main-ico01.png) no-repeat center;
    background-size: contain;
    width: 444px;
    height: 346px;
    z-index: 1;
}

.home_page .key .key-fx-mvs .box-cnt {
    flex: 1;
    display: flex;
    justify-content: center;
    align-items: flex-start;
    padding-top: 40px;
    padding-left: 4px;
}

.home_page .key .key-fx-mvs .box-cnt .mvs-box-ttl {
    display: flex;
    flex-direction: row-reverse;
    align-items: flex-end;
}

.home_page .key .key-fx-mvs .box-cnt .mvs-box-ttl .mvs-ttl,
.home_page .key .key-fx-mvs .box-cnt .mvs-box-ttl .mvs-sub-ttl {
    writing-mode: tb-rl;
    color: var(--main-color);
    font-weight: bold;
    margin-bottom: 0;
    line-height: 1.8em;
    letter-spacing: 0.23em;
}

.home_page .key .key-fx-mvs .box-cnt .mvs-box-ttl .mvs-ttl {
    font-size: 32px;
}

.home_page .key .key-fx-mvs .box-cnt .mvs-box-ttl .mvs-sub-ttl {
    margin-right: 4px;
    line-height: 1.9em;
    font-size: 18px;
    font-weight: 500;
    letter-spacing: 0.2em;
    margin-bottom: 5px;
}

.home_page .key .key-fx-mvs .box-img {
    flex-shrink: 0;
    position: relative;
}

.home_page .key .key-fx-mvs .box-img .img {
    margin-bottom: 0;
}

.home_page .key .key-fx-mvs .box-img .img img {
    border-top-left-radius: 50px;
    border-bottom-left-radius: 50px;
}

.home_page .key .key-fx-mvs .box-img .mvs-scroll {
    position: absolute;
    right: 38px;
    bottom: 72px;
    text-decoration: none;
    color: #fff;
    font-family: var(--f-jose);
    font-size: 18px;
    writing-mode: tb-rl;
    letter-spacing: 0;
}

.home_page .key .key-fx-mvs .box-img .mvs-scroll:after {
    content: "";
    position: absolute;
    left: 3px;
    right: 0;
    top: calc(100% + 12px);
    width: 2px;
    height: 110px;
    background: #fff;
    margin: 0 auto;
    animation: scroll 1.5s infinite alternate-reverse forwards;
}

.home_page .key .mv_slider {
    display: flex;
}

.home_page .key .key_text {
    position: relative;
    width: 100%;
    height: 100%;
}

.home_page .key .key_text .item {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    height: var(--height);
    min-height: var(--min-height);
    max-height: var(--max-height);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}

.home_page .key .catch {
    padding: 10px;
    margin: 0px auto;
    max-width: 800px;
}

.home_page .key .catch .title,
.home_page .key .catch p {
    color: #fff;
    font-weight: 500;
    letter-spacing: 0.1em;
}

.home_page .key .catch .title {
    margin-bottom: 1em;
    font-size: 4em;
    line-height: 2;
}

.home_page .key .catch p {
    font-size: 2em;
}

.home_page .topic_path {
    display: none;
}

.home_page h2 {
    position: relative;
    margin-bottom: 31px;
    color: var(--main-color);
    font-family: var(--f-jp);
    font-size: calc(var(--ttl_size) + 14px);
    font-weight: 600;
    letter-spacing: 0.15em;
}

.home_page h2 .en {
    color: var(--main-color);
    font-weight: 500;
    text-transform: uppercase;
}

.home_page h2.white {
    color: #fff;
}

.home_page h2.white .en {
    color: #fff;
}

.home_page h3 {
    color: var(--clr1);
    font-family: var(--f-jp);
    font-size: calc(var(--ttl_size) + 0px);
}

@keyframes scroll {
    0% {
        top: 6em
    }
    to {
        top: calc(100% + 12px);
    }
}

@media only screen and (min-width: 769px) {
    .idx-list-ct li a:hover {
        color: var(--clr1);
    }
    .index04 .idx-fx-about.idx-fx-about04 .box-cnt .idx-list-link-about li a:hover {
        transform: translateY(-5px);
        transition: 0.3s all;
    }
}

section {
    background-size: cover;
    background-repeat: no-repeat;
}

.index0 {
    padding: 100px 0 69px;
    margin-top: 0;
    position: relative;
    z-index: 1;
}

.index0:before {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
    background: #FAF8F4;
    height: 100%;
    width: 100%;
    z-index: -1;
}

.index0:after {
    content: "";
    position: absolute;
    left: 11px;
    right: 0;
    top: 127px;
    margin: 0 auto;
    background: url(../images/idx-bg-sec0.png) no-repeat center;
    background-size: contain;
    width: 1198px;
    height: 522px;
    z-index: -1;
}

.index0 .idx-fx-family {
    display: flex;
    padding-left: 100px;
}

.index0 .idx-fx-family .box-cnt {
    max-width: 375px;
}

.index0 .idx-fx-family .box-cnt .txt {
    letter-spacing: -0.5px;
    font-weight: 500;
    line-height: 2em;
}

.index0 .idx-fx-family .box-img {
    flex: 1;
    display: flex;
    align-items: center;
    position: relative;
    top: -147px;
    left: -11px;
    z-index: 1;
}

.index0 .idx-fx-family .box-img .img {
    width: 413px;
    height: 446px;
    margin-bottom: 0;
    margin-top: -72px;
    margin-right: 12px;
    --mask: url(../images/idx-sec0-mask01.png);
    mask-image: var(--mask);
    -webkit-mask-image: var(--mask);
    mask-repeat: no-repeat;
    -webkit-mask-repeat: no-repeat;
    mask-size: 100% auto;
    -webkit-mask-size: 100% auto;
    mask-position: center;
}

.index0 .idx-fx-family .box-img .img img {
    height: 100%;
    width: 100%;
}

.index0 .idx-fx-family .box-img .box-fx-img .img02 {
    margin-bottom: 20px;
    margin-top: 53px;
    --mask: url(../images/idx-sec0-mask02.png);
    mask-image: var(--mask);
    -webkit-mask-image: var(--mask);
    mask-repeat: no-repeat;
    -webkit-mask-repeat: no-repeat;
    mask-size: 100% auto;
    -webkit-mask-size: 100% auto;
    mask-position: center;
}

.index0 .idx-fx-family .box-img .box-fx-img .img03 {
    width: 241px;
    height: 271px;
    --mask: url(../images/idx-sec0-mask03.png);
    mask-image: var(--mask);
    -webkit-mask-image: var(--mask);
    mask-repeat: no-repeat;
    -webkit-mask-repeat: no-repeat;
    mask-size: 100% auto;
    -webkit-mask-size: 100% auto;
    mask-position: center;
}

.idx-box-howto {
    width: calc(100% - 50px);
    background: #FFFFFF;
    position: relative;
    margin-left: auto;
    border-top-left-radius: 50px;
    border-bottom-left-radius: 50px;
    text-align: center;
    margin-top: -198px;
    padding: 72px 99px 70px;
}

.idx-box-howto:before {
    content: "";
    position: absolute;
    right: 0;
    top: 0;
    bottom: 0;
    margin: auto 0;
    width: calc(100% - 20px);
    height: calc(100% - 40px);
    background: url(../images/idx-bg-howto.png) no-repeat left;
    background-size: cover;
}

.idx-box-howto:after {
    content: "";
    position: absolute;
    left: -23px;
    top: 72px;
    background: url(../images/idx-ico-box-howto.svg) no-repeat center;
    background-size: contain;
    width: 144px;
    height: 125px;
}

.idx-box-howto .idx-ttl-en {
    padding-top: 25px;
    padding-left: 0;
}

.idx-box-howto .idx-ttl-en:before {
    top: 0;
    left: 0;
    right: 0;
    margin: 0 auto;
}

.idx-box-howto h2 {
    letter-spacing: 0.05em;
    margin-bottom: 60px;
}

.idx-box-howto .idx-list-howto {
    display: flex;
    margin-bottom: 63px;
}

.idx-box-howto .idx-list-howto li {
    margin-right: 20px;
}

.idx-box-howto .idx-list-howto li:last-child {
    margin-right: 0;
}

.idx-box-howto .idx-list-howto li a {
    text-decoration: none;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    background: #FAF8F4;
    width: 155px;
    height: 155px;
    border-radius: 10px;
    color: var(--clr1);
    position: relative;
}

.idx-box-howto .idx-list-howto li a:before {
    content: "";
    position: absolute;
    right: -6px;
    bottom: -6px;
    background: url(../images/idx-arr-howto.svg) no-repeat center;
    background-size: contain;
    width: 25px;
    height: 25px;
}

.idx-box-howto .idx-list-howto li a .ttl {
    font-weight: bold;
    line-height: 1.3em;
    letter-spacing: 0.1em;
}

.idx-box-howto .idx-list-howto li a .ico {
    margin-bottom: 18px;
    position: relative;
    top: 1px;
}

.idx-box-howto02 {
    background: url(../images/idx-bg-howto02.png) no-repeat center;
    background-size: 100% 100%;
    padding-bottom: 40px;
    position: relative;
}

.idx-box-howto02:before {
    content: "";
    position: absolute;
    left: 47.6%;
    transform: translate(-50%);
    bottom: -71px;
    background: url(../images/idx-howto-people.png) no-repeat center;
    background-size: contain;
    width: 1530px;
    height: 360px;
}

.idx-box-howto02 h3 {
    font-size: 26px;
    color: #E88C3E;
    font-weight: bold;
    position: relative;
    top: -20px;
    margin-bottom: 10px;
}

.idx-box-howto02 .idx-list-howto02 {
       display: flex;
    flex-wrap: wrap;
    padding: 0 55px 0 55px;
}

.idx-box-howto02 .idx-list-howto02 li {
    position: relative;
    display: flex;
    font-size: 18px;
    font-weight: 600;
    color: #E88C3E;
    align-items: center;
    width: 25%;
    flex-shrink: 0;
    letter-spacing: 0.05em;
    margin-bottom: 8px;
	white-space:nowrap;
}

/* .idx-box-howto02 .idx-list-howto02 li:nth-child(2),
.idx-box-howto02 .idx-list-howto02 li:nth-child(6),
.idx-box-howto02 .idx-list-howto02 li:nth-child(10) {
    max-width: 155px;
} */

/* .idx-box-howto02 .idx-list-howto02 li:nth-child(3),
.idx-box-howto02 .idx-list-howto02 li:nth-child(7),
.idx-box-howto02 .idx-list-howto02 li:nth-child(11) {
    max-width: 175px;
    margin-right: 22px;
} */

.idx-box-howto02 .idx-list-howto02 li:before {
    content: "";
    position: relative;
    left: 0;
    top: 0;
    background: url(../images/idx-check-howto.svg) no-repeat center;
    background-size: contain;
    width: 15px;
    height: 15px;
    margin-right: 15px;
	flex-shrink:0
}

.idx-ttl-en {
    font-size: 18px;
    color: var(--main-color);
    font-weight: 600;
    font-family: var(--f-jose);
    position: relative;
    padding-left: 23px;
    line-height: 1.5em;
    margin-bottom: 0;
    letter-spacing: 0.05em;
}

.idx-ttl-en:before {
    content: "";
    position: absolute;
    left: 0;
    top: 5px;
    width: 13px;
    height: 13px;
    border-radius: 50%;
    background: #E88C3E;
}

.idx-ttl01 {
    font-size: 21px;
    font-weight: 600;
    line-height: 1.8em;
    letter-spacing: 0;
    margin-bottom: 21px;
}

.index02 {
    padding: 96px 0 100px;
    position: relative;
    z-index: 1;
}

.index02:before {
    content: "";
    position: absolute;
    left: 110px;
    right: 0;
    top: -47px;
    margin: 0 auto;
    background: url(../images/idx-bg-medical.png) no-repeat center;
    background-size: contain;
    width: 1331px;
    height: 766px;
    z-index: -1;
}

.index02 .inner_big {
    padding: 0 110px;
}

.index02 .idx-list-medical {
    display: flex;
    margin-top: 60px;
}

.index02 .idx-list-medical li {
    width: 25%;
    border-radius: 20px;
    position: relative;
    max-width: 248px;
    margin-right: 30px;
}

.index02 .idx-list-medical li:not(:first-child) {
    top: -34px;
}

.index02 .idx-list-medical li:last-child {
    margin-right: 0;
    top: -104px;
}

.index02 .idx-list-medical li:nth-child(3) {
    top: -69px;
}

.index02 .idx-list-medical li img {
    border-radius: 20px;
}

.index02 .idx-list-medical li .box-ttl {
    position: absolute;
    bottom: 0;
    right: 0;
    background: #fff;
    line-height: 1.2em;
    display: flex;
    align-items: flex-end;
    justify-content: center;
    padding: 14px 11px 14px 20px;
    border-top-left-radius: 20px;
}

.index02 .idx-list-medical li .box-ttl .ttl {
    color: var(--clr1);
    font-weight: 600;
    letter-spacing: 0.05em;
    margin-right: 10px;
}

.index03 .idx-box-area {
    background: #F8B600;
    position: relative;
    border-top-right-radius: 50px;
    border-bottom-right-radius: 50px;
    width: calc(100% - 50px);
    padding: 99px 100px 70px;
    z-index: 1;
}

.index03 .idx-box-area:before {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    margin: auto 0;
    width: calc(100% - 18px);
    height: calc(100% - 38px);
    background: url(../images/idx-bg-area.png) no-repeat right;
    background-size: cover;
    z-index: -1;
}

.index03 .idx-box-area .idx-fx-area {
    display: flex;
    padding-bottom: 50px;
    margin-bottom: 50px;
    position: relative;
    min-width: 1020px;
}

.index03 .idx-box-area .idx-fx-area:after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    margin: 0 auto;
    background: url(../images/idx-area-hr.svg) no-repeat center;
    background-size: cover;
    width: 100%;
    height: 2px;
}

.index03 .idx-box-area .idx-fx-area .box-img {
    flex-shrink: 0;
    margin-left: 55px;
    margin-top: -160px;
    width: 503px;
    border-radius: 10px;
    position: relative;
    overflow: hidden;
}

.index03 .idx-box-area .idx-fx-area .box-img:after {
    content: "";
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translateY(-50%) translateX(-50%);
    width: 106%;
    height: 106%;
    background: url(../images/idx-bg-map.svg) no-repeat center;
    background-size: 100% 100%;
    display: none;
}

.index03 .idx-box-area .idx-fx-area .box-img iframe {
    border-radius: 10px;
}

.index03 .idx-box-area .idx-fx-area .box-cnt {
    position: relative;
}

.index03 .idx-box-area .idx-fx-area .box-cnt:before {
    content: "";
    position: absolute;
    right: 34px;
    top: -192px;
    background: url(../images/idx-area-ico01.png) no-repeat center;
    background-size: contain;
    width: 211px;
    height: 195px;
}

.index03 .idx-box-area .idx-fx-area .box-cnt .idx-ttl-en,
.index03 .idx-box-area .idx-fx-area .box-cnt h2,
.index03 .idx-box-area .idx-fx-area .box-cnt .txt {
    color: #fff;
}

.index03 .idx-box-area .idx-fx-area .box-cnt .idx-ttl-en:before {
    background: #fff;
}

.index03 .idx-box-area .idx-fx-area .box-cnt h2 {
    letter-spacing: 0.05em;
}

.index03 .idx-box-area .idx-fx-area .box-cnt .txt {
    line-height: 2em;
    letter-spacing: 0.022em;
}

.index03 .idx-box-area .idx-fx-area .box-cnt .idx-list-area {
    background: #ef8c00;
    border-radius: 10px;
    display: flex;
    flex-wrap: wrap;
    margin-top: 24px;
    margin-right: 11px;
    padding: 20px 50px;
    max-width: 460px;
}

.index03 .idx-box-area .idx-fx-area .box-cnt .idx-list-area li {
    position: relative;
    display: flex;
    color: #fff;
    width: 33.3333333333%;
    font-size: 18px;
    font-weight: 500;
    margin-right: 20px;
    letter-spacing: 0;
    margin-bottom: 3px;
}

.index03 .idx-box-area .idx-fx-area .box-cnt .idx-list-area li:last-child {
    margin-right: 0;
    margin-left: 6px;
    display: flex;
    justify-content: space-between;
    flex: 1;
}

.index03 .idx-box-area .idx-fx-area .box-cnt .idx-list-area li:last-child span {
    flex: 1;
}

.index03 .idx-box-area .idx-fx-area .box-cnt .idx-list-area li:nth-child(2),
.index03 .idx-box-area .idx-fx-area .box-cnt .idx-list-area li:nth-child(4) {
    margin-right: 34px;
    max-width: 100px;
}

.index03 .idx-box-area .idx-fx-area .box-cnt .idx-list-area li:nth-child(3) {
    margin-right: 0;
    max-width: fit-content;
}

.index03 .idx-box-area .idx-fx-area .box-cnt .idx-list-area li:before {
    content: "";
    position: relative;
    left: 0;
    top: 7px;
    background: url(../images/idx-check-area.svg) no-repeat center;
    background-size: contain;
    width: 15px;
    height: 15px;
    flex-shrink: 0;
    filter: brightness(0) invert(1);
    margin-right: 17px;
}

.index03 .idx-box-area .idx-list-area02 {
    display: flex;
}

.index03 .idx-box-area .idx-list-area02 li {
    width: 25%;
    background: #fff;
    border-radius: 20px;
    max-width: 238px;
    margin-right: 26px;
}

.index03 .idx-box-area .idx-list-area02 li:last-child {
    margin-right: 0;
}

.index03 .idx-box-area .idx-list-area02 li:nth-child(2) a {
    padding-right: 10px;
    padding-left: 15px;
}

.index03 .idx-box-area .idx-list-area02 li:nth-child(2) a .ico {
    margin-right: 25px;
}

.index03 .idx-box-area .idx-list-area02 li:nth-child(3) a {
    padding-right: 20px;
    padding-left: 20px;
}

.index03 .idx-box-area .idx-list-area02 li:nth-child(3) a .ico {
    margin-right: 20px;
}

.index03 .idx-box-area .idx-list-area02 li:nth-child(3) a .ttl {
    letter-spacing: 0;
}

.index03 .idx-box-area .idx-list-area02 li:last-child a {
    padding-right: 20px;
    padding-left: 20px;
}

.index03 .idx-box-area .idx-list-area02 li:last-child a .ico {
    margin-right: 20px;
}

.index03 .idx-box-area .idx-list-area02 li:last-child a .ttl {
    letter-spacing: 0;
}

.index03 .idx-box-area .idx-list-area02 li a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    min-height: 100px;
    text-decoration: none;
    padding: 0 19px 0 30px;
}

.index03 .idx-box-area .idx-list-area02 li a .ico {
    margin-right: 16px;
}

.index03 .idx-box-area .idx-list-area02 li a .ttl {
    color: var(--clr1);
    font-weight: bold;
    margin-right: 17px;
    letter-spacing: 0.05em;
    line-height: 1.3em;
}

.index04 {
    background: #FAF8F4;
    padding-top: 429px;
    margin-top: -360px;
    position: relative;
    padding-bottom: 84px;
}

.index04:before {
    content: "";
    position: absolute;
    left: 80px;
    right: 0;
    top: 300px;
    margin: 0 auto;
    background: url(../images/idx-bg-all-about.png) no-repeat center;
    background-size: 100% 100%;
    width: 1461px;
    height: 2882px;
}

.index04 .idx-ttl-en,
.index04 h2 {
    letter-spacing: 0.03em;
    text-align: center;
}

.index04 .idx-ttl-en {
    padding-left: 0;
    padding-top: 25px;
}

.index04 .idx-ttl-en:before {
    top: 0;
    right: 0;
    margin: 0 auto;
}

.index04 h2 {
    margin-bottom: 60px;
}

.index04 .idx-fx-about {
    display: flex;
    padding-left: 100px;
    margin-bottom: 69px;
}

.index04 .idx-fx-about:last-child {
    margin-bottom: 0;
}

.index04 .idx-fx-about .box-cnt {
    background: url(../images/idx-bg-about01.png) no-repeat center;
    background-size: 100% 100%;
    padding: 50px 83px 57px 50px;
    margin-right: -127px;
    position: relative;
    z-index: 1;
    height: fit-content;
}

.index04 .idx-fx-about .box-cnt h3 {
    font-size: 26px;
    font-weight: bold;
    letter-spacing: 0.1em;
    color: var(--main-color);
    position: relative;
    padding-bottom: 27px;
    margin-bottom: 21px;
}

.index04 .idx-fx-about .box-cnt h3:before {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    margin: 0 auto;
    width: 100%;
    height: 2px;
    background: url(../images/idx-ico-h3.svg) no-repeat center;
    background-size: cover;
}

.index04 .idx-fx-about .box-cnt .txt {
    line-height: 2em;
    letter-spacing: -0.68px;
    margin-bottom: 22px;
}

.index04 .idx-fx-about .box-cnt .stt {
    font-family: var(--f-mont);
    font-size: 40px;
    font-weight: 800;
    display: flex;
    align-items: center;
    justify-content: center;
    letter-spacing: 0.05em;
    background: url(../images/idx-about-stt01.svg) no-repeat center;
    background-size: 100% 100%;
    width: 127px;
    height: 100px;
    position: absolute;
    right: 22px;
    bottom: -38px;
    color: #fff;
    padding-left: 13px;
    padding-bottom: 4px;
}

.index04 .idx-fx-about .box-img {
    flex-shrink: 0;
    position: relative;
    margin-top: 70px;
    height: fit-content;
}

.index04 .idx-fx-about .box-img .img img {
    border-top-left-radius: 20px;
    border-bottom-left-radius: 20px;
}

.index04 .idx-fx-about .box-img .idx-list-about {
    display: flex;
    position: absolute;
    right: 30px;
    bottom: 20px;
}

.index04 .idx-fx-about .box-img .idx-list-about li {
    width: 140px;
    height: 140px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    background: #fff;
    border-radius: 50%;
    text-align: center;
    margin-right: 20px;
    padding-bottom: 8px;
}

.index04 .idx-fx-about .box-img .idx-list-about li:last-child {
    margin-right: 0;
}

.index04 .idx-fx-about .box-img .idx-list-about li .ico {
    margin-bottom: 6px;
}

.index04 .idx-fx-about .box-img .idx-list-about li .ttl {
    color: var(--main-color);
    font-weight: bold;
    font-size: 18px;
    letter-spacing: 0;
    line-height: 1.3em;
}

.index04 .idx-fx-about.idx-fx-about02 {
    padding-left: 0;
    padding-right: 100px;
    margin-bottom: 0;
}

.index04 .idx-fx-about.idx-fx-about02 .box-img {
    margin-top: 0;
}

.index04 .idx-fx-about.idx-fx-about02 .box-img img {
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
    border-top-right-radius: 20px;
    border-bottom-right-radius: 20px;
}

.index04 .idx-fx-about.idx-fx-about02 .box-cnt {
    margin-right: 0;
    margin-left: -127px;
    margin-top: 70px;
    background: url(../images/idx-bg-about02.png) no-repeat center;
    background-size: 100% 100%;
    padding: 50px 50px 57px 84px;
}

.index04 .idx-fx-about.idx-fx-about02 .box-cnt .stt {
    bottom: initial;
    top: -25px;
    right: -35px;
    background: url(../images/idx-about-stt02.svg) no-repeat center;
    background-size: 100% 100%;
    width: 126px;
    height: 104px;
    padding-left: 5px;
    padding-bottom: 7px;
}

.index04 .idx-fx-about.idx-fx-about02 .box-cnt .idx-btn a {
    justify-content: flex-start;
    padding-left: 20px;
}

.index04 .idx-fx-about.idx-fx-about03 {
    padding-left: 50px;
    padding-right: 80px;
    margin-bottom: 0;
}

.index04 .idx-fx-about.idx-fx-about03 .box-about {
    width: 48.3%;
}

.index04 .idx-fx-about.idx-fx-about03 .box-about:first-child {
    margin-right: 1.7%;
}

.index04 .idx-fx-about.idx-fx-about03 .box-about:last-child {
    margin-top: 70px;
}

.index04 .idx-fx-about.idx-fx-about03 .box-about:last-child .box-cnt .stt {
    background: url(../images/idx-about-stt04.svg) no-repeat center;
    background-size: 100% 100%;
    width: 118px;
    height: 113px;
    right: -42px;
    bottom: -39px;
    padding-top: 13px;
    padding-left: 0;
}

.index04 .idx-fx-about.idx-fx-about03 .box-about .box-img {
    margin-left: 50px;
    margin-top: 0;
}

.index04 .idx-fx-about.idx-fx-about03 .box-about .box-img .img img {
    border-radius: 20px;
}

.index04 .idx-fx-about.idx-fx-about03 .box-about .box-cnt {
    margin-right: 0;
    background: url(../images/idx-bg-about03.png) no-repeat center;
    background-size: 100% 100%;
    max-width: 505px;
    margin-top: -106px;
    padding: 76px 43px 52px 50px;
}

.index04 .idx-fx-about.idx-fx-about03 .box-about .box-cnt .stt {
    background: url(../images/idx-about-stt03.svg) no-repeat center;
    background-size: 100% 100%;
    width: 118px;
    height: 113px;
    right: 37px;
    bottom: -43px;
    padding-top: 13px;
    padding-left: 0;
}

.index04 .idx-fx-about.idx-fx-about04 .box-cnt {
    margin-right: -210px;
    padding: 48px 83px 87px 50px;
}

.index04 .idx-fx-about.idx-fx-about04 .box-cnt .stt {
    background: url(../images/idx-about-stt05.svg) no-repeat center;
    background-size: 100% 100%;
    width: 140px;
    height: 120px;
    right: 112px;
    bottom: -52px;
    padding-left: 2px;
    padding-bottom: 0px;
    padding-top: 10px;
}

.index04 .idx-fx-about.idx-fx-about04 .box-cnt .idx-list-link-about {
    display: flex;
    flex-wrap: wrap;
}

.index04 .idx-fx-about.idx-fx-about04 .box-cnt .idx-list-link-about li {
    width: 50%;
    margin-bottom: 10px;
}

.index04 .idx-fx-about.idx-fx-about04 .box-cnt .idx-list-link-about li:nth-child(2n) a {
    padding-left: 24px;
    padding-right: 18px;
}

.index04 .idx-fx-about.idx-fx-about04 .box-cnt .idx-list-link-about li a {
    display: flex;
    align-items: center;
    justify-content: center;
    background: #FAF8F4;
    color: var(--clr1);
    font-weight: bold;
    min-height: 50px;
    max-width: 201px;
    border-radius: 10px;
    text-decoration: none;
    padding: 0 20px;
}

.index04 .idx-fx-about.idx-fx-about04 .box-cnt .idx-list-link-about li a .ico {
    margin-right: 10px;
}

.index04 .idx-fx-about.idx-fx-about04 .box-cnt .idx-list-link-about li a .ttl {
    flex: 1;
}

.index04 .idx-fx-about.idx-fx-about04 .box-cnt .idx-list-link-about li a .ico-arr {
    line-height: 0;
}

.index05 {
    background: #FAF8F4 url(../images/idx-bg-community.png) no-repeat top center;
    background-size: cover;
    position: relative;
    padding: 83px 0 70px;
}

.index05:before {
    content: "";
    position: absolute;
    right: 0;
    bottom: 0;
    background: url(../images/idx-ico-community.png) no-repeat right bottom;
    background-size: contain;
    width: 482px;
    height: 160px;
    z-index: 2;
}

.index05 .index05-frame {
    border-radius: 20px;
    background: #fff;
    border: 2px solid #F8B600;
    padding: 50px 67px 17px;
    max-width: 1080px;
    margin: 0 auto;
    position: relative;
    z-index: 1;
}

.index05 .index05-frame .index05-fx-frame {
    display: flex;
}

.index05 .index05-frame .index05-fx-frame .box-left {
    padding-top: 103px;
}

.index05 .index05-frame .index05-fx-frame .box-left .box-ttl {
    position: absolute;
    left: -158px;
    top: -97px;
    background: url(../images/idx-box-ttl-community.svg) no-repeat center;
    background-size: 100% 100%;
    width: 535px;
    height: 211px;
    padding: 76px 50px 75px 106px;
}

.index05 .index05-frame .index05-fx-frame .box-left .box-ttl:after {
    content: "";
    position: absolute;
    right: -130px;
    bottom: -17px;
    background: url(../images/idx-people-community.svg) no-repeat center;
    background-size: contain;
    width: 222px;
    height: 236px;
}

.index05 .index05-frame .index05-fx-frame .box-left .box-ttl h2,
.index05 .index05-frame .index05-fx-frame .box-left .box-ttl .idx-ttl-en {
    color: #fff;
}

.index05 .index05-frame .index05-fx-frame .box-left .box-ttl h2 {
    font-size: 34px;
    line-height: 1.3em;
}

.index05 .index05-frame .index05-fx-frame .box-left .box-ttl .idx-ttl-en:before {
    background: #fff;
}

.index05 .index05-frame .index05-fx-frame .box-left h3 {
    font-size: 26px;
    color: #E88C3E;
    font-weight: bold;
    letter-spacing: 0.03em;
    margin-bottom: 15px;
}

.index05 .index05-frame .index05-fx-frame .box-left .txt {
    margin-bottom: 22px;
    line-height: 2em;
    font-weight: 500;
    letter-spacing: -0.5px;
}

.index05 .index05-frame .index05-fx-frame .box-left .idx-btn {
    text-align: right;
}

.index05 .index05-frame .index05-fx-frame .box-left .idx-btn a {
    margin-left: auto;
    margin-right: 8px;
    background: #E88C3E;
}

.index05 .index05-frame .index05-fx-frame .box-left .idx-btn a:before {
    background: url(../images/idx-ico-btn03.svg) no-repeat center;
}

.index05 .index05-frame .index05-fx-frame .box-right {
    min-width: 553px;
    margin-left: 40px;
}

.index05 .index05-frame .index05-fx-frame .box-right .idx-list-community {
    display: flex;
    border-radius: 15px;
}

.index05 .index05-frame .index05-fx-frame .box-right .idx-list-community li {
    text-align: center;
    width: 25%;
    min-width: 25%;
    height: fit-content;
    background: #FAF8F4;
}

.index05 .index05-frame .index05-fx-frame .box-right .idx-list-community li:first-child {
    border-top-left-radius: 15px;
    border-bottom-left-radius: 15px;
}

.index05 .index05-frame .index05-fx-frame .box-right .idx-list-community li:last-child {
    border-top-right-radius: 15px;
    border-bottom-right-radius: 15px;
}

.index05 .index05-frame .index05-fx-frame .box-right .idx-list-community li:nth-child(3),
.index05 .index05-frame .index05-fx-frame .box-right .idx-list-community li:nth-child(4) {
    min-width: 22.5%;
}

.index05 .index05-frame .index05-fx-frame .box-right .idx-list-community li:nth-child(3) .ttl,
.index05 .index05-frame .index05-fx-frame .box-right .idx-list-community li:nth-child(4) .ttl {
    padding: 20px 10px;
}

.index05 .index05-frame .index05-fx-frame .box-right .idx-list-community li:nth-child(3) .ttl:before,
.index05 .index05-frame .index05-fx-frame .box-right .idx-list-community li:nth-child(4) .ttl:before {
    width: 103px;
}

.index05 .index05-frame .index05-fx-frame .box-right .idx-list-community li:nth-child(3) .ttl:first-child,
.index05 .index05-frame .index05-fx-frame .box-right .idx-list-community li:nth-child(4) .ttl:first-child {
    line-height: 1.4em;
}

.index05 .index05-frame .index05-fx-frame .box-right .idx-list-community li:nth-child(3) .ttl:not(:first-child),
.index05 .index05-frame .index05-fx-frame .box-right .idx-list-community li:nth-child(4) .ttl:not(:first-child) {
    padding: 16px 10px;
    min-height: 96px;
}

.index05 .index05-frame .index05-fx-frame .box-right .idx-list-community li:nth-child(3) {
    border-right: 3px solid #fff;
}

.index05 .index05-frame .index05-fx-frame .box-right .idx-list-community li:nth-child(3) {
    min-width: calc(25% + 32px);
    height: calc(100% + 70px);
    position: relative;
    top: -16px;
    border: 1px solid #5A9F4D;
    border-radius: 10px;
    background: #fff;
    box-shadow: 2px 2px 2px rgba(0, 0, 0, 15%);
}

.index05 .index05-frame .index05-fx-frame .box-right .idx-list-community li:nth-child(3) .ttl {
    padding: 20px 15px;
}

.index05 .index05-frame .index05-fx-frame .box-right .idx-list-community li:nth-child(3) .ttl:before {
    width: 151px;
}

.index05 .index05-frame .index05-fx-frame .box-right .idx-list-community li:nth-child(3) .ttl:first-child {
    background: #5A9F4D;
    border-top-left-radius: 8px;
    border-top-right-radius: 8px;
    color: #fff;
    font-size: 22px;
    font-weight: bold;
}

.index05 .index05-frame .index05-fx-frame .box-right .idx-list-community li:nth-child(3) .ttl:first-child:before {
    display: none;
}

.index05 .index05-frame .index05-fx-frame .box-right .idx-list-community li:nth-child(3) .ttl:not(:first-child) {
    padding: 15px 15px 20px;
    min-height: 99px;
}

.index05 .index05-frame .index05-fx-frame .box-right .idx-list-community li:nth-child(3) .ttl:last-child {
    padding-bottom: 30px;
}

.index05 .index05-frame .index05-fx-frame .box-right .idx-list-community li:nth-child(3) .ttl:last-child:before {
    display: none;
}

.index05 .index05-frame .index05-fx-frame .box-right .idx-list-community li:first-child .ttl:first-child {
    overflow: hidden;
    color: transparent;
}

.index05 .index05-frame .index05-fx-frame .box-right .idx-list-community li .ttl {
    font-size: 18px;
    color: var(--main-color);
    font-weight: 600;
    line-height: 1.5em;
    text-align: center;
    min-height: 50px;
    padding: 20px 15px 22px;
    margin-bottom: 0;
    position: relative;
    letter-spacing: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    min-height: 96px;
}

.index05 .index05-frame .index05-fx-frame .box-right .idx-list-community li .ttl span {
    font-size: 67%
}

.index05 .index05-frame .index05-fx-frame .box-right .idx-list-community li .ttl img {
    margin: 0 auto;
}

.index05 .index05-frame .index05-fx-frame .box-right .idx-list-community li .ttl:before {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    margin: 0 auto;
    width: 115px;
    height: 2px;
    background: url(../images/idx-hr-community.svg) no-repeat center;
    background-size: cover;
}

.index05 .index05-frame .index05-fx-frame .box-right .idx-list-community li .ttl:first-child {
    color: #909090;
    min-height: 92px;
}

.index05 .index05-frame .index05-fx-frame .box-right .idx-list-community li .ttl:last-child:before {
    display: none;
}

.index06 {
    background: url(../images/idx-bg-ct.png) no-repeat top center;
    background-size: cover;
    padding: 87px 0 220px;
}

.index06 h2 {
    letter-spacing: 0.08em;
    text-align: center;
    color: #fff;
    padding-bottom: 21px;
    margin-bottom: 21px;
    position: relative;
}

.index06 h2:before {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    margin: 0 auto;
    width: 284px;
    height: 2px;
    background: url(../images/idx-ico-h2.svg) no-repeat center;
    background-size: cover;
}

.index06 .txt {
    text-align: left;
    max-width: 582px;
    margin: 0 auto;
    letter-spacing: -1px;
    color: #fff;
    line-height: 2em;
    font-weight: 500;
}

.idx-list-ct {
    display: flex;
    justify-content: center;
    margin-top: 42px;
}

.idx-list-ct li {
    margin-right: 24px;
}

.idx-list-ct li:last-child {
    margin-right: 0;
}

.idx-list-ct li:nth-child(2) a .ico {
    margin-right: 7px;
}

.idx-list-ct li:nth-child(2) a .ttl {
    font-size: 26px;
    letter-spacing: -0.5px;
    line-height: 0.9em;
    padding-bottom: 10px;
}

.idx-list-ct li:last-child a .ico {
    margin-right: 10px;
}

.idx-list-ct li:last-child a .ttl {
    letter-spacing: -0.5px;
    line-height: 1.2em;
    padding-bottom: 5px;
}

.idx-list-ct li:first-child a {
    padding-left: 50px;
}

.idx-list-ct li a {
    display: flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    color: var(--clr1);
    background: #fff;
    border-radius: 10px;
    min-width: 300px;
    min-height: 88px;
    padding: 0 20px 0 25px;
}

.idx-list-ct li a .ico {
    margin-right: 10px;
}

.idx-list-ct li a .ttl {
    line-height: 1.4em;
    font-weight: bold;
    font-size: 20px;
    letter-spacing: 0;
    margin-bottom: 0;
    flex: 1;
}

.idx-list-ct li a .ttl span {
    font-size: 14px;
}

.idx-btn a {
    text-decoration: none;
    color: #fff;
    border-radius: 20px;
    background: var(--main-color);
    display: flex;
    align-items: center;
    justify-content: flex-start;
    max-width: 240px;
    min-height: 53px;
    font-size: 16px;
    letter-spacing: 0.05em;
    position: relative;
    font-weight: 500;
    padding-right: 45px;
    padding-left: 20px;
}

.idx-btn a:before {
    content: "";
    position: absolute;
    right: 15px;
    top: 14px;
    background: url(../images/idx-ico-btn.svg) no-repeat center;
    background-size: contain;
    width: 25px;
    height: 25px;
}

.index07 {
    background: url(../images/idx-bg-greeting.png) no-repeat top center;
    background-size: cover;
    position: relative;
    padding: 90px 0;
    margin-top: -121px;
}

.index07:before {
    content: "";
    position: absolute;
    left: 93px;
    right: 0;
    top: 46px;
    margin: 0 auto;
    background: url(../images/idx-bg-greeting02.png) no-repeat center;
    background-size: contain;
    width: 1098px;
    height: 708px;
    z-index: 1;
}

.index07 .index07-fx {
    display: flex;
}

.index07 .index07-fx .box-left {
    position: relative;
    margin-left: -188px;
    margin-right: 70px;
    margin-top: 35px;
    height: fit-content;
}

.index07 .index07-fx .box-left .img {
    width: 576px;
    height: 516px;
    --mask: url(../images/idx-bg-img-greeting01.svg);
    mask-image: var(--mask);
    mask-repeat: no-repeat;
    mask-size: 100% auto;
    mask-position: center;
    margin-bottom: 0;
    position: relative;
}

.index07 .index07-fx .box-left .img .sub-ttl {
    position: absolute;
    right: -18px;
    top: 104px;
}

.index07 .index07-fx .box-left .ttl-greeting {
    position: absolute;
    right: -18px;
    top: 104px;
}

.index07 .index07-fx .box-left .box-ttl {
    width: 209px;
    height: 200px;
    background: url(../images/idx-bg-ttl-greeting.svg) no-repeat center;
    background-size: 100% 100%;
    color: #fff;
    text-align: center;
    position: absolute;
    right: -25px;
    bottom: -49px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding-top: 24px;
    padding-left: 10px;
}

.index07 .index07-fx .box-left .box-ttl .sub-ttl {
    display: block;
    font-size: 12px;
    letter-spacing: 0;
    margin-bottom: 6px;
}

.index07 .index07-fx .box-left .box-ttl .ttl {
    line-height: 1.2em;
    font-size: 20px;
    font-weight: bold;
}

.index07 .index07-fx .box-left .box-ttl .ttl span {
    display: block;
    font-size: 14px;
    font-weight: 500;
}

.index07 .index07-fx .box-left .box-ttl .ttl label {
    cursor: default;
    display: block;
    font-size: 10px;
    font-weight: 500;
    font-family: var(--f-jose);
}

.index07 .index07-fx .box-center {
    max-width: 515px;
    flex-shrink: 0;
    position: relative;
    z-index: 1;
}

.index07 .index07-fx .box-center h2 {
    margin-bottom: 26px;
    letter-spacing: 0;
    white-space: nowrap;
    font-size: 38px;
}

.index07 .index07-fx .box-center .txt {
    line-height: 2.5em;
    font-weight: 500;
}

.index07 .index07-fx .box-center .idx-list-btn {
    display: flex;
    margin-top: 29px;
}

.index07 .index07-fx .box-center .idx-list-btn li {
    width: 50%;
    margin-right: 10px;
}

.index07 .index07-fx .box-center .idx-list-btn li:last-child {
    margin-right: 0;
}

.index07 .index07-fx .box-center .idx-list-btn li:last-child a {
    letter-spacing: -0.5px;
}

.index07 .index07-fx .box-right {
    margin-top: -114px;
    margin-left: -6px;
}

.index07 .index07-fx .box-right .img02 {
    width: 411px;
    height: 351px;
    --mask: url(../images/idx-bg-img-greeting02.svg);
    mask-image: var(--mask);
    mask-repeat: no-repeat;
    mask-size: 100% auto;
    mask-position: center;
    margin-bottom: 64px;
}

.index07 .index07-fx .box-right .img03 {
    margin-left: 53px;
    width: 221px;
    height: 251px;
    --mask: url(../images/idx-bg-img-greeting03.svg);
    mask-image: var(--mask);
    mask-repeat: no-repeat;
    mask-size: 100% auto;
    mask-position: center;
    margin-bottom: 0;
}

.index08 {
    padding: 100px 0;
}

.index08 .box {
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    z-index: 1;
    width: 238px;
    height: 229px;
    transition: all 0.3s;
    color: #fff;
    text-align: center;
}

.index08 .box::before {
    content: "";
    display: block;
    position: absolute;
    transition: all 0.3s;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background-image: url(../images/doctor.jpg);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    background-color: var(--main-color);
    z-index: -1;
    --mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 238 229' %3E%3Cpath d='M7.790,92.655 C0.489,114.686 -2.999,140.450 8.422,161.34 C13.375,169.960 20.650,177.390 28.386,184.63 C76.535,225.594 153.75,247.999 207.372,207.209 C237.463,184.605 240.996,137.660 235.151,102.626 C230.113,72.430 214.626,43.769 190.924,24.336 C157.942,-2.704 121.593,-6.1 84.325,11.146 C49.608,27.120 21.242,56.863 7.790,92.655 Z'/%3E%3C/svg%3E");
    mask-image: var(--mask);
    -webkit-mask-image: var(--mask);
    mask-repeat: no-repeat;
    -webkit-mask-repeat: no-repeat;
    mask-size: 100% auto;
    -webkit-mask-size: 100% auto;
    mask-position: bottom center;
    -webkit-mask-position: bottom center;
}

.index08 .box:hover::before {
    opacity: 1;
}

.index09 {
    padding: 100px 0;
    background-color: #333;
}

.index09 .idx_row {
    display: flex;
    flex-wrap: wrap;
}

.index09 .idx_row .box {
    width: 100%;
    margin-bottom: 20px;
    background-color: var(--main-color);
    height: 100px;
    display: flex;
    align-items: center;
    justify-content: center;
}

@media only screen and (min-width: 769px) {
    .index09 .idx_row>.box {
        width: calc((100% - 30px) / 2);
        margin-right: 30px;
        margin-bottom: 30px;
    }
    .index09 .idx_row>.box:nth-child(2n+2),
    .index09 .idx_row>.box:last-child {
        margin-right: 0px;
    }
    .idx-box-howto .idx-list-howto li a:hover,
    .index02 .idx-list-medical li:hover,
    .index03 .idx-box-area .idx-list-area02 li:hover {
        transform: translateY(-5px);
        transition: 0.3s all;
    }
}

.index09 .idx_row.st1>.box {
    width: calc((100% - 20px) / 3);
    margin-right: 10px;
    margin-bottom: 10px;
}

.index09 .idx_row.st1>.box:nth-child(3n+3),
.index09 .idx_row.st1>.box:last-child {
    margin-right: 0px;
}

@media only screen and (min-width: 769px) {
    .index09 .idx_row.st2>.box {
        width: calc((100% - 60px) / 4);
        margin-right: 20px;
        margin-bottom: 20px;
    }
    .index09 .idx_row.st2>.box:nth-child(4n+4),
    .index09 .idx_row.st2>.box:last-child {
        margin-right: 0px;
    }
}

@media only screen and (min-width: 1280px) {
    .index09 .idx_row.st3>.box {
        width: calc((100% - 80px) / 5);
        margin-right: 20px;
        margin-bottom: 20px;
    }
    .index09 .idx_row.st3>.box:nth-child(5n+5),
    .index09 .idx_row.st3>.box:last-child {
        margin-right: 0px;
    }
}

.idx_map {
    height: 450px;
}

.idx_map iframe {
    height: 100%;
}

@media only screen and (min-width: 769px) and (max-width: 1560px) {
    .index03 .idx-box-area {
        padding: 99px 90px 70px;
    }
    .index05:before {
        content: "";
        position: absolute;
        right: -30px;
        bottom: 0;
        background: url(../images/idx-ico-community.png) no-repeat right bottom;
        background-size: contain;
        width: 442px;
        height: 120px;
        z-index: 2;
    }
}

@media only screen and (min-width: 769px) and (max-width: 1280px) {
    .inner_big,
    .inner,
    .inner_sm {
        padding-left: 0;
        padding-right: 0;
    }
    .index02 .inner_big {
        padding: 0 100px;
    }
    footer .f-box02 .f-box02-fx {
        padding: 0 10px;
    }
    footer .f-box02 .f-box02-fx:before {
        left: -26px;
    }
    .index07 {
        margin-top: -61px;
    }
    .index06 {
        padding-bottom: 160px;
    }
    .index04:before {
        left: -52px;
    }
    .index02:before {
        left: 29px;
    }
    .idx-box-howto02 .idx-list-howto02 {
               padding: 0 4.109vw 0 2.516vw;
        max-width: 960px;
        margin: 0 auto;
    }
    .home_page h2 {
        font-size: calc(var(--ttl_size) + 1.094vw);
    }
    .index03 .idx-box-area .idx-fx-area .box-cnt .idx-list-area {
        padding: 1.563vw 3.906vw;
    }
    .index03 .idx-box-area .idx-fx-area .box-cnt .idx-list-area li {
        font-size: 1.406vw;
        margin-right: 1.563vw;
    }
    .index03 .idx-box-area .idx-fx-area .box-img {
        margin-left: 4.297vw;
    }
    .index03 .idx-box-area {
        width: calc(100% - 3.906vw);
        padding: 99px 7.813vw 70px;
    }
    .index03 .idx-box-area .idx-fx-area .box-img img {
        width: 39.297vw;
        height: auto
    }
    .index03 .idx-box-area .idx-fx-area .box-cnt .idx-list-area li:before {
        margin-right: 1.328vw;
    }
    .index03 .idx-box-area .idx-list-area02 li a {
        padding: 0 1.484vw 0 2.344vw;
    }
    .index03 .idx-box-area .idx-fx-area .box-cnt .idx-list-area li:nth-child(2),
    .index03 .idx-box-area .idx-fx-area .box-cnt .idx-list-area li:nth-child(4) {
        margin-right: 2.656vw;
    }
    .index03 .idx-box-area .idx-list-area02 li a .ttl {
        font-size: 1.25vw
    }
    .index03 .idx-box-area .idx-list-area02 li a .ico {
        margin-right: 1.25vw;
    }
    .index03 .idx-box-area .idx-list-area02 li a .ico img {
        height: 4.297vw;
        width: auto;
    }
    .index05:before {
        right: -150px;
    }
}

@media only screen and (min-width: 769px) and (max-width: 1250px) {
    .home_page .key .key-fx-mvs:before {
        left: -4.063vw;
        bottom: -2.344vw;
        width: 34.688vw;
        height: 27.031vw;
    }
	.index07 .index07-fx .box-center h2{
		    font-size: 3vw;
	}
    .home_page .key .key-fx-mvs .box-cnt {
        padding-top: 3.125vw;
    }
    .home_page .key .key-fx-mvs .box-cnt .mvs-box-ttl .mvs-ttl {
        font-size: max(2.5vw, 22px);
    }
    .home_page .key .key-fx-mvs .box-cnt .mvs-box-ttl .mvs-sub-ttl {
        font-size: max(1.406vw, 14px);
    }
    .home_page .key .key-fx-mvs .box-img .img img {
        width: max(72.578vw, 580px);
        height: auto;
    }
    .home_page .key .key-fx-mvs .box-img .mvs-scroll {
        right: 2.969vw;
        bottom: 5.625vw;
        font-size: max(1.406vw, 12px);
    }
    .home_page .key .key-fx-mvs .box-img .mvs-scroll:after {
        top: calc(100% + 0.938vw);
        height: 8.594vw;
    }
    .index0 {
        padding: 17.813vw 0 5.391vw;
        margin-top: -6.563vw;
    }
    .index0:after {
        left: 0.859vw;
        top: 9.922vw;
        width: 93.594vw;
        height: 40.781vw;
    }
    .index0 .idx-fx-family {
        padding-left: 7.813vw;
    }
    .index0 .idx-fx-family .box-cnt {
        max-width: max(29.297vw, 300px);
    }
    .index0 .idx-fx-family .box-cnt .txt {
        font-size: max(1.25vw, 13px);
    }
    .index0 .idx-fx-family .box-img {
        top: -11.484vw;
        left: -0.859vw;
    }
    .index0 .idx-fx-family .box-img .img {
        width: 32.266vw;
        height: 34.844vw;
        margin-top: -5.625vw;
        margin-right: 0.938vw;
    }
    .index0 .idx-fx-family .box-img .box-fx-img .img02 {
        margin-bottom: 1.563vw;
        margin-top: 4.141vw;
        width: 26.25vw;
        height: 25.781vw;
    }
    .index0 .idx-fx-family .box-img .box-fx-img .img03 {
        width: 18.828vw;
        height: 21.172vw;
    }
    .idx-ttl-en {
        font-size: max(1.406vw, 14px);
        padding-left: 1.797vw;
    }
    .idx-ttl-en:before {
        width: max(1.016vw, 8px);
        height: max(1.016vw, 8px);
    }
    .home_page h2 {
        margin-bottom: 2.422vw;
        font-size: 3.438vw;
    }
    .idx-ttl01 {
        font-size: max(1.641vw, 17px);
        margin-bottom: 1.641vw;
    }
    .idx-box-howto {
        width: calc(100% - 3.906vw);
        margin-top: -15.469vw;
        padding: 5.625vw 7.734vw 5.469vw;
    }
    .idx-box-howto:before {
        width: calc(100% - 1.563vw);
        height: calc(100% - 3.125vw);
    }
    .idx-box-howto:after {
        left: -1.797vw;
        top: 5.625vw;
        width: 11.25vw;
        height: 9.766vw;
    }
    .idx-box-howto .idx-ttl-en {
        padding-top: 1.953vw;
        padding-left: 0;
    }
    .idx-box-howto .idx-ttl-en:before {
        top: 0;
        left: 0;
        right: 0;
        margin: 0 auto;
    }
    .idx-box-howto h2 {
        letter-spacing: 0.05em;
        margin-bottom: 4.688vw;
    }
    .idx-box-howto .idx-list-howto {
        margin-bottom: 4.922vw;
    }
    .idx-box-howto .idx-list-howto li {
        margin-right: 1.563vw;
    }
    .idx-box-howto .idx-list-howto li a {
        width: max(12.109vw, 90px);
        height: max(12.109vw, 90px);
    }
    .idx-box-howto .idx-list-howto li a:before {
        right: -0.469vw;
        bottom: -0.469vw;
        width: max(1.953vw, 16px);
        height: max(1.953vw, 16px);
    }
    .idx-box-howto .idx-list-howto li a .ttl {
        font-size: max(1.25vw, 11px);
    }
    .idx-box-howto .idx-list-howto li a .ico {
        margin-bottom: 1.406vw;
    }
    .idx-box-howto .idx-list-howto li a .ico img {
        height: max(4.688vw, 30px);
        width: auto;
    }
    .idx-box-howto .idx-box-howto02 {
        padding-bottom: 3.125vw;
    }
    .idx-box-howto .idx-box-howto02:before {
        bottom: -5.547vw;
        width: 114vw;
        height: 26.438vw;
    }
    .idx-box-howto h3 {
        font-size: max(2.031vw, 20px);
        top: -1.563vw;
        margin-bottom: 0.781vw;
    }
    .idx-box-howto .idx-list-howto02 {
        padding: 0 12.109vw 0 9.516vw;
    }
    .idx-box-howto .idx-list-howto02 li {
        font-size: max(1.206vw, 11px);
        margin-bottom: 0.625vw;
    }
/*     .idx-box-howto .idx-list-howto02 li:nth-child(2),
    .idx-box-howto .idx-list-howto02 li:nth-child(6),
    .idx-box-howto .idx-list-howto02 li:nth-child(10) {
        max-width: 12.109vw;
    }
    .idx-box-howto .idx-list-howto02 li:nth-child(3),
    .idx-box-howto .idx-list-howto02 li:nth-child(7),
    .idx-box-howto .idx-list-howto02 li:nth-child(11) {
        max-width: 13.672vw;
        margin-right: 1.719vw;
    } */
    .idx-box-howto .idx-list-howto02 li:before {
        width: max(1.094vw, 10px);
        height: max(1.094vw, 10px);
        margin-right: 1.172vw;
    }
    .index02 {
        padding: 7.5vw 0 7.813vw;
    }
    .index02:before {
        left: 2.266vw;
        right: 0;
        top: -3.672vw;
        width: 103.984vw;
        height: 59.844vw;
    }
    .index02 .inner_big {
        padding: 0 7.813vw;
    }
    .index02 .idx-list-medical {
        margin-top: 4.688vw;
    }
    .index02 .idx-list-medical li {
        margin-right: 2.344vw;
    }
    .index02 .idx-list-medical li:not(:first-child) {
        top: -2.656vw;
    }
    .index02 .idx-list-medical li:last-child {
        top: -8.125vw;
    }
    .index02 .idx-list-medical li:nth-child(3) {
        top: -5.391vw;
    }
    .index02 .idx-list-medical li .box-ttl {
        padding: 1.094vw 0.859vw 1.094vw 1.563vw;
    }
    .index02 .idx-list-medical li .box-ttl .ttl {
        font-size: max(1.25vw, 12px);
    }
    .index02 .idx-list-medical li .box-ttl .ico img {
        width: max(1.953vw, 16px);
        height: auto;
    }
    .index03 .idx-box-area {
        width: calc(100% - 3.906vw);
        padding: 7.734vw 5.813vw 5.469vw;
    }
    .index03 .idx-box-area:before {
        width: calc(100% - 1.563vw);
        height: calc(100% - 3.125vw);
    }
    .index03 .idx-box-area .idx-fx-area {
        padding-bottom: 3.906vw;
        margin-bottom: 3.906vw;
        min-width: auto;
    }
    .index03 .idx-box-area .idx-fx-area .box-img {
        margin-left: 4.297vw;
        margin-top: -12.5vw;
        width: 39.297vw;
        height: 39.297vw;
    }
    .index03 .idx-box-area .idx-fx-area .box-img img {
        width: max(39.297vw, 300px);
        height: auto;
    }
    .index03 .idx-box-area .idx-fx-area .box-cnt:before {
        right: 2.656vw;
        top: -15vw;
        width: 16.484vw;
        height: 15.234vw;
    }
    .index03 .idx-box-area .idx-fx-area .box-cnt h2 {
        letter-spacing: 0.05em;
    }
    .index03 .idx-box-area .idx-fx-area .box-cnt .txt {
        font-size: max(1.25vw, 14px);
    }
    .index03 .idx-box-area .idx-fx-area .box-cnt .idx-list-area {
        margin-top: 1.875vw;
        margin-right: 0.859vw;
        padding: 1.563vw 4.906vw;
        max-width: 500px;
        justify-content: space-between;
    }
    .index03 .idx-box-area .idx-fx-area .box-cnt .idx-list-area li {
        font-size: max(1.406vw, 12px);
        margin-right: 1.563vw;
        margin-bottom: 0.234vw;
        width: auto;
    }
    .index03 .idx-box-area .idx-fx-area .box-cnt .idx-list-area li:last-child {
        margin-left: 1.8513vw;
    }
    .index03 .idx-box-area .idx-fx-area .box-cnt .idx-list-area li:nth-child(2),
    .index03 .idx-box-area .idx-fx-area .box-cnt .idx-list-area li:nth-child(4) {
        margin-right: 2.656vw;
        max-width: 7.813vw;
    }
    .index03 .idx-box-area .idx-fx-area .box-cnt .idx-list-area li:before {
        top: 0.547vw;
        width: max(1.016vw, 10px);
        height: max(1.016vw, 10px);
        margin-right: 1.328vw;
    }
    .index03 .idx-box-area .idx-list-area02 li {
        margin-right: 2.031vw;
    }
    .index03 .idx-box-area .idx-list-area02 li:nth-child(2) a {
        padding-right: 0.781vw;
        padding-left: 1.172vw;
    }
    .index03 .idx-box-area .idx-list-area02 li:nth-child(2) a .ico {
        margin-right: 1.953vw;
    }
    .index03 .idx-box-area .idx-list-area02 li:nth-child(3) a {
        padding-right: 1.563vw;
        padding-left: 1.563vw;
    }
    .index03 .idx-box-area .idx-list-area02 li:nth-child(3) a .ico {
        margin-right: 1.563vw;
    }
    .index03 .idx-box-area .idx-list-area02 li:last-child a {
        padding-right: 1.563vw;
        padding-left: 1.563vw;
    }
    .index03 .idx-box-area .idx-list-area02 li:last-child a .ico {
        margin-right: 1.563vw;
    }
    .index03 .idx-box-area .idx-list-area02 li a {
        min-height: 7.813vw;
        padding: 0 1.484vw 0 2.344vw;
    }
    .index03 .idx-box-area .idx-list-area02 li a .ico {
        margin-right: 1.25vw;
    }
    .index03 .idx-box-area .idx-list-area02 li a .ico img {
        height: 4.297vw;
        width: auto;
    }
    .index03 .idx-box-area .idx-list-area02 li a .ttl {
        margin-right: 1.328vw;
        font-size: max(1.25vw, 11px);
    }
    .index03 .idx-box-area .idx-list-area02 li a .ico-arr img {
        width: max(1.953vw, 16px);
        height: auto;
    }
    .index04 {
        padding-top: 33.516vw;
        margin-top: -28.125vw;
        padding-bottom: 6.563vw;
    }
    .index04:before {
        left: 4.063vw;
        right: 0;
        top: 23.438vw;
        width: 114.141vw;
        height: 225.156vw;
    }
    .index04 .idx-ttl-en {
        padding-top: 1.953vw;
    }
    .index04 h2 {
        margin-bottom: 4.688vw;
    }
    .index04 .idx-fx-about {
        padding-left: 7.813vw;
        margin-bottom: 4.219vw;
    }
    .index04 .idx-fx-about:last-child {
        margin-bottom: 0;
    }
    .index04 .idx-fx-about .box-cnt {
        padding: 3.906vw 6.484vw 4.453vw 3.906vw;
        margin-right: -9.922vw;
    }
    .index04 .idx-fx-about .box-cnt h3 {
        font-size: max(2.031vw, 18px);
        padding-bottom: 2.109vw;
        margin-bottom: 1.641vw;
    }
    .index04 .idx-fx-about .box-cnt .txt {
        margin-bottom: 1.719vw;
        font-size: max(1.25vw, 13px);
    }
    .index04 .idx-fx-about .box-cnt .stt {
        font-size: max(3.125vw, 26px);
        width: 9.922vw;
        height: 7.813vw;
        right: 1.719vw;
        bottom: -2.969vw;
        padding-left: 1.016vw;
        padding-bottom: 0.313vw;
    }
    .index04 .idx-fx-about .box-img {
        margin-top: 5.469vw;
    }
    .index04 .idx-fx-about .box-img .img img {
        width: 65.469vw;
        height: max(34.063vw, 370px);
        object-fit: cover;
    }
    .index04 .idx-fx-about .box-img .idx-list-about {
        right: 2.344vw;
        bottom: 2.734vw;
    }
    .index04 .idx-fx-about .box-img .idx-list-about li {
        width: max(10.938vw, 100px);
        height: max(10.938vw, 100px);
        margin-right: 1.563vw;
        padding-bottom: 0.625vw;
    }
    .index04 .idx-fx-about .box-img .idx-list-about li:last-child {
        margin-right: 0;
    }
    .index04 .idx-fx-about .box-img .idx-list-about li .ico {
        margin-bottom: 0.469vw;
    }
    .index04 .idx-fx-about .box-img .idx-list-about li .ico img {
        height: max(2.344vw, 20px);
        width: auto;
    }
    .index04 .idx-fx-about .box-img .idx-list-about li .ttl {
        font-size: max(1.406vw, 13px);
    }
    .index04 .idx-fx-about.idx-fx-about02 {
        padding-right: 7.813vw;
    }
    .index04 .idx-fx-about.idx-fx-about02 .box-cnt {
        margin-left: -9.922vw;
        margin-top: 5.469vw;
        padding: 3.906vw 3.906vw 4.453vw 6.563vw;
    }
    .index04 .idx-fx-about.idx-fx-about02 .box-cnt .stt {
        top: -1.953vw;
        right: -2.734vw;
        width: 9.844vw;
        height: 8.125vw;
        padding-left: 0.391vw;
        padding-bottom: 0.547vw;
    }
    .index04 .idx-fx-about.idx-fx-about02 .box-cnt .idx-btn a {
        padding-left: 1.563vw;
    }
    .index04 .idx-fx-about.idx-fx-about03 {
        padding-left: 3.906vw;
        padding-right: 6.25vw;
    }
    .index04 .idx-fx-about.idx-fx-about03 .box-about:last-child {
        margin-top: 5.469vw;
    }
    .index04 .idx-fx-about.idx-fx-about03 .box-about:last-child .box-cnt .stt {
        width: 9.219vw;
        height: 8.828vw;
        right: -3.281vw;
        bottom: -3.047vw;
        padding-top: 1.016vw;
    }
    .index04 .idx-fx-about.idx-fx-about03 .box-about .box-img {
        margin-left: 3.906vw;
    }
    .index04 .idx-fx-about.idx-fx-about03 .box-about .box-img .img img {
        width: 39.453vw;
        height: auto;
    }
    .index04 .idx-fx-about.idx-fx-about03 .box-about .box-cnt {
        max-width: 39.453vw;
        margin-top: -8.281vw;
        padding: 5.938vw 3.359vw 4.063vw 3.906vw;
    }
    .index04 .idx-fx-about.idx-fx-about03 .box-about .box-cnt .stt {
        width: 9.219vw;
        height: 8.828vw;
        right: 2.891vw;
        bottom: -3.359vw;
        padding-top: 1.016vw;
    }
    .index04 .idx-fx-about.idx-fx-about04 .box-img .img img {
        height: max(34.063vw, 400px);
    }
    .index04 .idx-fx-about.idx-fx-about04 .box-cnt {
        margin-right: -16.406vw;
        padding: 3.75vw 6.484vw 7.891vw 3.906vw;
    }
    .index04 .idx-fx-about.idx-fx-about04 .box-cnt .stt {
        width: 10.938vw;
        height: 9.375vw;
        right: 8.75vw;
        bottom: -4.063vw;
        padding-left: 0.156vw;
        padding-top: 0.781vw;
    }
    .index04 .idx-fx-about.idx-fx-about04 .box-cnt .idx-list-link-about li {
        width: 47%;
        margin-bottom: 0.781vw;
        margin-right: 0.781vw;
        max-width: max(15.703vw, 150px);
    }
    .index04 .idx-fx-about.idx-fx-about04 .box-cnt .idx-list-link-about li:nth-child(2n) a {
        padding-left: 1.875vw;
        padding-right: 1.406vw;
    }
    .index04 .idx-fx-about.idx-fx-about04 .box-cnt .idx-list-link-about li a {
        min-height: max(3.906vw, 45px);
        max-width: max(15.703vw, 150px);
        padding: 0 1.563vw;
    }
    .index04 .idx-fx-about.idx-fx-about04 .box-cnt .idx-list-link-about li a .ico {
        margin-right: 0.781vw;
    }
    .index04 .idx-fx-about.idx-fx-about04 .box-cnt .idx-list-link-about li a .ttl {
        font-size: max(1.25vw, 12px);
    }
    .index04 .idx-fx-about.idx-fx-about04 .box-cnt .idx-list-link-about li a .ico-arr img {
        width: max(1.953vw, 14px);
        height: auto;
    }
    .index05 {
        padding: 6.484vw 0 5.469vw;
    }
    .index05:before {
        width: 37.656vw;
        height: 12.5vw;
        right: -240px;
    }
    .index05 .index05-frame {
        padding: 3.906vw 5.234vw 3.328vw;
        max-width: max(84.375vw, 700px);
    }
    .index05 .index05-frame .index05-fx-frame .box-left {
        padding-top: 8.047vw;
    }
    .index05 .index05-frame .index05-fx-frame .box-left .box-ttl {
        left: -12.344vw;
        top: -7.578vw;
        width: max(41.797vw, 400px);
        height: 16.484vw;
        padding: 5.938vw 3.906vw 5.859vw 8.281vw;
    }
    .index05 .index05-frame .index05-fx-frame .box-left .box-ttl:after {
        right: -10.156vw;
        bottom: -1.328vw;
        width: 17.344vw;
        height: 18.438vw;
    }
    .index05 .index05-frame .index05-fx-frame .box-left .box-ttl h2,
    .index05 .index05-frame .index05-fx-frame .box-left .box-ttl .idx-ttl-en {
        color: #fff;
    }
    .index05 .index05-frame .index05-fx-frame .box-left .box-ttl h2 {
        font-size: max(2.656vw, 26px);
    }
    .index05 .index05-frame .index05-fx-frame .box-left h3 {
        font-size: max(2.031vw, 20px);
        margin-bottom: 1.172vw;
    }
    .index05 .index05-frame .index05-fx-frame .box-left .txt {
        margin-bottom: 1.719vw;
        font-size: max(1.25vw, 13px);
    }
    .index05 .index05-frame .index05-fx-frame .box-left .idx-btn a {
        margin-right: 0.625vw;
    }
    .index05 .index05-frame .index05-fx-frame .box-right {
        min-width: 43.203vw;
        margin-left: 3.125vw;
    }
    .index05 .index05-frame .index05-fx-frame .box-right .idx-list-community {
        border-radius: 1.172vw;
    }
    .index05 .index05-frame .index05-fx-frame .box-right .idx-list-community li {
        text-align: center;
        width: 25%;
        min-width: 25%;
        height: fit-content;
        background: #FAF8F4;
    }
    .index05 .index05-frame .index05-fx-frame .box-right .idx-list-community li:nth-child(3),
    .index05 .index05-frame .index05-fx-frame .box-right .idx-list-community li:nth-child(4) {
        min-width: 22.5%;
    }
    .index05 .index05-frame .index05-fx-frame .box-right .idx-list-community li:nth-child(3) .ttl,
    .index05 .index05-frame .index05-fx-frame .box-right .idx-list-community li:nth-child(4) .ttl {
        padding: 1.563vw 0.781vw;
    }
    .index05 .index05-frame .index05-fx-frame .box-right .idx-list-community li:nth-child(3) .ttl:before,
    .index05 .index05-frame .index05-fx-frame .box-right .idx-list-community li:nth-child(4) .ttl:before {
        width: 8.047vw;
    }
    .index05 .index05-frame .index05-fx-frame .box-right .idx-list-community li:nth-child(3) .ttl:first-child,
    .index05 .index05-frame .index05-fx-frame .box-right .idx-list-community li:nth-child(4) .ttl:first-child {
        line-height: 1.4em;
    }
    .index05 .index05-frame .index05-fx-frame .box-right .idx-list-community li:nth-child(3) .ttl:not(:first-child),
    .index05 .index05-frame .index05-fx-frame .box-right .idx-list-community li:nth-child(4) .ttl:not(:first-child) {
        padding: 1.25vw 0.781vw;
        min-height: 7.5vw;
    }
    .index05 .index05-frame .index05-fx-frame .box-right .idx-list-community li:nth-child(3) {
        min-width: calc(25% + 2.5vw);
        height: calc(100% + 5.469vw);
        top: -1.25vw;
    }
    .index05 .index05-frame .index05-fx-frame .box-right .idx-list-community li:nth-child(3) .ttl {
        padding: 1.563vw 1.172vw;
    }
    .index05 .index05-frame .index05-fx-frame .box-right .idx-list-community li:nth-child(3) .ttl:before {
        width: 11.797vw;
    }
    .index05 .index05-frame .index05-fx-frame .box-right .idx-list-community li:nth-child(3) .ttl:first-child {
        font-size: max(1.719vw, 13px);
    }
    .index05 .index05-frame .index05-fx-frame .box-right .idx-list-community li:nth-child(3) .ttl:not(:first-child) {
        padding: 1.172vw 1.172vw 1.563vw;
        min-height: 7.734vw;
    }
    .index05 .index05-frame .index05-fx-frame .box-right .idx-list-community li:nth-child(3) .ttl:last-child {
        padding-bottom: 2.344vw;
    }
    .index05 .index05-frame .index05-fx-frame .box-right .idx-list-community li:first-child .ttl:first-child {
        text-indent: -1000px;
        overflow: hidden;
    }
    .index05 .index05-frame .index05-fx-frame .box-right .idx-list-community li .ttl {
        font-size: max(1.406vw, 11px);
        min-height: 7.5vw;
        padding: 1.563vw 0.641vw 1.719vw;
    }
    .index05 .index05-frame .index05-fx-frame .box-right .idx-list-community li .ttl:before {
        width: 8.984vw;
        height: 2px;
    }
    .index05 .index05-frame .index05-fx-frame .box-right .idx-list-community li .ttl:first-child {
        min-height: 7.188vw;
    }
    .index05 .index05-frame .index05-fx-frame .box-right .idx-list-community li .ttl img {
        width: 2.734vw;
        height: auto;
    }
    .index06 {
        padding: 6.797vw 0 12.5vw;
    }
    .index06 .txt {
        font-size: max(1.25vw, 14px);
    }
    .idx-list-ct {
        margin-top: 3.281vw;
    }
    .idx-list-ct li {
        margin-right: 1.875vw;
    }
    .idx-list-ct li:nth-child(2) a .ico {
        margin-right: 0.547vw;
    }
    .idx-list-ct li:nth-child(2) a .ttl {
        font-size: max(2.031vw, 20px);
        padding-bottom: 0.781vw;
    }
    .idx-list-ct li:last-child a .ico {
        margin-right: 0.781vw;
    }
    .idx-list-ct li:last-child a .ttl {
        padding-bottom: 0.391vw;
    }
    .idx-list-ct li:first-child a {
        padding-left: 3.906vw;
    }
    .idx-list-ct li a {
        min-width: max(23.438vw, 220px);
        min-height: max(6.875vw, 75px);
        padding: 0 1.563vw 0 1.953vw;
    }
    .idx-list-ct li a .ico {
        margin-right: 0.781vw;
    }
    .idx-list-ct li a .ico img {
        height: max(3.125vw, 30px);
        width: auto;
    }
    .idx-list-ct li a .ttl {
        font-size: max(1.563vw, 16px);
    }
    .idx-list-ct li a .ttl span {
        font-size: max(1.094vw, 11px);
    }
    .idx-list-ct li a .ico-arr img {
        width: max(1.953vw, 18px);
        height: max(1.953vw, 18px);
    }
    .index07 {
        padding: 7.031vw 0;
        margin-top: -9.453vw;
    }
    .index07:before {
        left: 7.266vw;
        top: 3.594vw;
        width: 85.781vw;
        height: 55.313vw;
    }
    .index07 .index07-fx .box-left {
        margin-left: -14.688vw;
        margin-right: 5.469vw;
        margin-top: 2.734vw;
    }
    .index07 .index07-fx .box-left .img {
        width: 45vw;
        height: 40.313vw;
    }
    .index07 .index07-fx .box-left .img .sub-ttl {
        right: -1.406vw;
        top: 8.125vw;
    }
    .index07 .index07-fx .box-left .ttl-greeting {
        right: -1.406vw;
        top: 8.125vw;
    }
    .index07 .index07-fx .box-left .ttl-greeting img {
        width: 9.922vw;
        height: auto;
    }
    .index07 .index07-fx .box-left .box-ttl {
        width: max(16.328vw, 150px);
        height: max(15.625vw, 130px);
        right: -1.953vw;
        bottom: -3.828vw;
        padding-top: 1.875vw;
        padding-left: 0.781vw;
    }
    .index07 .index07-fx .box-left .box-ttl .sub-ttl {
        font-size: max(0.938vw, 9px);
        margin-bottom: 0.469vw;
    }
    .index07 .index07-fx .box-left .box-ttl .ttl {
        font-size: max(1.563vw, 14px);
    }
    .index07 .index07-fx .box-left .box-ttl .ttl span {
        font-size: max(1.094vw, 10px);
    }
    .index07 .index07-fx .box-left .box-ttl .ttl label {
        font-size: max(0.781vw, 7px);
    }
    .index07 .index07-fx .box-center {
        max-width: max(40.234vw, 350px);
    }
    .index07 .index07-fx .box-center h2 {
        margin-bottom: 2.031vw;
    }
    .index07 .index07-fx .box-center .txt {
        font-size: max(1.25vw, 13px);
    }
    .index07 .index07-fx .box-center .idx-list-btn {
        margin-top: 2.266vw;
    }
    .index07 .index07-fx .box-center .idx-list-btn li {
        margin-right: 0.781vw;
    }
    .index07 .index07-fx .box-right {
        margin-top: -8.906vw;
        margin-left: -0.469vw;
    }
    .index07 .index07-fx .box-right .img02 {
        width: 32.109vw;
        height: 27.422vw;
        margin-bottom: 5vw;
    }
    .index07 .index07-fx .box-right .img03 {
        margin-left: 4.141vw;
        width: 17.266vw;
        height: 19.609vw;
    }
    .idx-btn a {
        font-size: max(1.25vw, 12px);
        padding-right: 3.516vw;
        padding-left: 1.563vw;
        min-height: max(4.141vw, 45px);
        border-radius: 1.563vw;
        max-width: max(18.75vw, 200px);
    }
    .idx-btn a:before {
        right: 1.172vw;
        width: max(1.953vw, 16px);
        height: max(1.953vw, 16px);
    }
	    .idx-box-howto .idx-list-howto02 {
        padding: 0 8.109vw 0 7.516vw;
    }
}

@media only screen and (min-width: 769px) and (max-width: 1024px) {
    .home_page .key .key-fx-mvs:before {
        left: -6.063vw;
    }
    .index04 .idx-fx-about.idx-fx-about04 .box-cnt {
        margin-right: -27.406vw;
    }
    .index04 .idx-fx-about:last-child {
        margin-top: 1vw;
    }
    .index05 .index05-frame {
        padding: 3.906vw 3.234vw 3.328vw;
        max-width: max(84.375vw, 700px);
    }
    .index03 .idx-box-area .idx-fx-area .box-img:after {
        width: 110%;
        height: 108%;
    }
}

@media only screen and (min-width: 769px) and (max-width: 992px) {
    .index03 .idx-box-area .idx-list-area02 li a .ico img {
        height: 3.297vw;
        width: auto;
    }
    .index03 .idx-box-area .idx-fx-area .box-cnt .idx-list-area {
        padding: 1.563vw 23px;
        min-width: 317px;
        max-width: 317px;
    }
    .index0 .idx-fx-family .box-img {
        top: -7.484vw;
        left: -0.859vw;
        margin-bottom: 50px;
    }
    .idx-box-howto .idx-list-howto li a .ico {
        margin-bottom: 1.06vw;
    }
    .idx-box-howto {
        padding: 5.625vw 5.734vw 5.469vw;
    }
    .idx-box-howto .idx-list-howto li a {
        width: max(12.109vw, 98px);
        height: max(12.109vw, 98px);
    }
/*     .idx-box-howto .idx-list-howto02 li:nth-child(3),
    .idx-box-howto .idx-list-howto02 li:nth-child(7),
    .idx-box-howto .idx-list-howto02 li:nth-child(11) {
        max-width: 23.672vw;
    }
    .idx-box-howto .idx-list-howto02 li:nth-child(2),
    .idx-box-howto .idx-list-howto02 li:nth-child(6),
    .idx-box-howto .idx-list-howto02 li:nth-child(10) {
        max-width: 13.109vw;
    } */
    .idx-box-howto .idx-box-howto02:before {
              bottom: -5.547vw;
        width: 118vw;
        height: 28.438vw;
    }
    .index03 .idx-box-area {
        padding: 7.734vw 5.813vw 5.469vw;
    }
    .index03 .idx-box-area {
        width: calc(100% - 2.906vw);
    }
    .index03 .idx-box-area .idx-fx-area .box-cnt .idx-list-area li:nth-child(2),
    .index03 .idx-box-area .idx-fx-area .box-cnt .idx-list-area li:nth-child(4) {
        margin-right: 6vw;
    }
    .index04 .idx-fx-about .box-cnt {
        padding: 3.906vw 6.484vw 6.453vw 3.906vw;
        margin-right: -14.922vw;
    }
    .index04 .idx-fx-about.idx-fx-about02 .box-cnt {
        margin-left: -14.922vw;
        padding: 3.906vw 3.906vw 6.453vw 6.563vw;
        margin-top: 7.469vw;
    }
    .index04 .idx-fx-about .box-img .idx-list-about {
        bottom: 4vw;
    }
    .index04 .idx-fx-about.idx-fx-about03 .box-about .box-cnt {
        padding: 5.938vw 3.359vw 6.063vw 3.906vw;
    }
    .index04 .idx-fx-about.idx-fx-about03 .box-about .box-cnt .stt {
        right: 1.891vw;
    }
    .index05 .index05-frame .index05-fx-frame .box-left .box-ttl {
        padding: 4.938vw 3.906vw 5.859vw 9.281vw;
    }
    .index05 .index05-frame .index05-fx-frame .box-left {
        padding-top: 6.047vw;
    }
    .index07 .index07-fx .box-left {
        margin-left: -17.688vw;
        margin-right: 3.469vw;
        margin-top: 2.734vw;
    }
    .index06 {
        padding: 6.797vw 0 15.5vw;
    }
    .index0 .idx-fx-family .box-img {
        left: 1.141vw;
    }
    .index0 .idx-fx-family {
        padding-left: 5.813vw;
    }
    .index03 .idx-box-area .idx-fx-area .box-cnt .idx-list-area li:last-child {
        margin-left: 0.1513vw;
    }
    .index03 .idx-box-area .idx-fx-area .box-cnt .idx-list-area li {
        margin-right: 0 !important;
        width: auto;
        min-width: 89px;
    }
    .index03 .idx-box-area .idx-fx-area .box-cnt .idx-list-area li:nth-child(3) {
        justify-content: flex-end;
    }
}


.idx_news {
  padding: 100px 0px 80px;
  background-color: #FAF8F4;
}
.idx_news h2{
    margin-bottom: 10px;
    color: var(--clr1);
}
.idx_news .idx-ttl-en {
    text-transform: uppercase;
}
.idx_news .idx-btn {
    margin-top: 40px;
}
.idx_news .content {
  align-items: inherit;
}
.idx_news .content li {
  border-bottom: 1px dashed #e5e5e5;
  width: auto;
}
.idx_news .content li:first-child{
  border-top: 1px dashed #e5e5e5;
}
.idx_news .content li a {
  display:flex;
  text-decoration: none;
  padding: 26px 30px 25px 0;
  font-weight: 500;
  transition: all 0.3s;
  letter-spacing: 0.1em;
  white-space: nowrap;
  max-width: 100%;
  background: url(../images/idx_news_arr_ico.svg) no-repeat right center/25px auto;
}
.idx_news .content li a span {
  display: inline;
}
.idx_news .content li a:hover {
  opacity: 1;
  color: var(--main-color);
}

.idx_news .content li a .date {
  width: 7em;
  transition: all 0.3s;
  color: var(--main-color);
}
.idx_news .content li a .title {
  max-width: calc(100% - 7em);
  position: relative;
  text-overflow: ellipsis;
  overflow: hidden;
  color: var(--clr1);
}
.idx_news .content .news {
  position: relative;
}

@media only screen and (min-width: 769px) {
  .idx_news {
    --size-box-ttl:300px;
  }
  .idx_news .box_left {
    width: var(--size-box-ttl);
  }
  .idx_news .box {
    width: calc(100% - var(--size-box-ttl) - 40px);
    max-width: 1000px;
  }
  .idx_news .content li a:hover .title {
  color: var(--main-color);
}
}
@media only screen and (min-width: 769px) and (max-width: 1280px) {
.idx_news {
    --size-box-ttl:220px;
    
  }
  .idx_news .inner {
    padding-left: 10px;
    padding-right: 10px;
  }
}
/*# sourceMappingURL=index_pc.css.map */