@charset "UTF-8";
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&display=swap');

*,
:after,
:before {
    box-sizing: border-box
}

a,
button {
    color: inherit;
    cursor: pointer
}

button {
    background-color: transparent;
    border-width: 0;
    padding: 0
}

figure {
    margin: 0
}

input::-moz-focus-inner {
    border: 0;
    margin: 0;
    padding: 0
}

dd,
ol,
ul {
    list-style: none;
    margin: 0;
    padding: 0
}

h1,
h2,
h3,
h4,
h5,
h6 {
    font-size: inherit;
    font-weight: inherit;
    margin: 0
}

p {
    margin: 0
}

cite {
    font-style: normal
}

fieldset {
    border-width: 0;
    margin: 0;
    padding: 0
}

img {
    border: 0;
    display: block
}

.clearfix:after {
    clear: both;
    content: "";
    display: block
}

.over {
    opacity: 1;
    transition: .4s
}

.pc {
    display: block
}

.sp {
    display: none
}

body {
    background: #fff;
    color: #4d4d4d;
    font-family: "Noto Sans JP", YuGothic, Yu Gothic, Hiragino Kaku Gothic ProN, Hiragino Sans, Meiryo, sans-serif;
    font-size: .875rem;
    height: 100%;
    line-height: 1;
    text-align: left
}

body:before {
    background: url(../img/bg.webp) no-repeat top;
    background-size: cover;
    content: "";
    height: 100%;
    left: 0;
    position: fixed;
    top: 0;
    width: 100%
}

body img {
    width: 100%
}

.en {
    font-family: Arial, sans-serif;
    font-weight: 500
}

.en,
.ja {
    font-style: normal
}

.ja {
    font-family: "Noto Sans JP", sans-serif;
    font-weight: 700
}

.style__name:after,
body:before {
    z-index: -1
}

.style3 svg {
    z-index: 2
}

footer {
    background: linear-gradient(40deg, #f9dae6, #7bc4e6);
    color: #fff;
    font-family: Arial, sans-serif;
    font-style: normal;
    font-weight: 400;
    padding: 40px 0;
    text-align: center
}

footer .footer__sns h3 {
    font-size: 1rem;
    margin-bottom: 1em
}

footer .footer__sns ul {
    align-items: center;
    display: flex;
    justify-content: center
}

footer .footer__sns ul li {
    margin: 0 12px;
    width: 24px
}

footer .footer__logo {
    margin: 40px auto;
    width: 210px
}

footer .footer__copy {
    font-size: .625rem;
    letter-spacing: .025em
}

.logoPc {
    height: 100dvh;
    left: 0;
    position: fixed;
    top: 0;
    width: calc(50vw - 207.5px)
}

.logoPc .snsPc {
    background: #4d4d4d;
    border-radius: 50%;
    height: 70px;
    left: 30px;
    position: absolute;
    top: 30px;
    width: 70px
}

.logoPc .snsPc img {
    width: 34px
}

.logoPc .snsPc a {
    display: grid;
    height: 100%;
    place-items: center;
    width: 100%
}

.logoPc h2 {
    left: 50%;
    position: absolute;
    top: 50%;
    translate: -50% -50%;
    width: min(17.96875vw, 230px)
}

nav {
    height: 100dvh;
    position: fixed;
    right: 0;
    top: 0;
    width: calc(50vw - 207.5px)
}

nav ul {
    display: inline-block;
    font-size: min(1.5625vw, 20px);
    left: 50%;
    position: absolute;
    top: 50%;
    translate: -50% -50%
}

nav ul li {
    padding: .5em 0
}

nav ul li p {
    margin-bottom: .5em
}

nav ul li span {
    background: #4d4d4d;
    color: #fff;
    display: inline-block;
    padding: 0 3px 3px 3px;
}

nav ul li a {
    text-decoration: none
}

main {
    /* background: #c7c7e5; */
    background: rgb(249,207,224);
    border-left: 20px solid #fff;
    border-right: 20px solid #fff;
    box-shadow: 0 0 20px 5px rgba(0, 0, 0, .2);
    box-sizing: border-box;
    margin: 0 auto;
    width: 415px
}

.content section {
    padding: 60px 0;
    position: relative
}

.content section svg {
    stroke-width: 0;
    left: 0;
    position: absolute;
    top: -12px
}

.content section#info {
    padding: 60px 0 0
}

.btn {
    cursor: pointer;
    display: inline-block;
    font-size: .875rem;
    font-weight: 900;
    margin: 0 auto;
    position: relative;
    text-align: center;
    text-decoration: none;
    transition: all .3s;
    -webkit-user-select: none;
    user-select: none;
    vertical-align: middle
}

.btn:hover {
    opacity: .8
}

.btn-large-wrap {
    background: #fff;
    margin: 0 auto
}

a.btn-large {
    background: #ff8cbd;
    color: #fff;
    line-height: 1.4;
    padding: 1.2em 0;
    width: 100%
}

.keyvisual {
    background: linear-gradient(-40deg, #f9dae6, #7bc4e6);
    height: 570px;
    overflow: hidden;
    position: relative;
    width: 100%
}

.keyvisual__logo {
    left: 20px;
    position: absolute;
    top: 20px;
    width: 25.0666666667%
}

.keyvisual__logo.fadeIn.active {
    -webkit-animation-delay: .4s;
    animation-delay: .4s
}

.keyvisual__bg {
    left: 50%;
    position: absolute;
    translate: -50% 40px;
    width: 100%
}

.keyvisual__bg.fadeIn.active {
    -webkit-animation-delay: .4s;
    animation-delay: .4s
}

.keyvisual__ttl {
    left: 50%;
    position: absolute;
    top: 0;
    translate: -50% 25px;
    width: 100%
}

.keyvisual__ttl.fadeInUp.active {
    -webkit-animation-delay: .6s;
    animation-delay: .6s
}

.keyvisual__obj {
    bottom: 0;
    left: 50%;
    position: absolute;
    translate: -50% 0;
    width: 100%
}

.keyvisual__obj.fadeInUp.active {
    -webkit-animation-delay: .8s;
    animation-delay: .8s
}

.keyvisual__catch {
    bottom: 55px;
    display: grid;
    left: 0;
    place-items: center;
    position: absolute;
    width: 100%
}

.keyvisual__catch p {
    background: #fff;
    -webkit-clip-path: inset(0 100% 0 0);
    clip-path: inset(0 100% 0 0);
    color: #6bb7ff;
    display: inline-block;
    font-size: 1.125rem;
    font-weight: 700;
    margin-bottom: .3em;
    padding: .3em .2em;
    text-align: center;
    transition-property: -webkit-clip-path;
    transition-property: clip-path;
    transition-property: clip-path, -webkit-clip-path
}

.keyvisual__catch p.active {
    -webkit-clip-path: inset(0);
    clip-path: inset(0);
    transition: .6s cubic-bezier(.37, 0, .63, 1);
    transition-delay: 1.2s
}

.keyvisual__catch p span {
    color: #ff7fb0;
}

.concept__inr {
    margin: 0 auto;
    width: 80%
}

.concept__read {
    line-height: 30px;
    margin-bottom: 1.25rem;
    text-align: justify
}

.profile {
    /* background-color: #a9d1c7; */
    background-color: rgb(161, 217, 247);
}

.profile svg {
    fill: rgb(161, 217, 247);
}

.profile__ttl {
    color: #fff;
    font-size: 2.5rem;
    letter-spacing: .05em;
    margin-bottom: 1em;
    text-align: center
}

.profile__visual {
    margin: 0 auto 2em;
    width: 66.6666666667%
}

.profile__name {
    color: #fff;
    font-size: 1.25rem;
    font-weight: 700;
    margin-bottom: 1em;
    text-align: center
}

.profile__read {
    line-height: 28px;
    margin: 0 auto;
    text-align: justify;
    width: 80%
}

.profile__sns {
    display: flex;
    gap: 0 30px;
    justify-content: center;
    margin-top: 2em
}

.profile__sns li p {
    background: #6bb7ff;
    border-radius: 50px;
    height: 50px;
    width: 50px
}

.profile__sns li p img {
    width: 24px
}

.profile__sns li p a {
    display: grid;
    height: 100%;
    place-items: center;
    width: 100%
}

.style__ttl {
    margin: 0 auto .5em;
    width: 69.3333333333%
}

.style__ttl img {
    height: auto;
    width: 100%;
}

.style__name {
    display: inline-block;
    height: 40px;
    left: 50%;
    position: relative;
    translate: -50% 0;
    width: 66.6666666667%
}

.style__name p {
    background: #fff;
    display: grid;
    font-size: 1.5625rem;
    height: 100%;
    place-items: center;
    width: 100%
}

.style__name:after {
    bottom: -.5em;
    content: "";
    height: 100%;
    position: absolute;
    right: -.5em;
    width: 100%
}

.style .movie {
    margin: 40px auto;
    width: 86.6666666667%
}

.style .movie iframe {
    aspect-ratio: 9/16;
    border: none;
    height: 100%;
    width: 100%
}

.style .item__heading {
    align-items: center;
    display: flex;
    overflow: hidden
}

.style .item__heading p:first-child {
    width: 60%
}

.style .item__heading p:nth-child(2) {
    display: flex;
    flex-direction: column;
    font-size: 1.25rem;
    justify-content: center;
    -webkit-text-orientation: upright;
    text-orientation: upright;
    width: 40%;
    -webkit-writing-mode: vertical-rl;
    writing-mode: vertical-rl
}

.style .item__heading p:nth-child(2) span {
    align-self: flex-start;
    border-left: 2px solid #fff;
    margin: 0 .2em;
    padding-left: .3em
}

.style .item__heading.right {
    flex-direction: row-reverse
}

.style .item__read {
    line-height: 30px;
    margin: 3em auto;
    text-align: justify;
    width: 80%
}

.style .item__detail {
    align-items: center;
    display: flex;
    margin: 0 auto;
    width: 80%
}

.style .item__detail dt {
    line-height: 24px;
    width: 75%
}

.style .item__detail dd {
    width: 25%
}

.style1 {
    /* background: #a9d1c7; */
    background: rgb(194, 223, 191);
}

.style1 svg {
    fill: rgb(194, 223, 191);
}

.style1 .style__name p {
    color: #64bd9f
}

.style1 .style__name:after {
    background: #64bd9f
}

.style2 {
    /* background: #c6acdf; */
    background: rgb(202, 165, 206);
}

.style2 svg {
    fill: rgb(202, 165, 206);
}

.style2 .style__name p {
    color: #bd95e5
}

.style2 .style__name:after {
    background: #bd95e5
}

.style3 {
    /* background: #ffc3da; */
    background: rgb(250, 196, 158);
}

.style3 svg {
    fill: rgb(202, 165, 206);
    top: 0
}

.style3 .obj2 {
    margin: -60px 0 30px;
    overflow: hidden
}

.style3 .style__name p {
    color: #eea01e;
}

.style3 .style__name:after {
    background: #eea01e;
}

.style4 {
    /* background: #a9c7e5; */
    background: rgb(255, 237, 155);
}

.style4 svg {
    fill: rgb(255, 237, 155);
}

.style4 .style__name p {
    color: #78a9e5
}

.style4 .style__name:after {
    background: #78a9e5
}

.style5 {
    background: #ffdcbe
}

.style5 svg {
    fill: #ffdcbe
}

.style5 .style__name p {
    color: #eea01e
}

.style5 .style__name:after {
    background: #eea01e
}

.style-info {
    /* background: #ffdcbe; */
    background: rgb(249, 207, 224);
}

.style-info svg {
    fill: rgb(249, 207, 224);
}

.style-info .style__name p {
    color: #ff8cbd;
}

.style-info .style__name:after {
    background: #ff8cbd;
}

.info__ttl {
    color: #ff8cbd;
    font-size: 1.25rem;
    font-weight: 700;
    line-height: 1.7;
    margin-bottom: 1em;
    text-align: center
}

.info__read {
    text-align: justify;
    width: 80%;
    word-break: break-all
}

.info__event,
.info__read {
    line-height: 30px;
    margin: 2em auto
}

.info__event {
    background: #fff;
    /* border: 5px solid #eea01e; */
    border: 5px solid #ff8cbd;
    letter-spacing: .05em;
    padding: 1em;
    width: 88%
}

.info__event a {
    color: #ff8cbd;
    text-decoration: underline
}

.info__event .ttl {
    color: #ff8cbd;
    font-size: 1.25rem
}

.info__event .date,
.info__event .ttl {
    font-weight: 700;
    line-height: 1.7;
    margin-bottom: 1em;
    text-align: center
}

.info__event .date {
    font-size: 1.125rem
}

.info__event .notice {
    line-height: 1.7;
    margin-bottom: 1em
}

.swiper-button-next,
.swiper-button-prev {
    color: hsla(0, 0%, 100%, 0);
    margin: 0;
    outline: none;
    position: absolute;
    top: 46.6666666667%
}

.swiper-button-next {
    background: url(../img/btn_next.svg) no-repeat;
    background-size: cover;
    right: 2.6666666667%
}

.swiper-button-next,
.swiper-button-prev {
    height: 6.6666666667%;
    width: 6.6666666667%
}

.swiper-button-prev {
    background: url(../img/btn_prev.svg) no-repeat;
    background-size: cover;
    left: 2.6666666667%
}

.swiper-pagination-bullets {
    left: 50%!important;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%)
}

.swiper-pagination-bullet {
    background: none;
    border: 1px solid #fff;
    margin: 20px 5px 0!important;
    opacity: 1
}

.swiper-pagination-bullet-active {
    background: #fff;
    border: 1px solid #fff;
    opacity: 1
}

.fadeIn {
    -webkit-animation-duration: 1s;
    animation-duration: 1s;
    -webkit-animation-fill-mode: both;
    animation-fill-mode: both;
    opacity: 0
}

.fadeIn.active {
    -webkit-animation-delay: .2s;
    animation-delay: .2s;
    -webkit-animation-name: fadeIn;
    animation-name: fadeIn
}

@-webkit-keyframes fadeIn {
    0% {
        opacity: 0
    }
    to {
        opacity: 1
    }
}

@keyframes fadeIn {
    0% {
        opacity: 0
    }
    to {
        opacity: 1
    }
}

.fadeInUp {
    -webkit-animation-duration: 1s;
    animation-duration: 1s;
    -webkit-animation-fill-mode: both;
    animation-fill-mode: both;
    opacity: 0
}

.fadeInUp.active {
    -webkit-animation-delay: .2s;
    animation-delay: .2s;
    -webkit-animation-name: fadeInUp;
    animation-name: fadeInUp
}

@-webkit-keyframes fadeInUp {
    0% {
        opacity: 0;
        -webkit-transform: translate3d(0, 30%, 0);
        transform: translate3d(0, 30%, 0)
    }
    to {
        opacity: 1;
        -webkit-transform: translateZ(0);
        transform: translateZ(0)
    }
}

@keyframes fadeInUp {
    0% {
        opacity: 0;
        -webkit-transform: translate3d(0, 30%, 0);
        transform: translate3d(0, 30%, 0)
    }
    to {
        opacity: 1;
        -webkit-transform: translateZ(0);
        transform: translateZ(0)
    }
}

.fadeInDown {
    -webkit-animation-duration: 1s;
    animation-duration: 1s;
    -webkit-animation-fill-mode: both;
    animation-fill-mode: both;
    opacity: 0
}

.fadeInDown.active {
    -webkit-animation-delay: .2s;
    animation-delay: .2s;
    -webkit-animation-name: fadeInDown;
    animation-name: fadeInDown
}

@-webkit-keyframes fadeInDown {
    0% {
        opacity: 0;
        -webkit-transform: translate3d(0, -30%, 0);
        transform: translate3d(0, -30%, 0)
    }
    to {
        opacity: 1;
        -webkit-transform: translateZ(0);
        transform: translateZ(0)
    }
}

@keyframes fadeInDown {
    0% {
        opacity: 0;
        -webkit-transform: translate3d(0, -30%, 0);
        transform: translate3d(0, -30%, 0)
    }
    to {
        opacity: 1;
        -webkit-transform: translateZ(0);
        transform: translateZ(0)
    }
}

.fadeInLeft {
    -webkit-animation-duration: 1s;
    animation-duration: 1s;
    -webkit-animation-fill-mode: both;
    animation-fill-mode: both;
    opacity: 0
}

.fadeInLeft.active {
    -webkit-animation-delay: .2s;
    animation-delay: .2s;
    -webkit-animation-name: fadeInLeft;
    animation-name: fadeInLeft
}

@-webkit-keyframes fadeInLeft {
    0% {
        opacity: 0;
        -webkit-transform: translate3d(-30%, 0, 0);
        transform: translate3d(-30%, 0, 0)
    }
    to {
        opacity: 1;
        -webkit-transform: translateZ(0);
        transform: translateZ(0)
    }
}

@keyframes fadeInLeft {
    0% {
        opacity: 0;
        -webkit-transform: translate3d(-30%, 0, 0);
        transform: translate3d(-30%, 0, 0)
    }
    to {
        opacity: 1;
        -webkit-transform: translateZ(0);
        transform: translateZ(0)
    }
}

.fadeInRight {
    -webkit-animation-duration: 1s;
    animation-duration: 1s;
    -webkit-animation-fill-mode: both;
    animation-fill-mode: both;
    opacity: 0
}

.fadeInRight.active {
    -webkit-animation-delay: .2s;
    animation-delay: .2s;
    -webkit-animation-name: fadeInRight;
    animation-name: fadeInRight
}

@-webkit-keyframes fadeInRight {
    0% {
        opacity: 0;
        -webkit-transform: translate3d(30%, 0, 0);
        transform: translate3d(30%, 0, 0)
    }
    to {
        opacity: 1;
        -webkit-transform: translateZ(0);
        transform: translateZ(0)
    }
}

@keyframes fadeInRight {
    0% {
        opacity: 0;
        -webkit-transform: translate3d(30%, 0, 0);
        transform: translate3d(30%, 0, 0)
    }
    to {
        opacity: 1;
        -webkit-transform: translateZ(0);
        transform: translateZ(0)
    }
}

@media(hover:hover)and (pointer:fine) {
    .over:hover {
        opacity: .5
    }
}

@media(max-width:559px) {
    .pc {
        display: none
    }
    .sp {
        display: block
    }
    body:before {
        display: none
    }
    main {
        border-left: 0;
        border-right: 0;
        box-shadow: none;
        width: 100%
    }
}