@charset "UTF-8";
@import url(https://fonts.googleapis.com/css2?family=Amiri:wght@400;700&family=Noto+Sans+JP:wght@400;500&family=Roboto:wght@500&display=swap);

main {
    background-image: none;
    background-color: #fff;
    color: #3c3c3c;
}

main .comBtn01 {
    font-family: "Noto Sans JP", sans-serif;
    font-weight: 400;
    font-size: 1.4rem;
    letter-spacing: 0.05em;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
}

a {
    color: #3c3c3c;
}

.pc_flex {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
}

.c-blue {
    color: #003764;
}

.c-red {
    color: #891313;
}

.more_link .link span {
    font-family: "Noto Sans JP", sans-serif;
    font-weight: 400;
    font-size: 1.4rem;
    letter-spacing: 0.05em;
    color: #81cddf;
    text-decoration: underline;
}

.more_link .link span.arrow {
    display: inline-block;
}

.more_link .link span.arrow::before {
    top: 1px;
    bottom: 0;
    margin: auto 0;
    right: -10px;
    border-top: 1px solid #81cddf;
    border-right: 1px solid #81cddf;
}

.no-touchevents .more_link .link:hover span {
    text-decoration: none;
}

.link_wrap {
    position: relative;
    display: block;
    width: 100%;
    height: 100%;
    z-index: 1;
}

.link_wrap .bg {
    position: relative;
    display: block;
    width: 100%;
    height: 100%;
    overflow: hidden;
}

.link_wrap .bg::after {
    position: absolute;
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: #fff;
    opacity: 0;
    -webkit-transition: 0.5s cubic-bezier(0.12, 0.76, 0.475, 0.995);
    transition: 0.5s cubic-bezier(0.12, 0.76, 0.475, 0.995);
    z-index: 10;
}

.link_wrap .bg .img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    font-family: "object-fit: cover;";
    background-size: cover;
    background-position: center center;
    -webkit-transform-style: preserve-3d;
    transform-style: preserve-3d;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    transition: border-radius 0.5s cubic-bezier(0.12, 0.76, 0.475, 0.995), -webkit-transform 0.5s cubic-bezier(0.12, 0.76, 0.475, 0.995);
    -webkit-transition: border-radius 0.5s cubic-bezier(0.12, 0.76, 0.475, 0.995), -webkit-transform 0.5s cubic-bezier(0.12, 0.76, 0.475, 0.995);
    transition: transform 0.5s cubic-bezier(0.12, 0.76, 0.475, 0.995), border-radius 0.5s cubic-bezier(0.12, 0.76, 0.475, 0.995);
    transition: transform 0.5s cubic-bezier(0.12, 0.76, 0.475, 0.995), border-radius 0.5s cubic-bezier(0.12, 0.76, 0.475, 0.995), -webkit-transform 0.5s cubic-bezier(0.12, 0.76, 0.475, 0.995);
}

.no-touchevents .link_wrap:hover .bg .img {
    -webkit-transform: scale(1.04);
    -ms-transform: scale(1.04);
    transform: scale(1.04);
}

.no-touchevents .link_wrap:hover .bg:after {
    opacity: 0.2;
}

.arrow {
    position: relative;
    display: block;
}

.arrow::before {
    position: absolute;
    content: "";
    display: inline-block;
    border-top: 1px solid #3c3c3c;
    border-right: 1px solid #3c3c3c;
    -webkit-transition: 0.3s;
    transition: 0.3s;
    z-index: 10;
    display: none !important;
}

.bnr_area {
    margin: 0 auto;
}

.bnr_area .bnr_link {
    -webkit-transition: 0.3s;
    transition: 0.3s;
}

.no-touchevents .bnr_area .bnr_link:hover {
    opacity: 0.8;
}

.bnr_area .bnr_link .img {
    width: 100%;
    vertical-align: bottom;
}

body {
    line-height: 1;
}

img {
    vertical-align: bottom;
}

.sec_ttl {
    text-align: center;
    color: #3c5028;
}

.sec_ttl .en {
    font-weight: 400;
    letter-spacing: 0.05em;
    font-size: 4rem;
    font-family: Amiri, serif;
    font-weight: 400;
}

.sec_ttl .ja {
    display: block;
    font-weight: 700;
    font-size: 1.4rem;
    letter-spacing: 0.1em;
    font-family: source-han-serif-japanese, serif;
    font-weight: 500;
    -webkit-font-feature-settings: "palt";
    font-feature-settings: "palt";
}

.sec_sttl {
    font-family: source-han-serif-japanese, serif;
    font-weight: 500;
    -webkit-font-feature-settings: "palt";
    font-feature-settings: "palt";
}

.sec_sttl.ver02 {
    text-align: center;
    -webkit-font-feature-settings: "palt";
    font-feature-settings: "palt";
}

.sec_sttl.ver02 .en {
    font-weight: 400;
    letter-spacing: 0.05em;
    font-size: 3.4rem;
    font-family: Amiri, serif;
    font-weight: 400;
    line-height: 1;
}

.sec_sttl.ver02 .ja {
    display: block;
    font-weight: 700;
    font-size: 1.4rem;
    letter-spacing: 0.1em;
    line-height: 1;
    font-family: source-han-serif-japanese, serif;
    font-weight: 500;
}

.sec_txt {
    font-family: "Noto Sans JP", sans-serif;
    font-weight: 400;
    -webkit-font-feature-settings: "palt";
    font-feature-settings: "palt";
}

.mainArea {
    -webkit-font-feature-settings: "palt";
    font-feature-settings: "palt";
}

.titleArea .sec_ttl {
    height: 6.8rem;
}

.titleArea .mainvisual {
    margin-top: 70px;
}

.titleArea .mainvisual .mainvisualImg {
    position: relative;
    height: 750px;
}

.titleArea .mainvisual .mainvisualImg img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    font-family: "object-fit: cover;";
    background-size: cover;
    background-position: center center;
    position: absolute;
    top: 0;
    left: 0;
    -o-object-position: center bottom;
    object-position: center bottom;
}

.titleArea .catchText {
    margin-top: 60px;
    text-align: center;
}

.titleArea .catchText .sec_txt {
    margin-top: 20px;
}

.venueLayoutWrap {
    padding-top: 80px;
}

.venueLayoutWrap .introductionImg {
    position: relative;
    z-index: 1;
}

.venueLayoutWrap .introductionImg img {
    display: block;
    width: 100%;
    height: auto;
}

.venueLayoutWrap .introductionText {
    padding-top: 50px;
    padding-bottom: 60px;
    background-image: url(../img/texture_bg01.png);
    text-align: center;
}

.venueLayoutWrap .introductionText .textHeading img {
    width: 200px;
    height: auto;
}

.venueLayoutWrap .introductionText .sec_sttl {
    margin-top: 28px;
    font-size: 1.9rem;
    line-height: 1.8;
}

.venueLayoutWrap .introductionText .sec_txt {
    margin-top: 24px;
}

.venueLayoutWrap .venueData {
    margin-top: 100px;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    border: 20px solid #fcfaf7;
    padding-top: 40px;
    padding-bottom: 60px;
}

.venueLayoutWrap .venueData .dataImg img {
    display: block;
    max-width: 100%;
    height: auto;
}

.venueLayoutWrap .venueData .dataText {
    font-family: "Noto Sans JP", sans-serif;
    font-weight: 400;
}

.venueLayoutWrap .venueData .dataText .textHeading {
    border-bottom: 1px solid #3c5028;
    padding-bottom: 4px;
    line-height: 1;
    font-size: 1.4rem;
    letter-spacing: 0.05em;
    font-weight: 400;
}

.venueLayoutWrap .venueData .dataText .textHeading>.en {
    color: #3c5028;
    font-family: Amiri;
    font-size: 2rem;
    letter-spacing: 0.1em;
    font-weight: 700;
}

.venueLayoutWrap .venueData .dataText .textSpec {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin-bottom: -0.25em;
    padding-top: 20px;
    font-size: 1.4rem;
    line-height: 1.8;
    letter-spacing: 0.05em;
}

.venueLayoutWrap .venueData .dataText .textSpec>* {
    -ms-flex-negative: 0;
    flex-shrink: 0;
    margin-bottom: 0.25em;
}

.venueLayoutWrap .venueData .dataText .textSpec>dt {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    width: 5em;
    padding-right: 0.5em;
    font-size: 1em;
    position: relative;
    -moz-text-align-last: justify;
    text-align-last: justify;
    color: #3c5028;
}

.venueLayoutWrap .venueData .dataText .textSpec>dt:after {
    content: "：";
    position: absolute;
    right: -0.2em;
}

.venueLayoutWrap .venueData .dataText .textSpec>dd {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    padding-left: 0.5em;
    width: calc(100% - 5em);
    font-size: 1em;
}

.venueLayoutWrap .movieArea {
    margin-top: 80px;
    padding: 15px 15px 15px 445px;
    -webkit-box-shadow: 0 1px 3px rgba(0, 0, 0, 0.15);
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.15);
    text-align: center;
    position: relative;
    z-index: 1;
}

.venueLayoutWrap .movieArea:after {
    content: "";
    display: block;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    margin: auto;
    border: 1px solid #decda7;
    position: absolute;
    top: 5px;
    left: 5px;
    bottom: 5px;
    right: 5px;
    z-index: -1;
    pointer-events: none;
}

.venueLayoutWrap .movieArea .movieCatch {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: end;
    -ms-flex-align: end;
    align-items: flex-end;
    font-family: source-han-serif-japanese, serif;
    font-weight: 500;
    color: #3c5028;
    font-size: 1.9rem;
    line-height: 1;
    letter-spacing: 0.1em;
}

.venueLayoutWrap .movieArea .movieCatch:after,
.venueLayoutWrap .movieArea .movieCatch:before {
    content: "";
    display: block;
    width: 0;
    height: 18px;
}

.venueLayoutWrap .movieArea .movieCatch:before {
    border-left: 1px solid;
    margin-right: 18px;
    -webkit-transform: rotate(-30deg);
    -ms-transform: rotate(-30deg);
    transform: rotate(-30deg);
}

.venueLayoutWrap .movieArea .movieCatch:after {
    border-right: 1px solid;
    margin-left: 18px;
    -webkit-transform: rotate(30deg);
    -ms-transform: rotate(30deg);
    transform: rotate(30deg);
}

.venueLayoutWrap .movieArea .movieHeading {
    margin-top: 10px;
    font-size: 2.4rem;
    line-height: 1.4;
    letter-spacing: 0.1em;
    font-family: source-han-serif-japanese, serif;
    font-weight: 500;
}

.venueLayoutWrap .movieArea .prt_btn02 {
    margin: 12px auto 0;
    width: 250px;
}

.venueLayoutWrap .movieArea .prt_btn02>span {
    border-radius: 5px;
}

.venueLayoutWrap .movieArea .movieAnnotation {
    margin-top: 10px;
    font-size: 1.3rem;
    line-height: 1.7;
    letter-spacing: 0.05em;
}

.venueLayoutWrap .veArea {
    margin-top: 50px;
    -webkit-box-shadow: 0 1px 3px rgba(0, 0, 0, 0.15);
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.15);
}

.venueLayoutWrap .veArea .ph_box {
    margin: 0 auto;
    background-size: cover;
}

.venueLayoutWrap .veArea .ph_box>a {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    background-color: #fff;
    position: relative;
}

.no-touchevents .venueLayoutWrap .veArea .ph_box>a:hover:after {
    -webkit-transform: rotate(-45deg) translate(6px, 6px);
    -ms-transform: rotate(-45deg) translate(6px, 6px);
    transform: rotate(-45deg) translate(6px, 6px);
}

.venueLayoutWrap .veArea .ph_box>a:after {
    content: "";
    display: block;
    margin: auto 0;
    border-width: 8px 2px 2px 8px;
    border-style: solid;
    border-color: transparent #a18100 #a18100 transparent;
    width: 0;
    height: 0;
    position: absolute;
    top: 0;
    bottom: 0;
    -webkit-transform: rotate(-45deg);
    -ms-transform: rotate(-45deg);
    transform: rotate(-45deg);
    -webkit-transition: -webkit-transform 0.5s;
    transition: -webkit-transform 0.5s;
    transition: transform 0.5s;
    transition: transform 0.5s, -webkit-transform 0.5s;
}

.venueLayoutWrap .veArea .ph_box>a:after {
    top: 0;
    bottom: 0;
    right: 2rem;
    margin: auto;
    position: absolute;
    border-right-color: #3c5028;
    border-bottom-color: #3c5028;
}

.venueLayoutWrap .veArea .ph_box .left {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    background-color: #3c5028;
}

.venueLayoutWrap .veArea .ph_box .left img {
    margin: 0 auto;
    max-width: calc(100% - 2rem);
    height: auto;
}

.venueLayoutWrap .veArea .ph_box .right {
    position: relative;
}

.venueLayoutWrap .veArea .ph_box .right .txt {
    color: #3c5028;
    text-align: center;
    font-family: source-han-serif-japanese, serif;
    font-weight: 500;
    -webkit-font-feature-settings: "palt";
    font-feature-settings: "palt";
}

.venueLayoutWrap .veArea .ph_box .right:before {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    margin: auto;
    width: calc(100% - 4rem);
    height: 1px;
    background-color: #3c5028;
}

.venueLayoutWrap .veArea .ph_box .right:after {
    content: "";
    position: absolute;
    bottom: -2rem;
    left: 0;
    right: 0;
    margin: auto;
    width: calc(100% - 4rem);
    height: 1px;
    background-color: #3c5028;
}

.galleryLayoutWrap {
    padding-top: 120px;
    padding-bottom: 150px;
}

.galleryLayoutWrap .galleryImgs {
    display: grid;
    grid-template-columns: 33.333% 16.667% 16.667% 33.333%;
    grid-template-rows: 18.18% 18.18% 18.18% 18.18% 27.28%;
    height: 2200px;
}

.galleryLayoutWrap .galleryImgs .img {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: flex-end;
    position: relative;
    z-index: 1;
    overflow: hidden;
}

.galleryLayoutWrap .galleryImgs .img:nth-child(1) {
    grid-column: 1/3;
    grid-row: 1/3;
}

.galleryLayoutWrap .galleryImgs .img:nth-child(2) {
    grid-column: 1/3;
    grid-row: 3/4;
}

.galleryLayoutWrap .galleryImgs .img:nth-child(3) {
    grid-column: 3/5;
    grid-row: 1/2;
}

.galleryLayoutWrap .galleryImgs .img:nth-child(4) {
    grid-column: 3/5;
    grid-row: 2/4;
}

.galleryLayoutWrap .galleryImgs .img:nth-child(5) {
    grid-column: 1/2;
    grid-row: 4/5;
}

.galleryLayoutWrap .galleryImgs .img:nth-child(6) {
    grid-column: 2/4;
    grid-row: 4/5;
}

.galleryLayoutWrap .galleryImgs .img:nth-child(7) {
    grid-column: 4/5;
    grid-row: 4/5;
}

.galleryLayoutWrap .galleryImgs .img:nth-child(8) {
    grid-column: 1/5;
    grid-row: 5/6;
}

.galleryLayoutWrap .galleryImgs .img img {
    display: block;
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    font-family: "object-fit: cover;";
    background-size: cover;
    background-position: center center;
    position: absolute;
    z-index: -1;
}

.galleryLayoutWrap .galleryImgs .img .description {
    padding: calc(14px - .4em) 16px;
    font-size: 1.3rem;
    line-height: 1.8;
    letter-spacing: 0.05em;
    color: #fff;
    background-color: rgba(0, 0, 0, 0.7);
    -webkit-font-feature-settings: "palt";
    font-feature-settings: "palt";
    -webkit-transition: -webkit-transform 0.7s;
    transition: -webkit-transform 0.7s;
    transition: transform 0.7s;
    transition: transform 0.7s, -webkit-transform 0.7s;
    position: relative;
    z-index: 1;
    -webkit-transform: translateY(100%);
    -ms-transform: translateY(100%);
    transform: translateY(100%);
}

.ideaLayoutWrap {
    padding-top: 80px;
    padding-bottom: 120px;
    background-color: #ecede6;
}

.ideaLayoutWrap>.sec_sttl {
    margin-top: 28px;
    text-align: center;
}

.ideaLayoutWrap>.sec_txt {
    margin-top: 12px;
    text-align: center;
}

.ideaLayoutWrap .ideaContentsWrap {
    margin-top: 72px;
}

.ideaLayoutWrap .ideaContents .content {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    background-color: #fff;
    -webkit-box-shadow: 0 1px 2px rgba(0, 0, 0, 0.15);
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.15);
    min-height: 200px;
}

.ideaLayoutWrap .ideaContents .contentImg {
    -ms-flex-negative: 0;
    flex-shrink: 0;
    width: 200px;
}

.ideaLayoutWrap .ideaContents .contentImg img {
    display: block;
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    font-family: "object-fit: cover;";
    background-size: cover;
    background-position: center center;
}

.ideaLayoutWrap .ideaContents .contentText {
    -webkit-box-flex: 1;
    -ms-flex: 1;
    flex: 1;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    padding-left: 36px;
    padding-right: 28px;
}

.ideaLayoutWrap .ideaContents .contentText .contentHeading {
    font-family: source-han-serif-japanese, serif;
    font-weight: 500;
    font-size: 1.8rem;
    line-height: 1;
    letter-spacing: 0.1em;
    color: #be9b50;
}

.ideaLayoutWrap .ideaContents .contentText .sec_txt {
    margin-top: 20px;
    text-align: justify;
    text-justify: inter-ideograph;
}

@media print,
screen and (min-width: 641px) {
    .headerArea {
        position: fixed;
        top: 0;
    }

    .pb_180 {
        padding-bottom: 180px;
    }

    .pb_120 {
        padding-bottom: 120px;
    }

    .pt_120 {
        padding-top: 120px;
    }

    .pt_100 {
        padding-top: 100px;
    }

    .w980 {
        -webkit-box-sizing: border-box;
        box-sizing: border-box;
        margin: 0 auto;
        max-width: 100%;
        width: 980px;
    }

    .w1160 {
        margin: 0 auto;
        max-width: 100%;
        width: 1160px;
    }

    .w1220 {
        margin: 0 auto;
        max-width: 100%;
        width: 1220px;
    }

    .w1200 {
        margin: 0 auto;
        max-width: 100%;
        width: 1200px;
    }

    .arrow::before {
        width: 7px;
        height: 7px;
        -webkit-transform: rotate(45deg) skew(-25deg, -25deg);
        -ms-transform: rotate(45deg) skew(-25deg, -25deg);
        transform: rotate(45deg) skew(-25deg, -25deg);
    }

    .no-touchevents a:hover .arrow:before {
        -webkit-transform: rotate(45deg) skew(-25deg, -25deg) translate(3px, -3px);
        -ms-transform: rotate(45deg) skew(-25deg, -25deg) translate(3px, -3px);
        transform: rotate(45deg) skew(-25deg, -25deg) translate(3px, -3px);
    }

    .no-touchevents a:hover .arrow:before {
        -webkit-transform: rotate(45deg) skew(-25deg, -25deg) translate(3px, -3px);
        -ms-transform: rotate(45deg) skew(-25deg, -25deg) translate(3px, -3px);
        transform: rotate(45deg) skew(-25deg, -25deg) translate(3px, -3px);
    }

    .bnr_area {
        max-width: 980px;
    }

    .sec_ttl .en {
        line-height: 1;
    }

    .sec_ttl .ja {
        margin-top: 1rem;
    }

    .sec_sttl {
        font-size: 2.4rem;
        line-height: calc(40/24);
        letter-spacing: 0.1em;
    }

    .sec_sttl.ver02 .en {
        line-height: 1;
    }

    .sec_txt {
        font-size: 1.4rem;
        line-height: calc(26/14);
        letter-spacing: 0.05em;
    }

    .mainArea {
        margin-top: 7.4rem;
    }

    .venueLayoutWrap {
        padding-bottom: 60px;
    }

    .venueLayoutWrap .venueIntroduction {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-align: start;
        -ms-flex-align: start;
        align-items: flex-start;
        max-width: calc(100% - 40px);
    }

    .venueLayoutWrap .venueIntroduction>* {
        -ms-flex-negative: 0;
        flex-shrink: 0;
    }

    .venueLayoutWrap .introductionImg {
        margin-right: -40px;
        width: calc(50% + 40px);
    }

    .venueLayoutWrap .introductionText {
        margin-top: 40px;
        margin-left: -45px;
        width: calc(50% - 40px);
        padding-left: 85px;
        background-size: 100px;
        background-repeat: repeat;
    }

    .venueLayoutWrap .venueData {
        padding-left: 52px;
        padding-right: 52px;
    }

    .venueLayoutWrap .venueData .dataWrap {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-orient: horizontal;
        -webkit-box-direction: reverse;
        -ms-flex-direction: row-reverse;
        flex-direction: row-reverse;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center;
        -webkit-box-pack: justify;
        -ms-flex-pack: justify;
        justify-content: space-between;
    }

    .venueLayoutWrap .venueData .dataText {
        -ms-flex-negative: 0;
        flex-shrink: 0;
        width: 270px;
    }

    .venueLayoutWrap .venueData .dataText .textHeading {
        padding-left: 8px;
    }

    .venueLayoutWrap .venueData .dataText .textSpec {
        padding-left: 8px;
    }

    .venueLayoutWrap .movieArea {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
        flex-direction: column;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
        min-height: 240px;
    }

    .venueLayoutWrap .movieArea .movieImg {
        position: absolute;
        top: 15px;
        left: 15px;
    }

    .venueLayoutWrap .veArea .ph_box {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
        width: 100%;
        height: 22rem;
        background-image: url(../img/party/venue-virtielbnr-bg_pc.jpg);
    }

    .venueLayoutWrap .veArea .ph_box>a {
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center;
    }

    .venueLayoutWrap .veArea .ph_box .left {
        width: 15rem;
        height: 15rem;
    }

    .venueLayoutWrap .veArea .ph_box .right {
        width: 36rem;
    }

    .venueLayoutWrap .veArea .ph_box .right .txt {
        font-size: 2.6rem;
        letter-spacing: 0.1em;
        line-height: calc(36/26);
    }

    .venueLayoutWrap .veArea .ph_box .right:before {
        top: -1.8rem;
    }

    .venueLayoutWrap .veArea .ph_box .right:after {
        bottom: -2rem;
    }

    .galleryLayoutWrap .galleryImgs {
        max-width: calc(100% - 40px);
    }

    .galleryLayoutWrap .galleryImgs .img:before {
        content: "";
        display: block;
        width: 100%;
        height: 100%;
        background-color: rgba(0, 0, 0, 0.3);
        position: absolute;
        top: 0;
        left: 0;
        -webkit-transition: opacity 0.3s;
        transition: opacity 0.3s;
        pointer-events: none;
        opacity: 0;
    }

    .no-touchevents .galleryLayoutWrap .galleryImgs .img:hover:before {
        opacity: 1;
    }

    .no-touchevents .galleryLayoutWrap .galleryImgs .img:hover .description {
        -webkit-transform: translateY(0);
        -ms-transform: translateY(0);
        transform: translateY(0);
    }

    /* .ideaLayoutWrap {
        margin-bottom: 150px;
    } */

    .ideaLayoutWrap .ideaContentsWrap {
        padding: 0 20px;
        max-width: calc(100% - 40px);
    }

    .ideaLayoutWrap .ideaContents {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
        margin: 0 -15px -30px;
    }

    .ideaLayoutWrap .ideaContents .content {
        width: calc(100% / 2 - 30px);
        margin: 0 15px 30px;
    }
}

@media screen and (max-width: 640px) {
    .pc_flex {
        display: block;
    }

    .pb_180 {
        padding-bottom: 60px;
    }

    .pb_120 {
        padding-bottom: 60px;
    }

    .pt_120 {
        padding-top: 60px;
    }

    .pt_100 {
        padding-top: 50px;
    }

    .arrow::before {
        width: 6px;
        height: 6px;
        -webkit-transform: rotate(45deg) skew(-15deg, -15deg);
        -ms-transform: rotate(45deg) skew(-15deg, -15deg);
        transform: rotate(45deg) skew(-15deg, -15deg);
    }

    .no-touchevents a:hover .arrow:before {
        -webkit-transform: rotate(45deg) skew(-15deg, -15deg) translate(3px, -3px);
        -ms-transform: rotate(45deg) skew(-15deg, -15deg) translate(3px, -3px);
        transform: rotate(45deg) skew(-15deg, -15deg) translate(3px, -3px);
    }

    .no-touchevents a:hover .arrow:before {
        -webkit-transform: rotate(45deg) skew(-15deg, -15deg) translate(3px, -3px);
        -ms-transform: rotate(45deg) skew(-15deg, -15deg) translate(3px, -3px);
        transform: rotate(45deg) skew(-15deg, -15deg) translate(3px, -3px);
    }

    .bnr_area {
        max-width: 89%;
    }

    .sec_ttl .en {
        display: block;
        margin-bottom: 10px;
        font-size: 9.7vw;
    }

    .sec_ttl .ja {
        font-size: 3.6vw;
    }

    .sec_sttl {
        font-size: 5vw;
        line-height: calc(70/36);
        letter-spacing: 0.1em;
    }

    .sec_sttl.ver02 {
        color: #3c5028;
    }

    .sec_sttl.ver02 .en {
        display: block;
        margin-bottom: 10px;
        font-size: 8.3vw;
    }

    .sec_sttl.ver02 .ja {
        font-size: 2.8vw;
    }

    .sec_txt {
        font-size: 3.6vw;
        line-height: calc(46/26);
        letter-spacing: 0.05em;
    }

    .mainArea {
        margin-top: calc(100vw * (72 / 720));
    }

    .titleArea .mainvisual {
        margin-top: calc(100vw * (80 / 720));
    }

    .titleArea .mainvisual .mainvisualImg {
        height: calc(100vw * (800 / 720));
    }

    .titleArea .catchText {
        margin-top: calc(100vw * (80 / 720));
    }

    .titleArea .catchText .sec_txt {
        margin-top: calc(100vw * (40 / 720));
    }

    .venueLayoutWrap {
        padding-top: calc(100vw * (132 / 720));
    }

    .venueLayoutWrap .introductionText {
        margin-left: calc(100vw * (40 / 720));
        margin-right: calc(100vw * (40 / 720));
        padding-top: calc(100vw * (60 / 720));
        padding-bottom: calc(100vw * (80 / 720));
        background-repeat: repeat;
        background-size: 50px;
    }

    .venueLayoutWrap .introductionText .textHeading img {
        width: calc(100vw * (204 / 720));
    }

    .venueLayoutWrap .introductionText .sec_sttl {
        margin-top: calc(100vw * (32 / 720));
        font-size: 1.5rem;
    }

    .venueLayoutWrap .introductionText .sec_txt {
        margin-top: calc(100vw * (24 / 720));
        margin-left: calc(100vw * (40 / 720));
        margin-right: calc(100vw * (40 / 720));
        text-align: left;
        text-align: justify;
        text-justify: inter-ideograph;
    }

    .venueLayoutWrap .venueData {
        margin-top: calc(100vw * (50 / 720));
        margin-left: calc(100vw * (40 / 720));
        margin-right: calc(100vw * (40 / 720));
        border-width: calc(100vw * (10 / 720));
        padding: calc(100vw * (40 / 720));
    }

    .venueLayoutWrap .venueData .dataImg img {
        width: 100%;
    }

    .venueLayoutWrap .venueData .dataText .textHeading {
        margin-top: calc(100vw * (80 / 720));
        padding-bottom: calc(100vw * (16 / 720));
        font-size: 3.6vw;
    }

    .venueLayoutWrap .venueData .dataText .textHeading>.en {
        font-size: 5vw;
    }

    .venueLayoutWrap .venueData .dataText .textSpec {
        padding-top: calc(100vw * (28 / 720));
        font-size: 3.6vw;
    }

    .venueLayoutWrap .movieArea {
        margin-top: calc(100vw * (70 / 720));
        padding: calc(100vw * (60 / 720)) calc(100vw * (40 / 720)) calc(100vw * (72 / 720));
    }

    .venueLayoutWrap .movieArea .movieCatch {
        font-size: 3.9vw;
    }

    .venueLayoutWrap .movieArea .movieCatch:after,
    .venueLayoutWrap .movieArea .movieCatch:before {
        height: calc(100vw * (28 / 720));
    }

    .venueLayoutWrap .movieArea .movieCatch:before {
        margin-right: calc(100vw * (20 / 720));
    }

    .venueLayoutWrap .movieArea .movieCatch:after {
        margin-left: calc(100vw * (20 / 720));
    }

    .venueLayoutWrap .movieArea .movieHeading {
        margin-top: calc(100vw * (30 / 720));
        font-size: 5vw;
        line-height: 1.6;
    }

    .venueLayoutWrap .movieArea .movieImg {
        margin-top: calc(100vw * (40 / 720));
    }

    .venueLayoutWrap .movieArea .prt_btn02 {
        margin-top: calc(100vw * (60 / 720));
        width: 100%;
    }

    .venueLayoutWrap .veArea {
        margin-top: calc(100vw * (80 / 720));
    }

    .venueLayoutWrap .veArea .ph_box {
        background-image: url(../img/party/venue-virtielbnr-bg_sp.jpg);
    }

    .venueLayoutWrap .veArea .ph_box {
        width: 100%;
        padding-top: calc(100vw * (50 / 720));
        padding-bottom: calc(100vw * (50 / 720));
    }

    .venueLayoutWrap .veArea .ph_box>a {
        margin: 0 auto;
        width: calc(100vw * (460 / 720));
    }

    .venueLayoutWrap .veArea .ph_box>a:after {
        right: calc(100vw * (16 / 720));
        border-width: 6px 1px 1px 6px;
    }

    .venueLayoutWrap .veArea .ph_box .left {
        width: calc(100vw * (180 / 720));
        height: calc(100vw * (180 / 720));
    }

    .venueLayoutWrap .veArea .ph_box .left img {
        max-width: calc(100% - (100vw * (20 / 720)));
    }

    .venueLayoutWrap .veArea .ph_box .right {
        width: calc(100% - (100vw * (180 / 720)));
        height: calc(100vw * (180 / 720));
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
    }

    .venueLayoutWrap .veArea .ph_box .right .txt {
        font-size: 4.2vw;
        letter-spacing: 0.14em;
        line-height: calc(36/30);
    }

    .venueLayoutWrap .veArea .ph_box .right:before {
        top: calc(100vw * (15 / 720));
        width: calc(100vw * (248 / 720));
    }

    .venueLayoutWrap .veArea .ph_box .right:after {
        bottom: calc(100vw * (15 / 720));
        width: calc(100vw * (248 / 720));
    }

    .galleryLayoutWrap {
        padding-top: calc(100vw * (120 / 720));
        padding-bottom: calc(100vw * (150 / 720));
        padding-left: calc(100vw * (40 / 720));
        padding-right: calc(100vw * (40 / 720));
    }

    .galleryLayoutWrap .galleryImgs {
        height: calc(100vw * (1156 / 720));
    }

    .ideaLayoutWrap {
        padding-top: calc(100vw * (116 / 720));
        padding-bottom: calc(100vw * (100 / 720));
    }

    .ideaLayoutWrap>.sec_sttl {
        margin-top: calc(100vw * (36 / 720));
    }

    .ideaLayoutWrap>.sec_txt {
        margin-top: calc(100vw * (52 / 720));
    }

    .ideaLayoutWrap .ideaContentsWrap {
        margin-top: calc(100vw * (80 / 720));
        overflow: hidden;
    }

    .ideaLayoutWrap .ideaContents .content {
        min-height: calc(100vw * (330 / 720));
    }

    .ideaLayoutWrap .ideaContents .content+.content {
        margin-top: calc(100vw * (10 / 720));
    }

    .ideaLayoutWrap .ideaContents .contentImg {
        width: calc(100vw * (240 / 720));
    }

    .ideaLayoutWrap .ideaContents .contentText {
        padding-left: calc(100vw * (40 / 720));
        padding-right: calc(100vw * (40 / 720));
    }

    .ideaLayoutWrap .ideaContents .contentText .contentHeading {
        margin-right: calc(100vw * (40 / 720) * -1);
        font-size: 4.2vw;
    }

    .ideaLayoutWrap .ideaContents .contentText .sec_txt {
        margin-top: calc(100vw * (24 / 720));
    }
}



/*
23.4-11_パーティーページフッター遷移
*/

.asideLayoutWrap {
    /* padding-top: 60px; */
    padding-bottom: 120px;
  }

.asideLayoutWrap .asideMenuArea {
    margin-top: 100px;
}

.no-touchevents .asideLayoutWrap .asideMenuArea .link_wrap:hover:after {
    -webkit-transform: rotate(-45deg) translate(6px, 6px);
    -ms-transform: rotate(-45deg) translate(6px, 6px);
    transform: rotate(-45deg) translate(6px, 6px);
}

.asideLayoutWrap .asideMenuArea .link_wrap:after {
    content: "";
    display: block;
    margin: auto 0;
    border-width: 8px 2px 2px 8px;
    border-style: solid;
    border-color: transparent #a18100 #a18100 transparent;
    width: 0;
    height: 0;
    position: absolute;
    top: 0;
    bottom: 0;
    -webkit-transform: rotate(-45deg);
    -ms-transform: rotate(-45deg);
    transform: rotate(-45deg);
    -webkit-transition: -webkit-transform 0.5s;
    transition: -webkit-transform 0.5s;
    transition: transform 0.5s;
    transition: transform 0.5s, -webkit-transform 0.5s;
}

.asideLayoutWrap .asideMenuArea .link_wrap::after {
    border-color: transparent #fff #fff transparent;
}

.asideLayoutWrap .asideMenuArea .menu_ttl {
    position: absolute;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    margin: auto;
    text-align: center;
    color: #fff;
}

.asideLayoutWrap .asideMenuArea .menu_ttl .ttl {
    font-family: Amiri;
    font-weight: 400;
    font-size: 3.4rem;
    letter-spacing: 0.05em;
    line-height: 1;
    margin-bottom: 12px;
}

.asideLayoutWrap .asideMenuArea .menu_ttl .subttl {
    display: block;
    font-family: source-han-serif-japanese, serif;
    font-weight: 500;
    letter-spacing: 0.1em;
    line-height: 1;
}

.more_link .link span.arrow {
    display: inline-block;
}

.more_link .link span.arrow::before {
    top: 1px;
    bottom: 0;
    margin: auto 0;
    right: -10px;
    border-top: 1px solid #81cddf;
    border-right: 1px solid #81cddf;
}

.arrow {
    position: relative;
    display: block;
}

.arrow::before {
    position: absolute;
    content: "";
    display: inline-block;
    border-top: 1px solid #3c3c3c;
    border-right: 1px solid #3c3c3c;
    -webkit-transition: 0.3s;
    transition: 0.3s;
    z-index: 10;
}



@media print,
screen and (min-width: 641px) {
    .asideLayoutWrap .asideMenuArea {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: justify;
        -ms-flex-pack: justify;
        justify-content: space-between;
    }

    .asideLayoutWrap .asideMenuArea .detail {
        width: 31%;
        height: 150px;
    }

    .asideLayoutWrap .asideMenuArea .link_wrap::after {
        left: 90%;
    }

    .asideLayoutWrap .asideMenuArea .menu_ttl .subttl {
        font-size: 1.4rem;
    }

    .arrow::before {
        width: 7px;
        height: 7px;
        -webkit-transform: rotate(45deg) skew(-25deg, -25deg);
        -ms-transform: rotate(45deg) skew(-25deg, -25deg);
        transform: rotate(45deg) skew(-25deg, -25deg);
      }
    
      .no-touchevents a:hover .arrow:before {
        -webkit-transform: rotate(45deg) skew(-25deg, -25deg) translate(3px, -3px);
        -ms-transform: rotate(45deg) skew(-25deg, -25deg) translate(3px, -3px);
        transform: rotate(45deg) skew(-25deg, -25deg) translate(3px, -3px);
      }
    
      .no-touchevents a:hover .arrow:before {
        -webkit-transform: rotate(45deg) skew(-25deg, -25deg) translate(3px, -3px);
        -ms-transform: rotate(45deg) skew(-25deg, -25deg) translate(3px, -3px);
        transform: rotate(45deg) skew(-25deg, -25deg) translate(3px, -3px);
      }
    
}








@media screen and (max-width: 640px) {

    .asideLayoutWrap .asideMenuArea {
        margin-top: calc(100vw * (40 / 720));
        padding-left: calc(100vw * (80 / 720));
        padding-right: calc(100vw * (80 / 720));
    }

    .asideLayoutWrap .asideMenuArea .detail {
        width: 100%;
        height: calc(100vw * .78 * .46);
    }

    .asideLayoutWrap .asideMenuArea .detail+.detail {
        margin-top: 10px;
    }

    .asideLayoutWrap .asideMenuArea .link_wrap::after {
        right: 7%;
    }

    .asideLayoutWrap .asideMenuArea .menu_ttl .ttl {
        margin-bottom: 7px;
        font-size: 8.3vw;
    }

    .asideLayoutWrap .asideMenuArea .menu_ttl .subttl {
        font-size: 3.6vw;
    }

    .arrow::before {
        width: 6px;
        height: 6px;
        -webkit-transform: rotate(45deg) skew(-15deg, -15deg);
        -ms-transform: rotate(45deg) skew(-15deg, -15deg);
        transform: rotate(45deg) skew(-15deg, -15deg);
      }
    
      .no-touchevents a:hover .arrow:before {
        -webkit-transform: rotate(45deg) skew(-15deg, -15deg) translate(3px, -3px);
        -ms-transform: rotate(45deg) skew(-15deg, -15deg) translate(3px, -3px);
        transform: rotate(45deg) skew(-15deg, -15deg) translate(3px, -3px);
      }
    
      .no-touchevents a:hover .arrow:before {
        -webkit-transform: rotate(45deg) skew(-15deg, -15deg) translate(3px, -3px);
        -ms-transform: rotate(45deg) skew(-15deg, -15deg) translate(3px, -3px);
        transform: rotate(45deg) skew(-15deg, -15deg) translate(3px, -3px);
      }

      .asideLayoutWrap {
        /* padding-top: calc(100vw * (60 / 720)); */
        padding-bottom: calc(100vw * (80 / 720));
      }
    
    
}


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