/**小学生チケット**/
.kids_ticket {
    margin-bottom: 80px;
}

.kids_ticket .inner, .howto_main .inner {
    max-width: 1000px;
    width: 100%;
    margin: 30px auto;
    background-color: #fff;
    border-radius: 0 40px 40px 40px;
    padding-bottom: 20px;
}

.kids_ticket_page_ttl {
    background-color: #ef4e3a;
    padding: 30px;
    border-radius: 0 40px 0 0;
}

.kids_ticket_page_ttl h2 {
    margin: 0;
    text-align: center;
    font-size: 4rem;
    color: #fff;
}

.kids_ticket_page_price, .kids_ticket_page_venue {
    margin: 20px auto;
    text-align: center;
}

.kids_ticket_page_price h3, .kids_ticket_page_venue h3 {
    font-size: 3.2rem;
    padding-bottom: 16px;
    margin-bottom: 30px;
    font-weight: 700;
    border-bottom: 3px solid #AAAAAA;
    position: relative;
    display: inline-block;
}

.kids_ticket_page_price h3::before, .kids_ticket_page_venue h3::before {
    content: "";
    width: 75px;
    height: 3px;
    display: block;
    background-color: #F0007F;
    position: absolute;
    bottom: -3px;
    left: 50%;
    transform: translateY(0%) translateX(-50%);
    -webkit-transform: translateY(0%) translateX(-50%);
}

.kids_ticket_page_price img {
    display: block;
    max-width: 386px;
    width: 100%;
    margin: 0 auto;
}

.k_price {
    padding: 25px 80px;
    border-radius: 99px;
    background-color: #FFE564;
    display: inline-block;
    margin: 30px auto;
}

.k_price p {
    display: inline-block;
    width: auto;
    font-size: 2.8rem;
    font-weight: 700;
    margin: 0;
}

.venue__name {
    font-size: 2.8rem;
    line-height: 1.4;
    font-weight: 700;
    margin: 0;
}

.venue__name span {
    font-size: 1.8rem;
}

.attentions {
    text-align: left;
    max-width: 680px;
    width: 100%;
    margin: 30px auto;
    padding: 20px;
    border: 2px dotted #ff952a;
    border-radius: 10px;
}

.attentions h4 {
    margin: 0 auto 15px;
}

.attentions li {
    margin: 10px auto;
    line-height: 1.4;
}


.kids_ticket_page_link a {
    text-align: center;
    display: block !important;
    width: 380px;
    padding: 20px 0;
    background-color: #F0007F;
    color: #fff;
    font-size: 2rem;
    font-weight: 700;
    margin: 10px auto;
    border-radius: 7px;

}

@media screen and (max-width: 768px) {
    .kids_ticket {
        padding: 0 7px;
    }

    .kids_ticket .inner {
        border-radius: 0 20px 20px 20px;
    }

    .kids_ticket_page_ttl h2 {
        font-size: 2.8rem;
    }

    .kids_ticket_page_ttl {
        padding: 18px;
    }

    .kids_ticket_page_price h3, .kids_ticket_page_venue h3 {
        font-size: 2rem;
    }

    .k_price p {
        font-size: 2rem;
    }

    .venue__name span {
        font-size: 1.6rem;
        line-height: 1.4;
        display: block;
        margin: 10px 0;
    }

    .kids_ticket_page_link a {
        width: 340px;
    }

    .kids_ticket_page_price, .kids_ticket_page_venue {
        padding: 0 10px;
    }
}


/***チケット購入・入場方法***/
.howto_main .inner {
    padding: 35px;
}

.howto_contents h2 {
    font-size: 2.9rem;
    padding-bottom: 16px;
    margin-bottom: 30px;
    font-weight: 700;
    border-bottom: 3px solid #AAAAAA;
    position: relative;
}

.howto_contents h2::before {
    content: "";
    width: 223px;
    height: 3px;
    display: block;
    background-color: #F0007F;
    position: absolute;
    bottom: -3px;
    left: 0;
}

.stacaimg {
    margin: 0 auto;
}

.howto_grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 30px;
    margin: 15px auto 60px;
}

.howto_grid_item {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 30px;
}

.howto_grid_item_img img {
    border-radius: 25px;
    height: 100%;
    object-fit: cover;
}

.howto_grid_item_txt {
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.howto_grid_item_txt h3 {
    margin: 10px 0;
    padding-left: 20px;
    font-size: 2rem;
    position: relative;
}

.howto_grid_item_txt h3::before {
    content: "";
    width: 10px;
    height: 100%;
    background-color: var(--area-color, #F0007F);
    border-radius: 10px;
    position: absolute;
    top: 50%;
    left: 0%;
    transform: translateY(-50%) translateX(0%);
    -webkit-transform: translateY(-50%) translateX(0%);
}

.howto_grid_item_txt p {
    font-size: 1.8rem;
    line-height: 1.4;
    letter-spacing: .04em;
    font-weight: 500;
    margin: 10px 0;
}

.howto_grid_item_txt span {
    font-weight: 400;
    font-size: 1.4rem;
}

.howto_btn a {
    text-align: center;
    display: block !important;
    width: 95%;
    padding: 10px 0;
    background-color: #313565;
    color: #fff;
    font-size: 1.8rem;
    font-weight: 700;
    margin: 10px auto;
    border-radius: 7px;
}

.howto_att {
    padding: 10px 16px;
    border: 1px solid #A1A1A1;
    background-color: #F8F8F8;
    border-radius: 10px;
    margin: 10px;
}

.howto_att p {
    font-size: 1.6rem;
    letter-spacing: initial;
    line-height: 1.4;
}

.howto_att span {
    color: #F0007F;
    font-weight: 500;
}

.howto_bottom h5 {
    font-size: 2.4rem;
    text-align: center;
}

.tomannerbtn a {
    max-width: 380px;
    padding: 20px 0;
    background-color: #F0007F;
}

.p-howto {
    padding-bottom: 80px;
}

@media screen and (max-width: 768px) {
    .howto_main {
        padding: 0 7px;
    }

    .howto_main .inner {
        padding: 25px 10px;
    }

    .howto_contents h2 {
        font-size: 2rem;
        padding-bottom: 10px;
    }

    .howto_grid_item {
        grid-template-columns: 1fr;
    }
}


/**よくある質問・お問い合わせ**/
.p-general h2 {
    font-size: 2.9rem;
    padding-bottom: 16px;
    margin-bottom: 30px;
    font-weight: 700;
    border-bottom: 3px solid #AAAAAA;
    position: relative;
}

.p-general h2::before {
    content: "";
    width: 223px;
    height: 3px;
    display: block;
    background-color: #F0007F;
    position: absolute;
    bottom: -3px;
    left: 0;
}

.p-general h3 {
    margin: 0 0 10px;
    padding-left: 20px;
    font-size: 2rem;
    position: relative;
}

.p-general h3::before {
    content: "";
    width: 10px;
    height: 100%;
    background-color: #F0007F;
    border-radius: 10px;
    position: absolute;
    top: 50%;
    left: 0%;
    transform: translateY(-50%) translateX(0%);
    -webkit-transform: translateY(-50%) translateX(0%);
}

.p-general p {
    font-size: 1.8rem;
    letter-spacing: .05em;
    line-height: 1.6;
}

.ct_faq_block {
    margin: 40px auto;
}

.ct_intro p {
    font-size: 2rem;
    font-weight: 600;
}

.ct_faq_block a {
    color: #1A73E8;
    text-decoration: underline;
    text-underline-offset: 5px;
}

/**WPデフォルトアコーディオン**/

.p-general details {
    background-color: #FFF5FA;
    border-radius: 10px;
    padding: 16px;
}

.p-general details:not([open]) {
    margin-bottom: 7px;
}

.p-general details summary {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    position: relative;
    padding: 7px 24px 7px 32px;
    border-radius: 10px;
    background-color: #FFF5FA;
    color: #333;
    cursor: pointer;
    font-size: 1.8rem;
    font-weight: 600;
    letter-spacing: .05em;
}


.p-general details summary span {
    font-size: 1.4rem;
    font-weight: 500;
    display: block;
    margin-left: 20px;
}

.p-general details summary::-webkit-details-marker {
    display: none;
}

.p-general details {
    margin: 15px 0;
    position: relative;
}

.p-general details>p {
    padding-left: 32px;
    position: relative;
    font-weight: 500;
}

.p-general details summary::before {
    content: "";
    width: 26px;
    height: 26px;
    background: url(../img/whats/icon_q.svg) no-repeat center / contain;
    position: absolute;
    top: 50%;
    left: 0;
    transform: translateY(-50%) translateX(0%);
    -webkit-transform: translateY(-50%) translateX(0%);
    z-index: 1;
}

.p-general details summary::after {
    content: "";
    width: 18px;
    height: 18px;
    background: url(../img/common/icon_plus.svg) no-repeat center / contain;
    position: absolute;
    top: 50%;
    right: 2%;
    transform: translateY(-50%) translateX(0%);
    -webkit-transform: translateY(-50%) translateX(0%);
    transition: transform 0.3s ease;
}

.p-general details[open] summary::after {
    transform: translateY(-50%) rotate(45deg);
}

.p-general details>p::before {
    content: "";
    width: 26px;
    height: 26px;
    background: url(../img/whats/icon_a.svg) no-repeat center / contain;
    position: absolute;
    top: .1em;
    left: 0%;
}


.p-general details>p {
    opacity: 0;
    transform: translateY(-10px);
    transition: opacity 0.4s ease, transform 0.4s ease;
}


details[open]>p {
    opacity: 1;
    transform: translateY(0);
}


/**グラデヒーローエリア**/

/* グラデーション背景のベース */
.page-header__bg {
    position: relative;
    width: 100%;
    height: 400px;
    overflow: hidden;
    background-image: linear-gradient(90deg, rgba(226, 207, 255, 1), rgba(251, 253, 191, 1));
    background-size: 400% 400%;
    animation: gradientShift 15s ease infinite;
}

@keyframes gradientShift {
    0% {
        background-position: 0% 50%;
    }

    50% {
        background-position: 100% 50%;
    }

    100% {
        background-position: 0% 50%;
    }
}

.page-header__inner {
    padding: 0 59px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    height: 100%;
}

.page-header-text p {
    font-size: clamp(20px, 7.3vw, 100px);
    font-weight: 700;
    margin: 0;
    letter-spacing: .05em;
    display: inline-block;
    position: relative;
}

.page-header-text p::after {
    content: "";
    width: 50px;
    height: 95px;
    background: url(../img/rule/icon_a.svg) no-repeat center / cover;
    position: absolute;
    top: 50%;
    right: 0;
    transform: translateY(-50%) translateX(100%);
    -webkit-transform: translateY(-50%) translateX(100%);
}

.page-header-text span {
    color: #F0007F;
}

.page_name {
    color: initial;
}

.entry-content .inner {
    max-width: 1200px;
    width: 100%;
    margin: 40px auto;
    padding: 35px;
    border-radius: 20px;
    background-color: #fff;
}

.ct_faq_group {
    margin: 30px auto;
}

.ct_wrap {
    max-width: 680px;
    margin-top: 50px;
}

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

    .ct_intro p {
        font-style: 1.8rem;
    }

    .p-general p, .p-general details summary, .p-general details>p {
        font-size: 1.6rem;
    }

    .p-general details summary::before, .p-general details>p::before {
        left: -5px;
    }

    .entry-content .inner {
        padding: 15px 8px;
    }

    .page-header__bg {
        height: 182px;
    }

    .page-header__inner {
        padding: 0 20px;
    }

    .page-header-text p {
        font-size: 3.6rem;
    }

    .page-header-text p::after {
        width: 14px;
        height: 26px;
    }

    .page_name {
        font-size: 2rem;
    }

    .p-general .entry-content {
        padding: 0 7px;
    }

    .p-general h2 {
        font-size: 2.2rem;
    }

    .p-general h3 {
        font-size: 1.8rem;
    }
}