.home_page .key {
    background-size: cover;
    --height: 50vw;
    --min-height: 720px;
    --max-height: 720px;
    height: var(--height);
    min-height: var(--min-height);
    max-height: var(--max-height);
    overflow: hidden;
    font-size: 10px;
    max-width: 1920px;
    margin: 0 auto;
}

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

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

.box-main-txt {
    position: absolute;
    right: 2em;
    bottom: 12.375em;
    background: #f6efe7;
    color: var(--clr1);
    text-align: center;
    padding: 0.9375em;
    font-size: 1.8em;
    font-weight: 600;
    border-radius: 0.625em;
}

.home_page .key .key_text .item {
    width: 100%;
    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: 100% auto;
    background-position: center;
    background-repeat: no-repeat;
    position: relative;
}

.home_page .key .key_text .item .video {
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
    margin: auto;
    width: 100%;
    height: 100%;
}

.home_page .key .key_text .item .video video {
    width: 100%;
    height: 149.3%;
}

.home_page .key .inner {
    width: 100%;
    max-width: 1280px;
    padding-left: 5em;
    position: relative;
    height: 100%;
    display: flex;
    align-items: center;
}


/* .home_page .key .s1 {
    background-image: url(../images/idx-bg-main.jpg);
} */

.home_page .key .catch {
    max-width: 100%;
    margin-top: 17.9em;
}

.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: 0.2em;
    font-size: 5em;
    line-height: 1.5em;
    font-family: var(--f-hina);
}

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

.home_page .key .idx-list-main {
    position: absolute;
    right: 2.875em;
    bottom: 2.875em;
    width: 53.125em;
    display: flex;
    justify-content: space-between;
}

.home_page .key .idx-list-main li {
    margin-right: 1em;
    width: 33.3333333333%;
    display: flex;
    align-items: center;
    justify-content: center;
    max-width: 16.9em;
    height: 16.9em;
    border: 1px solid #fff;
    border-radius: 50%;
    background: transparent;
    text-align: center;
}

.home_page .key .idx-list-main li:last-child {
    margin-right: 0;
}

.home_page .key .idx-list-main li .ttl {
    font-size: 1.5em;
    letter-spacing: 0;
    line-height: 1.6em;
    color: #fff;
}

.home_page .idx-btn-view a {
    text-decoration: none;
    color: var(--clr1);
    font-family: var(--f-en);
    font-weight: 600;
    font-size: 1.4em;
    letter-spacing: 0.05em;
    padding-right: 1.4375em;
    position: relative;
    border-bottom: 0.125em solid var(--clr1);
    padding-bottom: 0.7em;
}

.home_page .idx-btn-view a:before {
    content: "";
    position: absolute;
    right: 0;
    bottom: 0.9em;
    background: url(../images/idx-ico-news.svg) no-repeat center;
    background-size: 100% auto;
    width: 0.78125em;
    height: 0.78125em;
}

.home_page .topic_path {
    display: none;
}

.home_page h2 {
    position: relative;
    margin-bottom: 35px;
    color: var(--clr1);
    font-family: var(--f-hina);
    font-size: 2.4375em;
    font-weight: 500;
    letter-spacing: 0.2em;
}

.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);
}

.home_page .idx-box-news {
    background: #f6efe7;
    border-top-right-radius: 7px;
    position: absolute;
    left: 0;
    bottom: 0;
    display: flex;
    padding-bottom: 2.8em;
    padding-top: 1.9em;
    padding-left: 5.05em;
    padding-right: 1.875em;
    min-width: 55.5em;
    max-width: 55.5em;
}

.home_page .idx-box-news .box-ttl {
    margin-right: 3.1em;
    flex-shrink: 0;
}

.home_page .idx-box-news .box-ttl .ttl {
    font-size: 2.2em;
    color: var(--clr2);
    font-weight: 600;
    font-family: var(--f-en);
    margin-bottom: 0.3em;
}

.home_page .idx-box-news .idx-list-news {
    padding-top: 1.35em;
}

.home_page .idx-box-news .idx-list-news li {
    margin-bottom: 0.925em;
}

.home_page .idx-box-news .idx-list-news li:last-child {
    margin-bottom: 0;
}

.home_page .idx-box-news .idx-list-news li a {
    display: flex;
    text-decoration: none;
    color: var(--clr1);
    padding-right: 3.2em;
    position: relative;
}

.home_page .idx-box-news .idx-list-news li a:before {
    content: "";
    position: absolute;
    right: 0;
    top: 0.4em;
    background: url(../images/idx-ico-news.svg) no-repeat center;
    background-size: 100% auto;
    width: 12.5px;
    height: 12.5px;
}

.home_page .idx-box-news .idx-list-news li a .date {
    color: #b5a999;
    font-size: 1em;
    font-family: var(--f-en);
    letter-spacing: 0.02em;
    font-weight: 500;
    margin-right: 0.925em;
    line-height: 1.7em;
}

.home_page .idx-box-news .idx-list-news li a .title {
    font-size: 1.2em;
    font-weight: 600;
    letter-spacing: -0.5px;
    display: -webkit-box;
    -webkit-line-clamp: 1;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
    transition: 0.3s all;
}

@media only screen and (min-width: 769px) {
    .index02-frame .index02-list02 li:hover {
        transform: translateY(-5px);
        transition: 0.3s all;
    }
    .index0-list li a:hover {
        opacity: 1;
    }
    .index0-list li:hover {
        transform: translateY(-5px);
        transition: 0.3s all;
    }
    .home_page .key .idx-box-news .idx-list-news li a:hover .title {
        text-decoration: underline;
        transition: 0.3s all;
    }
    .home_page .idx-btn-view a:hover {
        color: var(--clr2);
        opacity: 1;
        transition: 0.3s all;
        border-bottom: 1px solid var(--clr2);
    }
    .index02-list li a:hover {
        opacity: 1;
        transform: translateY(-5px);
        transition: 0.3s all;
    }
}

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

.index0 {
    padding: 6.8125em 0 0;
}

.index0 h2 {
    text-align: center;
    margin-bottom: 0;
    font-weight: 500;
}

.index0 .idx-ttl-en02 {
    margin-bottom: 3.9em;
}

.index0 .inner {
    position: relative;
    max-width: 1200px;
}

.index0 .inner:after {
    content: "";
    position: absolute;
    right: -110px;
    top: -260px;
    background: url(../images/index0-ico01.svg) no-repeat center;
    background-size: contain;
    width: 439px;
    height: 374px;
}

.index0-list {
    display: flex;
    position: relative;
    z-index: 1;
}

.index0-list:before {
    content: "";
    position: absolute;
    left: -6.25em;
    top: -13.125em;
    background: url(../images/index0-ico02.svg) no-repeat center;
    background-size: contain;
    width: 21.375em;
    height: 21.375em;
}

.index0-list li {
    width: 50%;
    border-radius: 7px;
    background: url(../images/index0-bg01.jpg) no-repeat center;
    background-size: 100% 100%;
    min-height: 18.75em;
    position: relative;
    margin-right: 0.4em;
    transition: 0.3s all;
}

.index0-list li:last-child {
    margin-right: 0;
    background: url(../images/index0-bg02.jpg) no-repeat center;
    background-size: 100% 100%;
}

.index0-list li:last-child a {
    padding-left: 2.5em;
}

.index0-list li:before {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
    margin: auto;
    width: 100%;
    height: 100%;
    background: rgb(209, 201, 191);
    mix-blend-mode: multiply;
    border-radius: 7px;
}

.index0-list li a {
    padding: 2em 1.875em;
    text-decoration: none;
    display: block;
    width: 100%;
    height: 100%;
    position: relative;
    z-index: 1;
}

.index0-list li .ttl {
    font-size: 1.5625em;
    color: #fff;
    font-family: var(--f-hina);
    position: relative;
    margin-bottom: -0.15em;
    line-height: 1.5em;
    display: block;
}

.index0-list li .ttl-en {
    line-height: 1em;
    font-size: 0.75em;
    color: #fff;
    position: relative;
    font-weight: 400;
    font-family: var(--f-en);
    letter-spacing: 0.03em;
}

.index0-list li .btn {
    position: absolute;
    right: 1.875em;
    bottom: 1.8125em;
    z-index: 1;
    line-height: 0;
}

.idx-list-btn02 {
    display: flex;
    margin-top: 2.5em;
}

.idx-list-btn02 li {
    max-width: 15.6875em;
    margin-right: 1.5625em;
}

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

.idx-list-btn02 li a {
    border-radius: 5px;
    min-width: 15.7em;
    min-height: 5em;
    padding-left: 1.15em;
    font-size: 1em;
}

.idx-list-btn02 li a .ico {
    width: 2.5em;
    flex-shrink: 0;
    text-align: center;
    margin-right: 1em;
}

.index02 {
    background: #f6efe7;
    margin-top: -9.375em;
    padding-top: 14.6875em;
    padding-bottom: 7.6em;
}

.index02.index03 {
    background: #faf5f1;
    margin-top: 0;
    padding-top: 5.2em;
    padding-bottom: 7.4em;
}

.index02.index03 .inner_sm:after {
    content: "";
    position: absolute;
    right: -12em;
    top: -6.55em;
    background: url(../images/index03-ico02.png) no-repeat center;
    background-size: 100% 100%;
    width: 56.875em;
    height: 37.9375em;
}

.index02.index03 .index02-bg {
    padding-bottom: 3.3em;
}

.index02.index03 .index02-bg:before {
    background: #f6efe7;
    height: 132.6%;
}

.index02.index03 .index02-frame {
    padding-bottom: 3em;
}


/* .index02.index03 .index02-frame:before {
    background: url(../images/index03-frame-ico01.svg) no-repeat center;
    background-size: 100% 100%;
} */

.index02.index03 .index02-frame h3:before {
    top: -0.35em;
}

.index02.index03 .index02-frame:after {
    background: url(../images/index03-frame-ico02.svg) no-repeat center;
    background-size: 100% 100%;
}

.index02.index03 .index02-frame h3 {
    top: -0.85em;
    margin-bottom: -0.9em;
    position: relative;
}

.index02-frame h3:before {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    top: 0.3em;
    bottom: 0;
    margin: auto;
    height: 1px;
    width: 50%;
    background: #fff;
    z-index: -1;
}

.index02.index03 .index02-frame h3 span {
    margin-top: -0.25em;
    display: block;
    font-size: 18px;
    letter-spacing: 0.1em;
}

.index02.index03 .index02-frame .index02-frame-fx {
    display: flex;
    position: relative;
    margin-top: 2.1em;
    padding: 0 4.2em;
}

.index02.index03 .index02-frame .index02-frame-fx:before {
    content: "";
    position: absolute;
    right: 3.875em;
    bottom: -3.9em;
    background: url(../images/index03-ico01.svg) no-repeat center;
    background-size: 100% auto;
    width: 15.5625em;
    height: 8.4375em;
}

.index02.index03 .index02-frame .index02-frame-fx .img {
    flex-shrink: 0;
    margin-right: 1.5em;
    margin-top: 0.5em;
}

.index02.index03 .index02-frame .index02-frame-fx .img img {
    border-radius: 7px;
}

.index02.index03 .index02-frame .index02-frame-fx .cnt>p {
    font-size: 0.875em;
    letter-spacing: 0;
    margin-bottom: 1.75em;
}

.index02.index03 .index02-frame .index02-frame-fx .cnt .idx-btn {
    max-width: 10.625em;
}

.index02.index03 .index02-frame .index02-frame-fx .cnt .idx-btn a {
    min-width: 11.7em;
    min-height: 3.3em;
    padding-left: 1.9em;
    font-size: 1.035em;
}

.index02 .inner_sm {
    position: relative;
}

.index02 .inner_sm:after {
    content: "";
    position: absolute;
    right: -23.3125em;
    top: -13.375em;
    background: url(../images/index02-ico-inner.png) no-repeat center;
    background-size: 100% 100%;
    width: 63.625em;
    height: 37.8125em;
}

.index02 .idx-ttl-en {
    padding-left: 1.1em;
    font-size: 1.0625em;
    color: var(--clr2);
    margin-bottom: 0.1em;
    font-weight: 500;
}

.index02 .idx-ttl-en:before {
    width: 0.625em;
}

.index02 .index02-bg {
    position: relative;
    z-index: 1;
    padding-bottom: 4.375em;
}

.index02 .index02-bg:before {
    content: "";
    position: absolute;
    left: -74em;
    background: #faf5f1;
    height: 111.5%;
    top: 3.9375em;
    width: 120em;
    border-top-right-radius: 7px;
    border-bottom-right-radius: 7px;
    z-index: -1;
}

.index02 .index02-box {
    max-width: 40em;
    margin-bottom: 2.5em;
}

.index02 .idx-fx-ttl {
    display: flex;
    align-items: center;
    margin-bottom: 1.1em;
}

.idx-list-btn02 li a:before {
    right: 0.9em
}

.index02 .idx-fx-ttl h2 {
    font-size: 3.75em;
    margin-bottom: 0;
    margin-right: 0.35em;
    font-weight: 500;
}

.index02 .idx-fx-ttl .idx-btn a {
    min-width: 11.75em;
    min-height: 3.45em;
}

.index02 .cnt>p {
    line-height: 2em;
    letter-spacing: -0.5px;
}

.index02-list {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
}

.index02-list li {
    width: 25%;
    max-width: 15.6875em;
    margin-right: 1.5625em;
    margin-bottom: 1.5625em;
}

.index02-list li:nth-child(4n) {
    margin-right: 0;
}

.index02-list li a {
    text-decoration: none;
    display: flex;
    align-items: center;
    min-height: 5em;
    width: 100%;
    background: #fff;
    border-radius: 0.3125em;
    padding-left: 1.0625em;
    padding-right: 0.875em;
    box-shadow: 0 0 10px 0 rgba(0, 0, 0, 0.1);
}

.index02-list li a .ico {
    width: 2.5em;
    flex-shrink: 0;
    margin-right: 0.9em;
    text-align: center;
}

.index02-list li a .ttl {
    font-size: 1em;
    font-weight: 600;
    color: var(--clr1);
    line-height: 1.3em;
    letter-spacing: 0;
}

.index02-list li a .btn {
    flex: 1;
    line-height: 0;
    text-align: right;
}

.index02-frame {
    border-radius: 7px;
    min-height: 20.0625em;
    position: relative;
    z-index: 2;
    max-width: 67.5em;
    margin-right: auto;
    margin-left: auto;
    padding-bottom: 4em;
}

.index02-frame:before {
    content: "";
    position: absolute;
    right: 0;
    top: 0;
    bottom: 0;
    margin: auto;
    left: 0;
    background: #fff;
    border: 1px solid #e2d9ca;
    border-radius: 15px;
    width: 100%;
    height: 100%;
}

.index02-frame:after {
    content: "";
    position: absolute;
    right: -0.625em;
    top: 0.625em;
    background: url(../images/index02-frame-ico02.svg) no-repeat center;
    background-size: 100% 100%;
    width: 100%;
    height: 100%;
    z-index: -1;
}

.index02-frame h3 {
    text-align: center;
    font-size: 2.4375em;
    font-family: var(--f-hina);
    position: relative;
    top: -0.9em;
    letter-spacing: 0.15em;
    margin-bottom: -0.85em;
    font-weight: 500;
    z-index: 1;
}

.index02-frame .index02-list02 {
    display: flex;
    padding: 0 4.125em;
    margin-top: 2.625em;
    position: relative;
}

.index02-frame .index02-list02:before {
    content: "";
    position: absolute;
    right: 4.5em;
    top: -7.75em;
    background: url(../images/index02-frame-ico03.svg) no-repeat center;
    background-size: 100% 100%;
    width: 12.375em;
    height: 5.3125em;
    z-index: 1;
}

.index02-frame .index02-list02 li {
    display: flex;
    border: 1px solid #e2d9ca;
    border-radius: 7px;
    overflow: hidden;
    margin-right: 1.25em;
    background: #fff;
    padding-right: 1.2em;
    position: relative;
    width: calc(100% / 2);
}

.index02-frame .index02-list02 li .link-in {
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
    margin: auto;
    width: 100%;
    height: 100%;
}

.index02-frame .index02-list02 li:before {
    content: "";
    position: absolute;
    right: 1.05em;
    bottom: 17px;
    background: url(../images/idx-ico-news.svg) no-repeat center;
    background-size: 100% auto;
    width: 0.78125em;
    height: 0.78125em;
}

.index02-frame .index02-list02 li:last-child {
    margin-right: 0;
}

.index02-frame .index02-list02 li .img {
    margin-bottom: 0;
    flex-shrink: 0;
    margin-right: 1.6em;
    width: 14.375em;
}

.index02-frame .index02-list02 li .img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.index02-frame .index02-list02 li .cnt {
    padding-top: 1.8em;
    padding-bottom: 1.8em;
}

.index02-frame .index02-list02 li .cnt .ttl {
    font-size: 1.125em;
    font-weight: 600;
    margin-bottom: 0.2em;
}

.index02-frame .index02-list02 li .cnt .txt {
    letter-spacing: -0.5px;
    line-height: 1.7em;
}

.idx-ttl-en02 {
    text-align: center;
    line-height: 1.65em;
}

.idx-ttl-en02 span {
    display: inline-block;
    position: relative;
    font-size: 0.875em;
    font-family: var(--f-en);
    color: var(--clr2);
    padding: 0 1.2625em;
    letter-spacing: 0.05em;
}

.idx-ttl-en02 span:before,
.idx-ttl-en02 span:after {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    margin: auto 0;
    width: 0.72em;
    height: 1px;
    background: var(--clr2);
}

.idx-ttl-en02 span:before {
    left: 0;
}

.idx-ttl-en02 span:after {
    right: 0;
}

.idx-ttl-en {
    font-size: 0.75em;
    font-family: var(--f-en);
    padding-left: 0.8125em;
    letter-spacing: 0.03em;
    position: relative;
    line-height: 1em;
    margin-bottom: 0.75em;
    font-weight: 600;
}

.idx-ttl-en:before {
    content: "";
    position: absolute;
    top: 0.5em;
    background: var(--clr2);
    width: 0.4375em;
    height: 1px;
    left: 0;
}

.idx-ttl-jp {
    line-height: 1.5em;
    margin-left: -5px;
}

.idx-ttl-jp span {
    padding: 0 2px 0 5px;
    font-size: 18px;
    color: var(--clr1);
    font-weight: 600;
    letter-spacing: 0.3em;
    background: linear-gradient(0deg, rgb(255, 255, 255) 40%, rgba(255, 255, 255, 0) 40%);
}

.index04 {
    padding-bottom: 7.5em;
}

.index04 .idx-btn {
    max-width: 13.125em;
    margin: -1.85em auto 0;
}

.index04 .bg {
    position: relative;
}

.index04 .bg img {
    height: 37.5em;
    object-fit: cover;
}

.index04 .bg:before {
    content: "";
    position: absolute;
    left: 50%;
    transform: translate(-50%);
    background: url(../images/index04-bg02.png) no-repeat center;
    background-size: 100% 100%;
    width: 120em;
    height: 35em;
    top: 18.75em;
}

.index04 h2 {
    text-align: center;
    margin-bottom: 0.06em;
}

.index04 .inner_big {
    margin-top: -6.4375em;
    position: relative;
    z-index: 1;
}

.index04 .inner_big:before {
    content: "";
    position: absolute;
    left: 46.5%;
    transform: translate(-50%);
    background: url(../images/index04-ico.png) no-repeat center;
    background-size: 100% 100%;
    width: 96.875em;
    height: 138.1875em;
    top: 4.0625em;
    z-index: -1;
}

.index04 .index04-fx {
    position: relative;
    display: flex;
    margin-top: 3.85em;
}

.index04 .index04-fx.index04-fx02 {
    justify-content: flex-end;
    margin-top: 6.2em;
    margin-bottom: 6.15em;
}

.index04 .index04-fx.index04-fx02 .img {
    order: 2;
}

.index04 .index04-fx.index04-fx02 .img img {
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
    border-top-left-radius: 7px;
    border-bottom-left-radius: 7px;
}

.index04 .index04-fx.index04-fx02 .cnt {
    order: 1;
    margin-left: 0;
    margin-right: -4.2em;
}

.index04 .index04-fx .img {
    flex-shrink: 0;
}

.index04 .index04-fx .img img {
    border-top-right-radius: 7px;
    border-bottom-right-radius: 7px;
}

.index04 .index04-fx .cnt {
    margin-top: 4.15em;
    margin-left: -3.7em;
    max-width: 29.875em;
    position: relative;
    z-index: 2;
}

.index04 .index04-fx .cnt .idx-ttl-en {
    color: var(--clr2);
    font-size: 0.875em;
    margin-bottom: 1.05em;
    padding-left: 1.3em;
    font-weight: 500;
}

.index04 .index04-fx .cnt .idx-ttl-en:before {
    background: var(--clr2);
    width: 0.625em;
}

.index04 .index04-fx .cnt h3 {
    font-size: 1.78125em;
    font-family: var(--f-hina);
    letter-spacing: 0.03em;
    line-height: 1.6em;
    margin-bottom: 1.15em;
}

.index04 .index04-fx .cnt .cnt-txt>p {
    letter-spacing: -0.5px;
}

.idx_gallery {
    margin-top: -18.3em;
    position: relative;
    z-index: 2;
}

.idx_gallery .item {
    margin: 0 0.9375em;
}

.idx_gallery .item.item02 {
    margin-top: 1.875em;
}

.idx_gallery .item img {
    border-radius: 7px;
}

.index05 {
    padding: 6.75em 0;
}

.index05 h2 {
    text-align: center;
    margin-bottom: 0.05em;
    position: relative;
    z-index: 2;
}

.index05 .idx-ttl-en02 {
    position: relative;
    z-index: 2;
}

.index05-fx {
    display: flex;
    margin-top: -2.5em;
}

.index05-cnt {
    position: relative;
    padding-bottom: 19em;
    width: 50%;
}

.index05-cnt:after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    margin: 0 auto;
    top: -10.75em;
    background: url(../images/index05-bg01.png) no-repeat center;
    background-size: 100% auto;
    width: 100%;
    height: calc(100% + 10.75em);
}

.index05-cnt:last-child:after {
    background: url(../images/index05-bg02.png) no-repeat center;
    background-size: 100% auto;
}

.index05-cnt:last-child .img:after {
    display: none;
}

.index05-cnt .img {
    border-radius: 50%;
    position: relative;
    width: 27.5em;
    height: 27.5em;
    margin: 0 auto 0.65em;
    z-index: 1;
}

.index05-cnt .img:before {
    content: "";
    position: absolute;
    left: 0.625em;
    right: 0;
    top: 0.9375em;
    bottom: 0;
    margin: auto;
    background: url(../images/index05-ico01.png) no-repeat center;
    background-size: 100% auto;
    width: 100%;
    height: 100%;
    z-index: -1;
}

.index05-cnt .img:after {
    content: "";
    position: absolute;
    right: -9.4375em;
    top: 0;
    bottom: 0;
    margin: auto 0;
    background: url(../images/idx-ico-x.svg) no-repeat center;
    background-size: 100% auto;
    width: 6.25em;
    height: 6.25em;
    z-index: 1;
}

.index05-cnt .img img {
    border-radius: 50%;
}

.index05-cnt .cnt {
    position: relative;
    z-index: 1;
    padding: 0 6.1em 0 6.3em;
}

.index05-cnt .cnt .idx-ttl-en {
    color: var(--clr2);
    padding-left: 0;
    margin-bottom: -0.05em;
}

.index05-cnt .cnt .idx-ttl-en:before {
    display: none;
}

.index05-cnt .cnt h3 {
    margin-bottom: 0.5em;
    font-size: 1.75em;
    letter-spacing: 0.14em;
    position: relative;
    display: flex;
    align-items: center;
}

.index05-cnt .cnt h3:after {
    content: "";
    position: relative;
    right: 0;
    top: 0;
    bottom: 0;
    margin: auto;
    width: 100%;
    height: 1px;
    background: #e2d9ca;
}

.index05-cnt .cnt h3 span {
    display: flex;
    align-items: center;
    flex-shrink: 0;
    margin-right: 15px;
    font-family: "Hina Mincho", serif;
}

.index05-cnt .cnt .txt {
    margin-bottom: 2em;
}

.index05-cnt .cnt .txt>p {
    letter-spacing: 0;
}

.index05-cnt .cnt .idx-list-btn li {
    margin-right: 1.125em;
}

.index05-cnt .cnt .idx-list-btn li:last-child a {
    letter-spacing: -0.5px;
}

.index05-cnt .cnt .idx-list-btn li a {
    min-width: 14.5em;
}

.idx_map {
    height: 450px;
}

.idx_map iframe {
    height: 100%;
}

@media only screen and (min-width: 769px) and (max-width: 1440px) {
    .home_page .key .key_text .item .video video {
        width: 100%;
        height: 112.5%;
    }
}

@media only screen and (min-width: 769px) and (max-width: 1366px) {
    .home_page .key .key_text .item .video video {
        width: 100%;
        height: 106.7%;
    }
}

@media only screen and (min-width: 769px) and (max-width: 1280px) {
     :root {
        --ttl_size: 24px;
    }
    .home_page .key {
        font-size: 0.782vw;
        --min-height: 72em;
        --max-height: 72em;
    }
    .index02.index03,
    .index04,
    .index05,
    .idx_gallery,
    .index02,
    .index0 {
        font-size: 1.25vw;
    }
    .index04 .inner_big,
    .index05 .inner_big {
        padding: 0;
    }
    .index02.index03 .index02-frame .index02-frame-fx .img img {
        width: 28.75em;
        height: auto;
    }
    .index04 .index04-fx .img img {
        width: 45em;
        height: auto;
    }
    .index05-cnt .img img {
        width: 27.5em;
        height: auto;
    }
    .idx_gallery .item img {
        width: 20.625em;
        height: auto;
    }
    .index02-frame .index02-list02 li .img img {
        width: 14.375em;
    }
    .home_page .key .key_text .item .video video {
        width: 100%;
        height: 100%;
    }
    .box-main-txt {
        right: 3em;
    }
}

@media only screen and (max-width: 1024px) and (min-width: 769px) {
    .home_page .idx-box-news {
        font-size: 0.95vw;
    }
    .home_page .key .catch {
        margin-top: 6.9em;
    }
    .home_page .key .idx-list-main {
        right: 5.875em;
    }
    .index0-list li .ttl-en {
        font-size: 1em;
    }
    .home_page .key {
        --min-height: 68em;
        --max-height: 68em;
    }
    .index02-frame h3:before {
        top: 0.35em;
    }
    .index02.index03 .index02-frame h3:before {
        top: -0.5em;
    }
    .home_page .key .key_text .item .video video {
        width: 100%;
        height: 105.8%;
    }
    .box-main-txt {
        right: 4em;
    }
}

@media only screen and (max-width: 992px) and (min-width: 769px) {
     :root {
        --ttl_size: 22px;
    }
    .index04 .index04-fx .cnt .cnt-txt>p {
        letter-spacing: -0.5px;
        font-size: 12px;
    }
    .index04 .index04-fx .img img {
        width: 50em;
        height: auto;
    }
    .home_page .idx-box-news {
        padding-left: 2.05em;
        min-width: 45.5em;
        max-width: 45.5em;
    }
    .index02.index03 .index02-frame h3:before {
        top: -0.7em;
    }
}


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