@charset "utf=8";

/* ==========================================
カバー
========================================== */

.cover-frame {
    position: relative;
}

.cover-mask-block {
    display: block;
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    margin: auto;
    z-index: 1;
    background: var(--mask-primary);
}

.cover-logo-block {
    position: absolute;
    top: 37%;
    right: 0;
    left: 0;
    margin: auto;
    max-width: 37rem;
    width: 40%;
    height: 39.5%;
    z-index: 9;
}

.cover-title {
    position: absolute;
    top: -8rem;
    right: 0;
    font-size: 4.5rem;
    font-family: var(--font-family01);
    letter-spacing: 1.3rem;
    writing-mode: vertical-rl;
    width: 4.5rem;
    height: 17.5rem;
}

.cover-logo {
    max-width: 20rem;
    width: 100%;
    margin: 0 auto;
}

/* cover-btn */

.cover-navi-block {
    max-width: 21.4rem;
    width: 100%;
    position: absolute;
    top: 5rem;
    left: 5rem;
    z-index: 9;
}

.cover-tel-btn-row {
    display: flex;
    align-items: center;
    justify-content: center;
    max-width: 21.4rem;
    width: 100%;
    padding: 0 0 .6rem 0;
}

.cover-tel-icon {
    max-width: 2.2rem;
    width: 20%;
    margin: 0 1.3rem 0 0;
}

.cover-tel-num {
    font-size: 2.2rem;
    font-weight: 400;
    letter-spacing: 0.1em;
    line-height: 1.45em;
}

.cover-tel-btn-row.border-white {
    border-bottom: .1rem solid var(--white);
}

.cover-btn {
    max-width: 21.4rem;
    width: 100%;
    text-align: center;
    font-size: 1.8rem;
    letter-spacing: 0.05em;
}

.cover-btn a {
    display: block;
    width: 100%;
    padding: .8rem 1.5rem 1rem;
    border: .1rem solid var(--white);
}

.cover-btn a:hover {
    background: rgba(255,255,255,.3);
}

.cover-rsv-btn {
    margin: 2.55rem 0 0 0;
    font-size: 1.8rem;
    font-weight: 400;
    letter-spacing: 0.05em;
}

.cover-ec-btn {
    margin: 1.5rem 0 0 0;
    font-size: 1.8rem;
    font-weight: 500;
    letter-spacing: 0.1em;
}

.cover-sns {
    display: block;
    margin: 2.5rem 0 0;
    max-width: 30px;
    width: 100%;
}

.scroll-link {
    display: block;
    position: absolute;
    bottom: -7rem;
    left: 0;
    right: 0;
    margin: auto;
    z-index: 9;
    max-width: 1.3rem;
    width: 2%;
}

/* swiper */

.cover .swiper-pagination, .cover .swiper-button-prev, .cover .swiper-button-next {
    display: none;
}

@keyframes zoomUp {
  0% {
    transform: scale(1);
  }
  100% {
    transform: scale(1.15);
  }
}
.swiper-slide-active .swiper-img,
.swiper-slide-duplicate-active .swiper-img,
.swiper-slide-prev .swiper-img {
  animation: zoomUp 7s linear 0s normal both;
}
.swiper-slide .swiper-img img {
  height: auto;
  width: 100%;
}

/* ==========================================
top01
========================================== */

.top01 {
    position: relative;
}

.top01:after {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    width: 100%;
    height: 100%;
    background: var(--mask-secondary);
    z-index: 1;
}

.top01-bg {
    background: url(../../../../uploads/top_bg01.jpg) no-repeat center;
    background-size: cover;
}

.top01-img01 {
    max-width: 78rem;
    width: 45%;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 2;
}

.top01-wrapper {
    max-width: 153rem;
    width: 100%;
    margin: 0 auto;
    position: relative;
}

.top01-wrapper:after {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    max-width: 67.4rem;
    width: 54.35%;
    height: 55%;
    background: url(../../../../uploads/top01_text_deco.png) no-repeat center;
    background-size: contain;
    z-index: 5;
}

.top01-frame {
    position: relative;
    padding: 10.7rem 0 16.5rem;
    z-index: 9;
}

/* row */

.top01-row {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
}

.top01-img02 {
    max-width: 66.3rem;
    width: 53.47%;
    margin: 18.8rem 0 0 0;
}

.top01-text-row {
    max-width: 46rem;
    width: 45%;
    display: grid;
    grid-auto-flow: row;
    writing-mode: vertical-rl;
    position: relative;
}

.top01-text-box {
    position: static;
    z-index: 20;
}

.top01-text-box02 {
    margin: 12.4rem 9rem auto auto;
}

.top01-text-box .text02 {
    letter-spacing: 0.4em;
    line-height: 2.8em;
}


/* ==========================================
top02
========================================== */

.top02 {
    position: relative;
}

.top02:before {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    width: 100%;
    height: 100%;
    background: var(--mask-secondary);
    z-index: 1;
}

.top02:after {
    content: "";
    position: absolute;
    right: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    width: 100%;
    height: 51.08%;
    background: var(--mask-gradation);
    z-index: 1;
}

/* .top02-bg {
    background: url(../../../../uploads/top_bg02.jpg) no-repeat center;
    background-size: cover;
} */

.top02-img-box03 {
    position: absolute;
    width: 100%;
    height: 100%;
    z-index: 0;
}

.top02-img03 img {
    justify-content: center;
    align-items: center;
    position: absolute;
    display: flex;
    top: 0;
    right: 0;
    left: 0;
    bottom: 0;
    max-height: 100%;
    height: 100% !important;
    max-width: 100%;
    width: 100%;
    margin: auto;
    object-fit: cover;
    transition: all .5s;
}

.top02-img-box01 {
    position: relative;
    z-index: 2;
}

.top02-wrapper {
    position: relative;
    max-width: 151rem;
    width: 100%;
    margin: 0 auto;
    padding: 12.6rem 0 10rem;
    z-index: 2;
}

.top02-img-box01 {
    max-width: 78.1rem;
    width: 40.68%;
    position: absolute;
    top: -7.5%;
    right: 0;
    z-index: 3;
}

.top02-img-box01:before {
    content: "";
    position: absolute;
    right: 0;
    bottom: -11.7rem;
    background: url(../../../../uploads/2025/05/top04_deco.png) no-repeat center;
    background-size: cover;
    width: 100%;
    height: 58.16%;
    z-index: 4;
}

.top02-img-box01:after {
    content: "";
    position: absolute;
    right: 0;
    bottom: -11.7rem;
    background: var(--primary);
    width: 100%;
    height: 58.16%;
    z-index: 3;
}

.top02-img01 {
    max-width: 38rem;
    width: 48.66%;
    margin: 0 auto 0 6rem;
    position: relative;
    z-index: 5;
}

.top02-img02 {
    max-width: 57.1rem;
    width: 37.81%;
}

/* text-frame */

.top02-text-frame {
    position: relative;
    margin: 12rem auto 0;
    padding: 6rem 1.5rem 4.4rem;
    max-width: 110rem;
    width: 100%;
    background: rgba(255,255,255,.25);
}

.top02-text-frame:after {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    background: url(../../../../uploads/top_deco02.png) no-repeat center;
    background-size: cover;
    width: 100%;
    height: 100%;
    z-index: 1;
}

.top02-text-block {
    max-width: 92.5rem;
    width: 100%;
    margin: 0 auto;
    position: relative;
    z-index: 2;
}

.top02-title-box {
    max-width: 82.4rem;
    width: 100%;
    margin: 0 auto;
    text-align: center;
    padding: 0 0 .6rem 0;
    position: relative;
}

.top02-title-box:after {
    content: "";
    position: absolute;
    right: 0;
    bottom: -2rem;
    margin: auto;
    background: url(../../../../uploads/2025/05/text_deco01.png) no-repeat center;
    background-size: contain;
    width: 100%;
    height: 2rem;
    z-index: 1;
}

.top02-title-box .title01 br {
    display: none;
}

.top02-text-box {
    position: relative;
    margin: 4rem auto 0;
}

.top02-text {
    font-weight: 700;
    text-align: center;
    line-height: 2.38em;
}

/* ==========================================
top03
========================================== */

.top03 {
    padding: 0 0 15rem 0;
}

.top03-frame {
    max-width: 147.6rem;
    width: 100%;
    margin: 0 auto;
}

.top03-row {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
}

.top03-img-box01 {
    max-width: 54rem;
    width: 36.59%;
    position: relative;
}

.top03-img-box01:before {
    content: "";
    position: absolute;
    top: 3.4rem;
    left: 0;
    margin: auto;
    background: url(../../../../uploads/2025/05/top05_deco.png) no-repeat center;
    background-size: cover;
    width: 83.52%;
    height: 79.24%;
    z-index: 2;
}

.top03-img-box01:after {
    content: "";
    position: absolute;
    top: 3.4rem;
    left: 0;
    margin: auto;
    background: var(--primary);
    background-size: cover;
    max-width: 45.1rem;
    width: 83.52%;
    height: 79.24%;
    z-index: 1;
}

.top03-img01 {
    max-width: 39.4rem;
    width: 72.96%;
    margin: 7rem 0 auto auto;
    position: relative;
    z-index: 3;
}

.top03-right {
    max-width: 69.4rem;
    width: 47.02%;
    position: relative;
    margin: 0 3.5%
}

.top03-btn {
    margin: 10rem auto 0;
}

/* ==========================================
top04
========================================== */

.top04-row {
    display: flex;
    align-items: stretch;
    justify-content: center;
}

.top04-left {
    position: relative;
    max-width: 87.5rem;
    width: 44.01%;
    background: var(--primary);
    padding: 9.6rem 1.5rem 9.5rem;
}

.top04-left:before {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    background: url(../../../../uploads/2025/05/text_bg02.png) no-repeat center;
    background-size: cover;
    width: 100%;
    height: 100%;
    z-index: 1;
}

.top04-img {
    max-width: 107.5rem;
    width: 55.99%;
    height: auto;
    min-height: 70rem;
    position: relative;
}

.top04-img img {
    justify-content: center;
    align-items: center;
    position: absolute;
    display: flex;
    top: 0;
    right: 0;
    left: 0;
    bottom: 0;
    max-height: 100%;
    height: 100% !important;
    max-width: 100%;
    width: 100%;
    margin: auto;
    object-fit: cover;
}

.top04-text-block {
    position: relative;
    max-width: 45rem;
    width: 100%;
    margin: 0 auto;
    z-index: 5;
}

.top04-text-block .title01 {
    line-height: 1.87em;
}

.top04-text-box {
    margin: 5.5rem 0 0;
}

.top04-text-box .text01 {
    line-height: 2.39em;
}

.top04-btn {
    margin: 7rem 0 0;
}

/* ==========================================
top05
========================================== */

.top05 {
    position: relative;
}

.top05:after {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    width: 100%;
    height: 100%;
    background: var(--mask-quaternary);
    z-index: 1;
}

.top05-bg {
    background: url(../../../../uploads/top_bg03.jpg) no-repeat center;
    background-size: cover;
}

.top05-frame {
    padding: 10.2rem 0;
    z-index: 5;
}

.top05-text-block {
    max-width: 36rem;
    width: 100%;
    margin: 0 0 0 auto;
}

.top05-text-block .title01 {
    font-weight: 400;
}

.top05-text-box {
    margin: 4.7rem 0 0;
}

.top05-text {
    font-size: 2.2rem;
    font-weight: 400;
    letter-spacing: 0.05em;
    line-height: 1.98em;
}

.top05-btn {
    margin: 7rem 0 0;
}

/* ==========================================
top06
========================================== */

.top06 {
    padding: 13.6rem 0 14.6rem;
}

.top06-row {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
}

.top06-left {
    max-width: 14.2rem;
    width: 20%;
}

.top06-title {
    writing-mode: vertical-lr;
    text-align: center;
    margin: 0 auto;
    letter-spacing: 0.3em;
}

.top06-deco {
    margin: 4rem 0 0;
}

.top06-right {
    max-width: 93.2rem;
    width: 75.16%;
}

.top-news-row {
    display: flex;
    align-items: center;
    justify-content: flex-start;
}

.top-news-link {
    display: block;
    padding: 3.2rem 0 .7rem 0;
    border-bottom: .1rem solid;
    position: relative;
}

.top-news-link:after {
    content: "";
    position: absolute;
    right: 0;
    bottom: 2rem;
    margin: auto;
    width: 3.7rem;
    height: .6rem;
    background: url(../../../../uploads/arrow_right_gray.png) no-repeat center;
    background-size: contain;
    z-index: 1;
}

.top-news-box:first-child .top-news-link {
    padding: 0rem 0 .7rem 0; 
}

.top-news-link .tit {
    margin: 1.5rem 0 0;
}

.top-news-link:hover .tit {
    text-decoration: underline;
}

.date {
    width: 8rem;
    margin: 0 3.1rem 0 0;
}

.category {
    display: block;
    max-width: fit-content;
    border: .1rem solid;
    padding: 0 1.5rem;
    font-size: 1.4rem;
    font-weight: 600;
    letter-spacing: 0.05em;
    text-align: center;
    word-break: keep-all;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */

@media screen and (width <= 1920px) {

}

/* ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆ */
/* ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆ */

/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */

@media screen and (width <= 1550px) {

}

/* ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆ */
/* ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆ */

/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */

@media screen and (width <= 1024px) {

    .cover-logo {
        width: 45%;
    }

    .cover-logo-block {
        top: 28%;
    }

    .cover-title {
        top: -4.5rem;
    }

    .scroll-link {
        width: 0.8%;
    }


    .top01-img02 {
        width: 48%;
        margin: 20rem 0 0 0;
    }

    .top01-text-row {
        margin: 0 7.3rem 0 0;
    }

    .top01-text-box01 {
        margin: 0;
    }

    .top01-text-box02 {
        margin: 6.4rem 7.8rem auto auto;
    }

    .top01-text-box .text02 {
        line-height: 2.2em;
    }

    .top02-img-box01 {
        top: -5%;
    }

    .top02-img-box01:after, .top02-img-box01:before {
        bottom: -1.3rem;
    }

    .top03 {
        padding: 0 0 12rem 0;
    }

    .top03-right {
        margin: 0;
    }
    
    .top04-left {
        width: 55%;
    }

    .top04-img {
        width: 45%;
    }

    .top05-text-block {
        margin: 0 7rem 0 auto;
    }

}

/* ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆ */
/* ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆ */

/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */

@media screen and (width <= 768px) {

    .cover-logo-block {
        top: 37%;
    }

    .cover-logo {
        width: 56%;
    }

    .cover-navi-block {
        display: none;
    }

    .scroll-link {
        width: 2%;
    }

    .top01-wrapper:after {
        width: 100%;
    }

    .top01-row {
        flex-direction: column-reverse;
        align-items: center;
    }

    .top01-img02 {
        max-width: 50rem;
        width: 100%;
        margin: 5rem 0 0 0;
    }

    .top01-text-row {
        max-width: 43rem;
        width: 98%;
        margin: 0 auto;
    }

    .top01-text-box02 {
        margin: 13.4rem 0 0 0;
    }

    .top02-wrapper {
        padding: 10rem 0 8rem;
    }

    .top02-img-box01 {
        width: 46%;
    }

    .top02-img02 {
        width: 40%;
    }

    .top03 {
        padding: 0 0 8rem 0;
    }

    .top03-row {
        flex-direction: column;
    }

    .top03-img-box01 {
        width: 67%;
    }

    .top03-right {
        width: 100%;
        margin: 6rem auto 0;
    }

    .top03-img02 {
        width: 80%;
        margin: 0 0 0 auto;
    }

    .top04-row {
        flex-direction: column-reverse;
    }
    
    .top04-left {
        width: 100%;
        padding: 8rem 1.5rem;

    }

    .top04-text-block .title01 {
        text-align: center;
    }

    .top04-text-box {
        margin: 4rem 0 0;
    }   

    .top04-btn {
        margin: 4rem auto 0;
    }


    .top04-img {
        width: 100%;
        min-height: auto;
    }

    .top04-img img {
        position: static;
    }

    
    .top05-frame {
        padding: 8rem 0;
    }

    .top05-text-block {
        margin: 0 auto;
    }

    .top05-text-block .title01 {
        text-align: center;
    }

    .top05-btn {
        margin: 4rem auto 0;
    }

    .top06 {
        padding: 8rem 0;
    }

    .top06-row {
        flex-direction: column;
        align-items: center;
    }
    
    .top06-right {
        margin: 4rem auto 0;
        width: 100%;
    }

}

/* ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆ */
/* ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆ */

/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */

@media screen and (width <= 576px) {

    .cover-logo-block {
        top: 0;
        bottom: 0;
        width: 60%;
    }

    .cover-logo {
        width: 43%;
    }

    .cover-title {
        top: -5rem;
        font-size: 3rem;
    }

    .top01-img01 {
        width: 58%;
    }

    .top01-wrapper:after {
        content: none;
    }

    .top02-img03 img {
        padding: 0 0 60rem 0;
        background: #181a21;
    }

    .top01-img02 {
        margin: 8rem 0 0 0;
    }

    .top01-text-row {
        margin: -5rem auto 0;
    }

    .top01-text-box01 {
        margin: 0 0 0 auto;
    }

    .top02-wrapper {
        padding: 10rem 0 5rem
    }

    .top02-text-frame {
        margin: 28rem auto 0;
    }

    .top02-img-box01 {
        width: 65%;
        top: -9%;
    }

    .top02-img01 {
        width: 60%;
    }

    .top02-img02 {
        position: absolute;
        width: 60%;
        top: 14%;
        left: 0;
        z-index: 5;
    }

    .top02-title-box .title01 br {
        display: block;
    }

    .top02-title-box:after {
        bottom: -2.2rem;
    }

    .top02-text {
        text-align: left;
    }

    .top03-img-box01 {
        width: 85%;
    }
    
    .top03-img02 {
        width: 90%;
    }

    .top05-text {
        font-size: 2rem;
    }

}

/* ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆ */
/* ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆ */