@charset "UTF-8";
/* Scss Document */ :root {
    --min-size: 100px;
    --clamp-vw: 18vw;
}
@media (max-width: 1024px) {
    :root {
        --min-size: 60px;
        --clamp-vw: 10vw;
    }
}
.padding100 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 100px);
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 100px);
}
.padding110 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 110px);
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 110px);
}
.padding120 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 120px);
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 120px);
}
.padding130 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 130px);
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 130px);
}
.padding140 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 140px);
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 140px);
}
.padding150 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 150px);
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 150px);
}
.padding160 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 160px);
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 160px);
}
.padding170 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 170px);
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 170px);
}
.padding180 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 180px);
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 180px);
}
.padding190 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 190px);
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 190px);
}
.padding200 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 200px);
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 200px);
}
.padding210 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 210px);
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 210px);
}
.padding220 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 220px);
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 220px);
}
.padding230 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 230px);
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 230px);
}
.padding240 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 240px);
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 240px);
}
.padding250 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 250px);
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 250px);
}
.padding260 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 260px);
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 260px);
}
.padding270 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 270px);
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 270px);
}
.padding280 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 280px);
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 280px);
}
.padding290 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 290px);
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 290px);
}
.padding300 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 300px);
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 300px);
}
.margin100 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 100px);
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 100px);
}
.margin110 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 110px);
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 110px);
}
.margin120 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 120px);
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 120px);
}
.margin130 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 130px);
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 130px);
}
.margin140 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 140px);
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 140px);
}
.margin150 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 150px);
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 150px);
}
.margin160 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 160px);
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 160px);
}
.margin170 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 170px);
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 170px);
}
.margin180 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 180px);
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 180px);
}
.margin190 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 190px);
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 190px);
}
.margin200 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 200px);
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 200px);
}
.margin210 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 210px);
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 210px);
}
.margin220 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 220px);
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 220px);
}
.margin230 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 230px);
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 230px);
}
.margin240 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 240px);
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 240px);
}
.margin250 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 250px);
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 250px);
}
.margin260 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 260px);
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 260px);
}
.margin270 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 270px);
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 270px);
}
.margin280 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 280px);
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 280px);
}
.margin290 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 290px);
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 290px);
}
.margin300 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 300px);
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 300px);
}
.pt-110 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 110px);
}
.pt-120 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 120px);
}
.pt-130 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 130px);
}
.pt-140 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 140px);
}
.pt-150 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 150px);
}
.pt-160 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 160px);
}
.pt-170 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 170px);
}
.pt-180 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 180px);
}
.pt-190 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 190px);
}
.pt-200 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 200px);
}
.pt-210 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 210px);
}
.pt-220 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 220px);
}
.pt-230 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 230px);
}
.pt-240 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 240px);
}
.pt-250 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 250px);
}
.pt-260 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 260px);
}
.pt-270 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 270px);
}
.pt-280 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 280px);
}
.pt-290 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 290px);
}
.pt-300 {
    padding-top: clamp(var(--min-size), var(--clamp-vw), 300px);
}
.pb-110 {
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 110px);
}
.pb-120 {
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 120px);
}
.pb-130 {
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 130px);
}
.pb-140 {
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 140px);
}
.pb-150 {
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 150px);
}
.pb-160 {
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 160px);
}
.pb-170 {
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 170px);
}
.pb-180 {
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 180px);
}
.pb-190 {
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 190px);
}
.pb-200 {
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 200px);
}
.pb-210 {
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 210px);
}
.pb-220 {
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 220px);
}
.pb-230 {
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 230px);
}
.pb-240 {
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 240px);
}
.pb-250 {
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 250px);
}
.pb-260 {
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 260px);
}
.pb-270 {
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 270px);
}
.pb-280 {
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 280px);
}
.pb-290 {
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 290px);
}
.pb-300 {
    padding-bottom: clamp(var(--min-size), var(--clamp-vw), 300px);
}
.mt-110 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 110px);
}
.mt-120 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 120px);
}
.mt-130 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 130px);
}
.mt-140 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 140px);
}
.mt-150 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 150px);
}
.mt-160 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 160px);
}
.mt-170 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 170px);
}
.mt-180 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 180px);
}
.mt-190 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 190px);
}
.mt-200 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 200px);
}
.mt-210 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 210px);
}
.mt-220 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 220px);
}
.mt-230 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 230px);
}
.mt-240 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 240px);
}
.mt-250 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 250px);
}
.mt-260 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 260px);
}
.mt-270 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 270px);
}
.mt-280 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 280px);
}
.mt-290 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 290px);
}
.mt-300 {
    margin-top: clamp(var(--min-size), var(--clamp-vw), 300px);
}
.mb-110 {
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 110px);
}
.mb-120 {
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 120px);
}
.mb-130 {
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 130px);
}
.mb-140 {
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 140px);
}
.mb-150 {
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 150px);
}
.mb-160 {
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 160px);
}
.mb-170 {
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 170px);
}
.mb-180 {
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 180px);
}
.mb-190 {
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 190px);
}
.mb-200 {
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 200px);
}
.mb-210 {
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 210px);
}
.mb-220 {
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 220px);
}
.mb-230 {
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 230px);
}
.mb-240 {
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 240px);
}
.mb-250 {
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 250px);
}
.mb-260 {
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 260px);
}
.mb-270 {
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 270px);
}
.mb-280 {
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 280px);
}
.mb-290 {
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 290px);
}
.mb-300 {
    margin-bottom: clamp(var(--min-size), var(--clamp-vw), 300px);
}
a, a:hover, a:focus, a:active, a:visited, a:focus-visible {
    text-decoration: none;
}
/************************/
.top_main {
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    height: 105vh;
    overflow: hidden;
}
.top_main_content {
    width: 90%;
    margin: 0 auto;
    position: relative;
    z-index: 500;
    text-align: center;
    padding-bottom: 110px;
}
.top_main_title {
    font-size: clamp(20px, 1.9vw, 24px);
    font-weight: 500;
    letter-spacing: 0.2em;
    margin-top: 90px;
}
.top_main_title .letter {
    letter-spacing: -0.13em;
}
.top_main_absolute {
    position: absolute;
    bottom: 0;
    left: 0;
    z-index: 500;
}
.textMoveWrap {
    display: flex;
    width: fit-content;
    animation: scrollLeft 25s linear infinite;
}
.textMove {
    white-space: nowrap;
    font-size: 150px;
    color: #a4a4a4;
    opacity: 0.2;
    letter-spacing: 0;
    white-space: nowrap;
    padding-right: 100px;
}
@keyframes scrollLeft {
    0% {
        transform: translateX(0);
    }
    100% {
        transform: translateX(-50%);
    }
}
.top_main_bg_left {
    position: absolute;
    top: 0;
    left: 0;
    width: 85%;
}
.top_main_bg_left img {
    max-width: 100%;
    height: auto;
}
.top_main_bg_right {
    position: absolute;
    top: 0;
    right: 0;
    text-align: right;
    width: 80%;
}
.top_main_bg_right img {
    max-width: 100%;
    height: auto;
}
/*******************************/
.title_eng {
    font-size: clamp(35px, 4.2vw, 48px);
    background: url("../images/title_logo.webp") 50% 50%/100px 105px no-repeat;
    height: 105px;
    display: flex;
    justify-content: center;
    align-items: center;
    letter-spacing: 0.1em;
}
.title_32 {
    font-size: clamp(24px, 2.6vw, 32px);
}
.center {
    text-align: center;
    font-weight: 500;
}
.top01_text {
    margin-top: 45px;
    text-align: center;
}
.top01_text p {
    line-height: 2.2em;
}
.top01_text p:nth-child(n+2) {
    margin-top: 40px;
}
.top01_img {
    text-align: center;
    margin-top: 50px;
}
.top01_bg_left {
    position: absolute;
    left: 0;
    bottom: -670px;
    width: 80%;
}
.top01_bg_left img {
    max-width: 100%;
    height: auto;
}
.top01_bg_right {
    position: absolute;
    right: 0;
    top: -470px;
    width: 90%;
    text-align: right;
}
.top01_bg_right img {
    max-width: 100%;
    height: auto;
}
/**パターン2****/
.top01_img_left2 {
    position: absolute;
    bottom: -70px;
    left: 0;
    width: 28%;
}
.top01_img_left2 img {
    max-width: 100%;
    height: auto;
}
.top01_img_right2 {
    position: absolute;
    bottom: -70px;
    right: -20px;
    width: 28%;
    text-align: right;
}
.top01_img_right2 img {
    max-width: 100%;
    height: auto;
}
/*******************************/
.title_24 {
    font-size: clamp(20px, 1.8vw, 24px);
}
.top02_grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    column-gap: 40px;
    row-gap: 40px;
}
.top02_grid > div {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}
.top02_grid h3 {
    display: flex;
    justify-content: center;
    font-size: 24px;
    margin-bottom: 30px;
    column-gap: 10px;
}
.top02_grid h3 span {
    font-size: 28px;
    letter-spacing: 0;
    position: relative;
    top: 1px;
}
.top02_grid p {
    text-align: center;
}
.top02_img {
    margin-top: 30px;
    text-align: center;
}
.top02_img img {
    max-width: 100%;
    height: auto;
}
/*******************************/
.top03_grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    column-gap: 40px;
    row-gap: 80px;
    max-width: 860px;
    margin-left: auto;
    margin-right: auto;
}
.top03_grid > div {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}
.top03_grid h3 {
    font-size: 32px;
    margin-bottom: 10px;
    text-align: center;
}
.top03_grid p {
    text-align: center;
}
.top03_mini {
    margin-top: 10px;
    font-size: 14px;
}
.top03_img {
    margin-top: 30px;
    text-align: center;
}
.top03_img img {
    max-width: 100%;
    height: auto;
}
/****************************/
.eng_48 {
    font-size: clamp(35px, 4vw, 48px);
    letter-spacing: 0.1em;
}
.top04_sns {
    display: flex;
    justify-content: center;
    align-items: center;
    column-gap: 50px;
}
.top04_sns img {
    transition: 0.3s ease;
}
.top04_sns a:hover img {
    transform: scale(0.9);
}
.top04_bg_left {
    position: absolute;
    bottom: -80px;
    left: 0;
    width: 65%;
}
.top04_bg_left img {
    max-width: 100%;
    height: auto;
}
.top04_bg_right {
    position: absolute;
    bottom: 200px;
    right: 0;
    text-align: right;
    width: 60%;
}
.top04_bg_right img {
    max-width: 100%;
    height: auto;
}
.title_24 {
    font-size: clamp(20px, 1.8vw, 24px);
}
/****************************/
.top05 {
    background: url(../images/top05_bg.webp) center / 100% no-repeat;
    background-position-y: 23%;
}
.top05_planName {
    border: 1px solid #202020;
    padding: 15px 2vw;
    display: grid;
    grid-template-columns: 28% 40% 28%;
    align-items: center;
    justify-content: space-between;
    gap: 15px;
    div:nth-child(1) {
        position: relative;
        display: flex;
        align-items: center;
        gap: 15px;
    }
    div:nth-child(1):after {
        content: "";
        position: absolute;
        top: 50%;
        right: 41%;
        transform: translateY(-45%);
        width: 2px;
        height: 32px;
        background-color: #202020;
    }
    div:nth-child(2) {
        letter-spacing: 0.1em;
        text-align: center;
    }
    div:nth-child(3) {
        font-size: 14px;
        letter-spacing: 0.2em;
        text-align: end;
    }
}
.top05_grid01 {
    display: grid;
    grid-template-columns: 51% 42%;
    justify-content: space-between;
    gap: 2vw;
    align-items: end;
    .price_box {
        text-align: end;
    }
}
.top05_grid02 {
    border: 1px solid #b1b1b1;
    padding: 45px 4vw;
    display: grid;
    align-items: center;
    grid-template-columns: 151px 1fr;
    gap: 2vw;
    .left {
        width: 100%;
        max-width: 151px;
        height: 151px;
        border: 1px solid #202020;
        border-radius: 50%;
        display: flex;
        align-items: center;
        justify-content: center;
        line-height: normal;
        text-align: center;
        font-weight: 700;
    }
    .grid_box {
        display: flex;
        align-items: center;
        gap: 10px;
        div {
            text-align: center;
            letter-spacing: 0.03em;
        }
        div:nth-child(1) {
            background-color: #f8f8f8;
            padding: 15px 1vw;
            text-align: center;
            p {
                line-height: 1.4em;
            }
            .title_20 {
                font-weight: 700;
            }
        }
        div:nth-child(2) {
            font-weight: 700;
            font-size: 30px;
        }
        div:nth-child(3) {
            background-color: #f8f8f8;
            padding: 15px 1vw;
            text-align: center;
            p {
                line-height: 1.4em;
            }
            .title_20 {
                font-weight: 700;
            }
        }
        div:nth-child(4) {
            font-weight: 700;
            font-size: 30px;
        }
        div:nth-child(5) {
            background-color: #f8f8f8;
            padding: 15px 1vw;
            text-align: center;
            p {
                line-height: 1.4em;
            }
            .title_20 {
                font-weight: 700;
            }
        }
    }
    .text {
        color: #636363;
        font-size: 14px;
        display: flex;
        align-items: baseline;
        span {
            display: block;
        }
    }
}
.plan_nextBorder {
    margin: 50px auto;
    background-color: #202020;
    width: 1px;
    height: 80px;
}
.top05_img_grid01 {
    display: grid;
    grid-template-columns: 42.5% 53.5%;
    justify-content: space-between;
    gap: 3%;
}
.top05_img_grid02 {
    display: grid;
    grid-template-columns: 53.5% 42.8%;
    justify-content: space-between;
    gap: 3%;
}
.top05_img_grid03 {
    display: grid;
    grid-template-columns: 48% 48%;
    justify-content: space-between;
    gap: 3%;
}
#yoyaku_btn {
    position: relative;
    z-index: 10;
    width: 80%;
    max-width: 640px;
    height: 100px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto;
    border: 1px solid #202020;
    letter-spacing: 0.3em;
    color: #202020;
    font-weight: 500;
    padding-right: 25px;
    transition: .3s;
    i {
        position: absolute;
        top: 50%;
        right: 16%;
        transform: translateY(-50%);
        background-image: url(../images/btn_icon01.webp);
        width: 24px;
        height: 24px;
    }
}
#yoyaku_btn:after {
    content: "";
    position: absolute;
    top: 7px;
    left: -15px;
    background-color: #202020;
    width: 45px;
    height: 1px;
    transform: rotateZ(-45deg);
}
#yoyaku_btn:hover {
    opacity: 0.5;
}
.title_20 {
    font-size: clamp(17px, 1.9vw, 20px);
}
.title_28 {
    font-size: clamp(22px, 2.3vw, 28px);
}
.title_32 {
    font-size: clamp(24px, 2.5vw, 32px);
}
.title_36 {
    font-size: clamp(26px, 2.8vw, 36px);
}
.title_48 {
    font-size: clamp(30px, 3.8vw, 48px);
}
.bold {
    font-weight: 700;
}
/******************/
.footer {
    background-color: #ffdceb;
    padding: 45px 0;
    margin-top: 120px;
}
.f_flex {
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 94%;
    max-width: 1760px;
    margin: 0 auto;
}
.copy_right span {
    border-bottom: 1px solid #202020;
}
.tel_text {
    text-align: center;
    font-size: clamp(16px, 2.4vw, 28px);
    span {
        font-size: clamp(40px, 4.4vw, 48px);
    }
    a {
        color: inherit;
    }
}
/***information**************************/
.store_table > div {
    display: flex;
    justify-content: space-between;
}
.store_table > div.none {
    display: none;
}
.store_table p {
    color: #3e3d3b;
    letter-spacing: 0.14em;
    line-height: 2.2em;
}
.store_table a {
    color: inherit;
}
.store_cell1 {
    width: 250px;
    padding: 35px 10px;
    border-bottom: 1px solid #222222;
}
.store_cell2 {
    width: calc(100% - 290px);
    padding: 35px 10px;
    border-bottom: 1px solid #a0a0a0;
}
.store_map iframe {
    width: 100%;
    height: clamp(300px, 50vw, 530px);
}

/*2025/10/24*/

.studio_grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 2vw;
}

.title_22 {
    font-size: clamp(18px, 1.8vw, 22px);
}

.top06 {
    .top05_planName {
        background-color: #eaf0c9;
        border: none;

        div:nth-child(1):after {
            right: 12%;
            transform: translateY(-50%);
        }
        .title_22 {
            letter-spacing: 0.1em;
        }
    }
    .top05_grid01 {
        grid-template-columns: 48% 45%;

        .font16 {
            display: inline-block;
            text-align: center;
            font-size: 16px;
            line-height: 1.2em;
        }
    }

    .top06_grid02 {
        border: 1px solid #b1b1b1;
        padding: 45px 4vw;
        display: grid;
        align-items: center;
        grid-template-columns: 151px 1fr;
        gap: 2vw;

        .left {
            background-color: #fffaac;
            border: none;
            width: 100%;
            max-width: 151px;
            height: 151px;
            border-radius: 50%;
            display: flex;
            align-items: center;
            justify-content: center;
            line-height: normal;
            text-align: center;
            font-weight: 700;
        }
        .bg_gray {
            background-color: #f8f8f8;
            text-align: center;
            display: flex;
            align-items: center;
            justify-content: center;
            border-radius: 3px;
            padding: 20px 0;
        }
    }

    .top06_grid02.one_cut_plan {
        .grid_box {
            display: grid;
            grid-template-columns: 48% 40%;
            align-items: center;
            gap: 1.5vw;

            .c-636363 {
                font-size: 14px;
                color: #636363;
                display: flex;
                align-items: baseline;
                gap: 2px;
            }
        }
    }

    .top06_grid02.wedding_plan {
        .grid_box {
            display: flex;
            flex-wrap: wrap;
            align-items: center;
            gap: 1vw;

            div:nth-child(2) {
                font-weight: 700;
                font-size: 30px;
            }

            .bg_gray {
                padding: 20px;
                height: -webkit-fill-available;
            }
        }

        .c-636363 {
            font-size: 14px;
            color: #636363;
        }
    }
}

.loop_contents {
    display: grid;
    gap: 2.2%;
}

/*loop img*/
.loop_img {
  overflow: hidden;
  width: 100%;
}

.loop_img ul {
  display: flex;
  width: max-content;
}

.loop_img.top ul {
  animation: loop_left 40s linear infinite;
}
.loop_img.bottom ul {
  animation: loop_right 40s linear infinite;
}

.loop_img li {
  white-space: nowrap;
  width: max-content;
  margin: 0 0.18%;
}

.loop_img li img {
  width: 100%;
  max-width: clamp(350px, 33vw, 620px);
}

/* アニメーション */
@keyframes loop_left {
  0% {
    transform: translateX(0%);
  }
  100% {
    transform: translateX(-50%);
  }
}

@keyframes loop_right {
  0% {
    transform: translateX(-50%);
  }
  100% {
    transform: translateX(0%);
  }
}





/* PC用
------------------------------------------------------------*/
@media only screen and (max-width: 1699px) and (min-width: 1025px) {
    .top_main {
        height: 125vh;
    }
}
@media only screen and (max-width: 1024px) {
    .top01_bg_left {
        bottom: -500px;
    }
    .top01_bg_right {
        top: -300px;
    }
    /*******************************/
    .top02_grid h3 {
        font-size: 20px;
    }
    .top02_grid h3 span {
        font-size: 24px;
    }
    .top02_grid p {
        font-size: 14px;
    }
}
@media only screen and (max-width: 768px) {
    /************************/
    .top_main {
        height: 600px;
    }
    .top_main_content {
        padding-bottom: 60px;
    }
    #logo img {
        width: 200px;
        height: auto;
    }
    .top_main_title {
        font-size: 18px;
        margin-top: 40px;
        line-height: 2em;
    }
    .textMove {
        font-size: 80px;
    }
    /*******************************/
    .top01_text {
        margin-top: 40px;
    }
    .top01_text p:nth-child(n+2) {
        margin-top: 30px;
    }
    .top01_img img {
        width: 100%;
        max-width: 300px;
        height: auto;
    }
    .top01_bg_left {
        bottom: -300px;
        width: 90%;
    }
    .top01_bg_right {
        top: -200px;
    }
    /**パターン2****/
    .top01_sp_flex {
        display: flex;
        justify-content: space-between;
        margin-top: 30px;
    }
    .top01_img_left2 {
        position: static;
        width: 48%;
    }
    .top01_img_right2 {
        position: static;
        width: 48%;
    }
    /*******************************/
    .title_24 {
        font-size: 24px;
    }
    .top02_grid {
        display: grid;
        grid-template-columns: repeat(1, 1fr);
        column-gap: 0;
        row-gap: 60px;
    }
    .top02_grid h3 {
        font-size: 22px;
        margin-bottom: 25px;
    }
    .top02_grid h3 span {
        font-size: 26px;
    }
    .top02_grid p {
        font-size: 17px;
        text-align: center;
        position: relative;
        z-index: 500;
    }
    .top02_img {
        margin-top: -15px;
        text-align: center;
    }
    .top02_img img {
        max-width: 270px;
        height: auto;
    }
    .top02_sp_mt {
        margin-top: 30px;
    }
    /*******************************/
    .top03_grid {
        display: grid;
        grid-template-columns: repeat(1, 1fr);
        column-gap: 20px;
        row-gap: 40px;
        max-width: 860px;
        margin-left: auto;
        margin-right: auto;
    }
    .top03_grid > div {
        display: flex;
        flex-direction: column;
        justify-content: space-between;
    }
    .top03_grid h3 {
        font-size: 28px;
        margin-bottom: 10px;
        text-align: center;
    }
    .top03_grid p:not(.top03_mini) {
        text-align: center;
        position: relative;
        z-index: 500;
        font-size: 20px;
    }
    .top03_img {
        margin-top: 15px;
        text-align: center;
    }
    .top03_img img {
        max-width: 240px;
        height: auto;
    }
    /****************************/
    .top04_sns {
        column-gap: 20px;
    }
    .top04_sns img {
        transform: scale(0.7);
    }
    .top04_bg_left {
        bottom: -80px;
        width: 55%;
    }
    .top04_bg_right {
        bottom: 150px;
        width: 70%;
    }
    /******************/
    .top05_planName {
        padding: 15px 4vw;
        grid-template-columns: repeat(1, 1fr);
        gap: 0;
    }
    .top05_planName {
        div:nth-child(2) {
            text-align: start;
        }
    }
    .top05_planName {
        div:nth-child(1):after {
            display: none;
        }
    }
    .top05_planName {
        div:nth-child(1) {
            gap: 5px;
        }
    }
    .top05_planName {
        div:nth-child(3) {
            padding-top: 15px;
        }
    }
    .top05_grid01 {
        grid-template-columns: repeat(1, 1fr);
        gap: 35px;
    }
    .top05_grid02 {
        padding: 35px 4vw;
        grid-template-columns: repeat(1, 1fr);
        gap: 25px;
    }
    .top05_grid02 {
        .left {
            margin: 0 auto;
        }
    }
    .top05_grid02 {
        & .grid_box {
            gap: 5px;
            div:nth-child(1) {
                padding: 20px 2vw;
            }
        }
    }
    .top05_grid02 {
        .text {
            padding-top: 5px;
        }
    }
    .top05_grid02 {
        & .grid_box {
            & div:nth-child(1) {
                p:nth-child(2) {
                    font-size: 15px;
                }
            }
        }
    }
    .top05_grid02 {
        & .grid_box {
            & div:nth-child(3) {
                padding: 20px 2vw;
                p:nth-child(2) {
                    font-size: 15px;
                }
            }
        }
    }
    .top05_grid02 {
        & .grid_box {
            & div:nth-child(5) {
                padding: 20px 2vw;
                p:nth-child(2) {
                    font-size: 15px;
                }
            }
        }
    }
    .plan_nextBorder {
        margin: 30px auto;
        height: 65px;
    }
    .top05_grid02.last {
        .grid_box {
            gap: 10px;
            flex-wrap: wrap;
        }
    }
    .top05_grid02.last {
        & .grid_box {
            div:nth-child(5) {
                width: 100%;
            }
        }
    }
    .top05_grid02.last {
        & .grid_box {
            div:nth-child(4) {
                width: 100%;
                text-align: center;
            }
        }
    }
    #yoyaku_btn {
        max-width: 640px;
        height: 90px;
        padding-right: 20px;
        font-size: 20px;
    }
    #yoyaku_btn {
        i {
            right: 5%;
            width: 24px;
            height: 24px;
        }
    }
    /******************/
    .footer {
        background-color: #ffdceb;
        padding: 40px 0;
        margin-top: 60px;
    }
    .f_flex {
        display: block;
        width: 90%;
        text-align: center;
    }
    .f_logo img {
        width: 200px;
        height: auto;
    }
    .copy_right {
        margin-top: 30px;
    }
    /***information**************************/
    .store_table p {
        letter-spacing: 0.14em;
        line-height: 2em;
        font-size: 15px;
    }
    .store_cell1 {
        width: 140px;
        padding: 20px 5px;
    }
    .store_cell2 {
        width: calc(100% - 150px);
        padding: 20px 5px;
    }

    /*2025/10/24*/
    .studio_grid {
        grid-template-columns: repeat(1, 1fr);
        gap: 45px;
    }
    .top06 {
        .top05_grid01 {
            grid-template-columns: repeat(1, 1fr);
        }
    }
    .top06 {
        .top06_grid02 {
            grid-template-columns: repeat(1, 1fr);
            gap: 35px;
            padding: 35px 4vw;

            .left {
                margin: 0 auto;
            }
        }
    }
    .top06 {
        & .top06_grid02.wedding_plan {
            .grid_box {
                gap: 10px;
                width: 88%;
                margin: 0 auto;
                display: grid;
                text-align: center;
            }
        }
    }
    .top06 {
        & .top06_grid02.one_cut_plan {
            .grid_box {
                gap: 10px;
                width: 88%;
                margin: 0 auto;
                display: grid;
                grid-template-columns: repeat(1, 1fr);
            }
        }
    }
    .top06 {
        & .top06_grid02.wedding_plan {
            .c-636363 {
                width: 88%;
                margin: 0 auto;
            }
        }
    }

}
/* スマートフォン 縦(ポートレート) */