html, body {
    overflow: visible;
}

.site-header, .site-footer,.site-body-bottom {
    display: none !important;
}

@media screen and (min-width: 992px) {
    .d-pc-none {
        display: none !important;
    }
}
@media screen and (max-width: 991px) {
    .d-sp-none {
        display: none !important;
    }
}

.site-body {
    padding-top: 0;
    padding-bottom: 0;
    padding-left: 50%;
}

@media screen and (max-width: 991px) {
    .site-body {
        display: block;
        padding-left: 0;
        /*padding-bottom: 75vw;
        background: url("../imgs/logo-green.svg") center bottom 5vw/75vw no-repeat;    */
    }
}

.site-body--left {
    position: fixed;
    height: 100dvh;
    overflow: hidden;
    width: 50%;
    left: 0;
    background: var(--green);
}

@media screen and (max-width: 991px) {
    .site-body--left {
        height: 100dvh;
        width: 100vw;
        display: flex;
        overflow: scroll;
        position: fixed;
        bottom: 0;
        left: 0;
        z-index: 10;
        scroll-behavior: smooth;
    }
}

.site-body--left .pageAnchors {
    position: absolute;
    bottom: 1em;
    left: 0;
    width: 100%;
    display: flex;
    gap: .5em;
    justify-content: center;
    padding: 0;
    margin: 0;
}

@media screen and (min-width: 992px) {
    .site-body--left .pageAnchors {
        display: none;
    }
}

.site-body--left--section {
    position: absolute;
    top: 0;
    width: 100%;
    height: 100%;
    transform-origin: left;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    background: var(--green);
    box-shadow: 4px 4px 8px rgba(0,0,0,.9);
    transform: rotateY(-180deg) skewX(-30deg);
    opacity: 0;
}
.site-body--left--section.is-active{
    transform: none;
    transition: all 1.8s ease-out;
    box-shadow: 0 0 8px rgba(0,0,0,0);
    opacity: 1;
}

@media screen and (max-width: 991px) {
    .site-body--left--section {
        position: sticky;
        height: 100%;
        flex: 100vw 0 0;
        left: 0;
        top: 0;
        overflow: hidden;
        opacity: 1;
        transform: none;
    }
}

.site-body--left--section--inner {
    width: 90%;
    text-align: center;
}

@media screen and (max-width: 991px) {
    .site-body--left--section--inner {
        display: flex;
        flex-direction: row-reverse;
        justify-content: center;
        text-align: left;
        position: relative;
        padding-bottom: 6rem;
    }
}

@media screen and (max-width: 991px) {
    .site-body--left--text {
        writing-mode: tb;
    }
}

.site-body--left--svg {

    max-width: 100%;
    max-height: 40dvh;
}

@media screen and (max-width: 991px) {
    .site-body--left--svg {
        max-height: 60vw;
    }
}

.site-body--logo {
    width: 70%;
    margin: 0 auto;
}

.site-body--right {
    color: var(--green);
    position: relative;
}
.ehonTrigger{
    position: absolute;
    width: 100%;
    height: 1px;
    pointer-events: none;
}
#ehonTrigger0 {
    top: -33px;/* WPの管理バーがあっても動作するように-33px */
}
#ehonTrigger1{
    top: 12.5%;
}
#ehonTrigger2{
    top: 25%;
}
#ehonTrigger3{
    top: 37.5%;
}
#ehonTrigger4{
    top: 50%;
}
#ehonTrigger5{
    top: 62.5%;
}
#ehonTrigger6{
    top: 75%;
}
#ehonTrigger7{
    bottom: 0;
}
@media screen and (max-width: 991px) {
    .site-body--right {
        height: auto;
    }
}

.site-body--right a {
    color: currentColor;
}

@media (min-width: 992px) {
    .container-righthalf {
        max-width: 480px;
    }
}

@media (min-width: 1200px) {
    .container-righthalf {
        max-width: 570px;
    }
}

.site-body--right--section1 {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    height: 100dvh;
}

@media screen and (max-width: 991px) {
    .site-body--right--section1 {
        height: auto;
        padding-top: 8rem;
        padding-bottom: 8rem;
        color: #fff;
        background: var(--green);
        width:100vw;
        margin-left:calc( ( 100% - 100vw ) / 2 );
    }
}
@media screen and (max-width: 767px) {
    .site-body--right--section1 {
        margin-left: -15px;
        margin-right: -15px;
        width: auto;
    }
}

.site-body--right--section1--logo {
    width: min(25rem, 60%);
    margin: 0 auto;
}
@media screen and (max-width: 991px){
    .site-body--right--section1--logo{
        width: 70vw;
        margin-top: 0 !important;
    }
}
.site-body--left--sectionlast--bg {
    width: 70%;
    right: -30%;
    top: 10%;
    position: absolute;
    opacity: 0;
}
@media screen and (max-width: 991px){
    .site-body--left--sectionlast--bg{
        transform: rotate(90deg);
        right: -14%;
        top: auto;
        bottom: 20%;
        width: 70%;
        opacity: 1;
    }
}
.site-body--left--section.is-active .site-body--left--sectionlast--bg{
    opacity: 1;
    transition: opacity .6s ease-out 1s;
}
@media screen and (max-width: 991px) {
    .site-body--left--section--inner6{
        justify-content: flex-start;
    }
    .site-body--left--p-pr{
        padding-right: 1em;
    }
    .site-body--left--salon {
        position: absolute;
        bottom: 0;
        right: 10%;
        width: 6rem;
    }
    .site-body--left--zzz{
        clip-path: inset(0 0 0 20%);
        position: absolute;
        bottom: 0;
        left: -10%;
        width: 70%;
    }
}
.ehonLastLogo{
    width: 8em;
    margin-top: 4rem;
    margin-bottom: 1rem;
}
@media screen and (min-width: 992px) {
    .ehonNext{
        display: none;
    }
}
.ehonNext{
    position: absolute;
    right: 0;
    top: 5px;
    color: currentColor;
    display: inline-flex;
    justify-content: center;
    align-items: center;
    background: rgba(0,0,0,.2);
    border-radius: 4px;
    width: 34px;
    height: 34px;
    font-size: 5vw;
}
.ehonNext:after{
    content: '次のページ';
    font-size: .8rem;
    position: absolute;
    right: 0;
    top: 101%;
    display: inline-block;
    white-space: nowrap;
}
#ehonToggleButton{
    position: fixed;
    top: 5px;
    left: 50%;
    display: inline-block;
    width: 34px;
    height: 34px;
    background: rgba(0,0,0,.2) url("../imgs/book-closed.svg") center/auto 80% no-repeat;
    border-radius: 4px;
}
#ehonToggleButton:after{
    content: '本を閉じる';
    position: absolute;
    font-size: .8rem;
    top: 101%;
    white-space: nowrap;
    left: -1em;
    color: #fff;
}
@media screen and (min-width: 992px) {
    #ehonToggleButton,.ehonNext {
        display: none;
    }
}
#ehonWrapper {
    transition: all .8s;
}
@media screen and (max-width: 991px){
    #ehonWrapper {
        pointer-events: none;
        opacity: 0;
        transition: opacity .4s ease-out;
    }
    #ehonWrapper.ehonOpened{
        pointer-events: auto;
        opacity: 1;
        transition: opacity .8s ease-out;
    }
    .ehonlink-figure{
        max-width: 70%;
        transform-origin: right bottom;
        transform: rotate(3deg);
    }
}
/*#ehonWrapper.ehonClosed{
    height: 0;
}
#ehonWrapper.ehonClosed #ehonToggleButton{
    bottom: 0;
    background-image: url("../imgs/book-open.svg");
    transition: bottom .8s;
    background-color: var(--green);
    background-size: 80% auto;
}*/