@charset "utf-8";
/* 新デザインページ用style */

/* Common */
/* =============================================== */
:root {
    --bg-pink: linear-gradient(45deg, #ff536e, #f71363);
    --bg-lightgray: #f1f1f1;
    --bg-lightpink: #ffeced;
    --bg-red: #d70146;
    --color-base: #1a1a1a;
    --color-gray: #4d4d4d;
    --color-primary: #f81363;
    --color-secondary: #fb89b1;
    --container-width: 780px;
    --font-en: "Oswald", sans-serif;
}

body {
    color: var(--color-base);
    font-family: YakuHanJP, "Noto Sans JP", sans-serif;
    font-feature-settings: "palt";
    font-optical-sizing: auto;
    font-size: 13px;
    line-height: 1.6;
}

img {
    max-width: 100%;
}

h1,
h2,
h3,
h4 {
    font-weight: 700;
}

select {
    border: 1px solid var(--color-gray);
}

.sp-only {
    display: none;
}

/* ========================================
   Header
======================================== */

.header {
    padding: 22px 0 18px;
    position: relative;
}

.header-logo {
    position: absolute;
    top: 12px;
    left: 18px;
    width: 200px;
}

.header-text {
    font-size: 20px;
    font-weight: 700;
    margin: 0 250px;
    text-align: center;
}

/* nav */
.fixed-nav {
    background-color: rgba(255, 255, 255, 0.85);
    padding: 20px 0;
    position: sticky;
    top: 0;
    width: 100%;
    z-index: 99;
}

.nav-list {
    display: flex;
    justify-content: center;
}

.nav-list li {
    background-position: center top 2px;
    background-repeat: no-repeat;
    background-size: 23px;
}

.nav-item-01 {
    background-image: url(/wp/wp-content/themes/renaissance/images/icon_nav_01.svg);
}

.nav-item-02 {
    background-image: url(/wp/wp-content/themes/renaissance/images/icon_nav_02.svg);
}

.nav-item-03 {
    background-image: url(/wp/wp-content/themes/renaissance/images/icon_nav_03.svg);
}

.nav-item-04 {
    background-image: url(/wp/wp-content/themes/renaissance/images/icon_nav_04.svg);
}

.nav-list li:not(:first-child) {
    border-left: 1px solid var(--color-base);
}

.nav-list li a {
    display: block;
    font-weight: 700;
    padding: 22px 40px 0;
    text-align: center;
    transition: 0.2s;
}

.nav-list li:hover {
    color: var(--color-primary);
}

/* ========================================
   Footer
======================================== */

.footer {
    background: var(--bg-red);
    padding: 65px 0 15px;
}

.footer-contact {
    align-items: flex-start;
    display: flex;
    margin: 0 auto;
    width: var(--container-width);
}

.footer-contact dl {
    align-items: center;
    color: #ffffff;
    display: flex;
    flex-direction: column;
    padding: 12px 0 22px;
    text-align: center;
    width: 50%;
}

.footer-contact dl:last-child {
    border-left: 1px solid rgba(255, 255, 255, 0.5);
}

.footer-contact dl dt {
    align-items: center;
    display: flex;
    font-size: 16px;
    min-height: 3em;
    justify-content: center;
    line-height: 1.4;
    text-align: center;
}

.footer-contact dl dd {
    margin-top: 16px;
}

.copyright {
    color: var(--color-secondary);
    font-size: 10px;
    line-height: 1;
    margin: 55px 0 0 0;
    text-align: center;
}

/* ========================================
   共通要素（ボタン・見出し・レイアウトなど）
======================================== */

/* details */
details {
    cursor: pointer;
}

summary {
    list-style: none;
}

summary::-webkit-details-marker {
    display: none;
}

.plus-circle {
    background-color: var(--color-gray);
    border-radius: 50%;
    display: inline-block;
    height: 13px;
    margin: 0 0 0 0.25em;
    position: relative;
    vertical-align: -0.25em;
    width: 13px;
}

.plus-circle::before,
.plus-circle::after {
    background-color: #ffffff;
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    transition: 0.3s;
}

.plus-circle::before {
    height: 60%;
    width: 1px;
}

.plus-circle::after {
    height: 1px;
    width: 60%;
}

details[open] .plus-circle::before {
    content: none;
}

/* arrow */
.arrow {
    background: url(/wp/wp-content/themes/renaissance/images/arrow_down.svg)
        no-repeat center;
    height: 40px;
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    width: 12px;
}

/* button */
.button {
    background-color: var(--color-primary);
    border: 1px solid #ffffff;
    border-radius: 25px;
    color: #ffffff;
    display: block;
    font-size: 15px;
    font-weight: 700;
    margin: 0 auto;
    padding: 12px 0;
    position: relative;
    text-align: center;
    transition: 0.3s;
    width: 220px;
}

.button:hover {
    scale: 1.025;
}

.button-outline {
    background-color: #ffffff;
    border-color: var(--color-primary);
    color: var(--color-primary);
}

.button::before,
.button::after {
    content: "";
    margin: auto;
    position: absolute;
    top: 0;
    right: 12px;
    bottom: 0;
    vertical-align: middle;
}

.button::before {
    background-color: #ffffff;
    border-radius: 50%;
    height: 12px;
    width: 12px;
}

.button::after {
    border-top: 1px solid var(--color-primary);
    border-right: 1px solid var(--color-primary);
    height: 5px;
    right: 17px;
    transform: rotate(45deg);
    width: 5px;
}

.button-outline::before {
    background-color: var(--color-primary);
}

.button-outline::after {
    border-top-color: #ffffff;
    border-right-color: #ffffff;
}

.button-icon-pin {
    background: url(/wp/wp-content/themes/renaissance/images/icon_pin_white.svg)
        no-repeat center left;
    background-size: 12px;
    padding: 0 0 0 16px;
}

.button-outline .button-icon-pin {
    background-image: url(/wp/wp-content/themes/renaissance/images/icon_pin_pink.svg);
}

/* entry */
.entry {
    display: none;
}

.entry-circle {
    aspect-ratio: 1;
    background: linear-gradient(-45deg, #00d001 30%, #00c901 75%);
    border-radius: 100%;
    color: #ffffff;
    display: flex;
    filter: drop-shadow(5px 5px 3px rgba(0, 0, 0, 0.15));
    font-size: 20px;
    font-weight: 700;
    padding: 34px 0 0 0;
    justify-content: center;
    position: relative;
    text-align: center;
    transition: 0.3s;
    width: 128px;
    will-change: filter;
}

.entry-circle:hover {
    scale: 1.05;
}

.entry-circle::after {
    border-right: 2px solid #ffffff;
    border-bottom: 2px solid #ffffff;
    content: "";
    display: inline-block;
    height: 14px;
    margin-right: -2px;
    position: absolute;
    top: 80px;
    right: 50%;
    transform: rotate(-45deg);
    width: 14px;
}

.entry-sticky {
    display: none;
    position: fixed;
    bottom: 20px;
    right: 20px;
    transition: opacity 0.3s, transform 0.3s;
}

.entry-sticky.is-visible {
    display: block;
}

.entry-sticky.is-absolute {
    position: absolute;
    top: auto;
    bottom: 400px;
}

/* link */
.link-text {
    color: #0000ff;
    text-decoration: underline;
    transition: 0.2s;
}

.link-text:hover {
    text-decoration: none;
}

/* container */
.section-container {
    margin: 0 auto;
    width: var(--container-width);
}

/* heading */
.section-common-header.has-bg {
    background: var(--bg-pink);
    margin: 0 calc(50% - 50vw) 30px;
    padding: 30px 0 23px;
    width: 100vw;
}

.section-common-heading {
    color: var(--color-primary);
    font-size: 23px;
    text-align: center;
}

.section-common-header.has-bg .section-common-heading {
    color: #ffffff;
}

.section-common-heading span {
    display: table;
    font-family: var(--font-en);
    font-size: 0.56em;
    font-style: italic;
    font-weight: 400;
    letter-spacing: 0.1em;
    margin: 4px auto 0;
    padding: 0 15px;
    position: relative;
}

.section-common-heading span::before,
.section-common-heading span::after {
    border: 1px solid;
    content: "";
    display: block;
    height: 1px;
    position: absolute;
    top: 0.75em;
    width: 10px;
}

.section-common-heading span::before {
    left: 0;
}

.section-common-heading span::after {
    right: 0;
}

/* notes */
.notes {
    color: var(--color-gray);
    font-size: 11px;
    line-height: 1.45;
    text-align: justify;
}

/* animation */
.fade-in {
    opacity: 0;
    transition-property: opacity;
    transition-duration: 600ms;
    transition-delay: 0.6s;
    transition-timing-function: cubic-bezier(0.455, 0.03, 0.515, 0.955);
}

.fade-in.is-visible {
    opacity: 1;
}

/* ========================================
   各セクションごとの要素
======================================== */

/* ----------------------------------------
   MV
---------------------------------------- */

.hero-area {
    background: url(/wp/wp-content/themes/renaissance/images/bg_hero.png)
            no-repeat center top,
        var(--bg-pink);
    background-size: cover;
    margin-top: -82px;
    padding: 120px 0 46px;
}

/* mv */
.mv-section {
    margin: 0 auto 50px;
    max-width: 1150px;
}

/* campaign */
.campaign-section .section-container {
    width: 870px;
}

.campaign-heading {
    margin: 0 auto 22px;
    width: 580px;
}

.campaign-period {
    color: #ffffff;
    font-size: 18px;
    font-weight: 700;
    line-height: 1;
    margin: 0 0 46px;
    text-align: center;
}

.campaign-period span {
    font-family: var(--font-en);
    font-size: 45px;
}

.campaign-block {
    display: flex;
    column-gap: 30px;
    margin: 0 0 11px;
}

.campaign-item {
    background-color: #ffeced;
    border-radius: 12px;
    flex: 1;
    padding: 40px 24px 20px;
    position: relative;
}

.campaign-item-heading {
    position: absolute;
    top: -22px;
    left: 50%;
    transform: translateX(-50%);
    width: 324px;
}

.campaign-section .notes {
    color: #ffffff;
}

.campaign-notes-gymtrial {
    margin: 8px 0 0 0;
}

.campaign-notes-gymtrial dt {
    border: 1px solid;
    display: inline-block;
    font-weight: 400;
    margin: 0 0 5px;
    padding: 2px 5px;
}

.reference-date {
    margin: 4px 0 0 0;
    text-align: right;
}

/* ----------------------------------------
   News
---------------------------------------- */

.news-section {
    padding: 48px 0 40px;
}

.news-none {
    font-size: 15px;
    font-weight: 500;
    margin: 6px 0 0 0;
    text-align: center;
}

.news-post {
    border-bottom: 1px solid #e5e5e5;
}

.news-post:not(:has(a)) {
    padding: 16px 100px 23px 5px;
}

.news-post a {
    display: block;
    padding: 16px 100px 23px 5px;
    position: relative;
}

.news-post a::after {
    border-top: 1px solid var(--color-primary);
    border-right: 1px solid var(--color-primary);
    content: "";
    height: 10px;
    position: absolute;
    top: 50%;
    right: 15px;
    transform: rotate(45deg) translateY(-50%);
    width: 10px;
}

.news-date {
    color: #989898;
    font-size: 15px;
    font-weight: 500;
    margin: 0 0 6px;
}

.news-heading {
    font-weight: 500;
}

/* ----------------------------------------
   Information
---------------------------------------- */

.information-section {
    background: url(/wp/wp-content/themes/renaissance/images/bg_information_01.jpg)
        no-repeat center bottom;
    background-size: auto 100%;
    padding: 106px 0 80px;
}

.information-section .section-container {
    background: url(/wp/wp-content/themes/renaissance/images/img_information_map.png)
        no-repeat right top;
    background-size: 336px;
    padding: 17px 0 0;
}

.information-heading {
    margin: 0 0 20px;
    width: 622px;
}

.information-text {
    margin: 0 0 68px;
    position: relative;
    width: 322px;
}

.information-text-number {
    position: absolute;
    top: 20px;
    left: 74px;
    transition-property: opacity, top;
    width: 166px;
}

.information-text-number.fade-in.is-visible {
    top: 0;
}

.information-section .button {
    width: 280px;
}

/* ----------------------------------------
   Concern
---------------------------------------- */

/* intro */
.concern-intro {
    background: url(/wp/wp-content/themes/renaissance/images/bg_concern_intro_01.jpg)
        no-repeat center bottom;
    background-size: cover;
    padding: 38px 0 62px;
    position: relative;
}

.concern-intro-heading {
    margin: 0 auto 30px;
    width: 425px;
}

.concern-intro-balloon {
    margin: 0 auto;
    position: relative;
    width: 545px;
}

.concern-intro-balloon li:first-child {
    margin: 0 0 0 32px;
    width: 144px;
}

.concern-intro-balloon li:nth-child(2) {
    position: absolute;
    top: 72px;
    right: 0;
    transition-delay: 0.8s;
    width: 163px;
}

.concern-intro-balloon li:nth-child(3) {
    margin: 72px 0 0 54px;
    transition-delay: 1s;
    width: 162px;
}

.concern-intro .arrow {
    bottom: -25px;
}

/* point */
.concern-point {
    background-color: var(--bg-lightpink);
    padding: 90px 0 115px;
}

.concern-point-heading {
    margin: 0 auto 50px;
    width: 505px;
}

.concern-point-item {
    background-color: #ffffff;
    border-radius: 10px;
    padding: 35px 40px 35px 45px;
    position: relative;
}

.concern-point-item:not(:last-of-type) {
    margin-bottom: 40px;
}

.point-item-icon {
    position: absolute;
    top: -30px;
    left: -40px;
    width: 88px;
}

.point-item-flex {
    align-items: center;
    display: flex;
    flex-direction: row-reverse;
}

.point-item-text {
    flex: 1;
}

.point-item-image {
    border-radius: 10px;
    overflow: hidden;
    width: 350px;
}

.point-item-heading {
    color: var(--color-primary);
    font-size: 20px;
    line-height: 1.35;
    margin: 0 0 10px;
}

.point-item-text p {
    margin-right: 35px;
}

.point-item-text p.notes {
    margin-top: 5px;
}

.point-notes {
    margin-top: 10px;
    text-align: right;
}

.point-gate {
    margin: 25px 0 0 0;
}

.gate-flow {
    border: 1px solid var(--color-primary);
    border-radius: 10px;
    display: flex;
    margin: 0 0 10px;
    padding: 12px 0;
}

.gate-flow li {
    flex: 1;
    padding: 3px 0 15px;
    text-align: center;
}

.gate-flow li:nth-child(2) {
    border-left: 1px solid var(--color-primary);
    border-right: 1px solid var(--color-primary);
}

.gate-flow dl dt {
    background-color: var(--color-secondary);
    border-radius: 5px;
    color: #ffffff;
    display: inline-block;
    font-family: var(--font-en);
    font-size: 13px;
    font-weight: 400;
    padding: 0 8px;
    margin: 0 0 10px;
}

.gate-flow dl dd {
    font-size: 15px;
    font-weight: 500;
    line-height: 1.3;
}

.gate-text {
    color: var(--color-primary);
    font-size: 20px;
    font-weight: 700;
    padding: 18px 0 4px;
    position: relative;
    text-align: center;
}

.gate-text::before {
    border-right: 1px solid var(--color-primary);
    border-bottom: 1px solid var(--color-primary);
    content: "";
    display: inline-block;
    height: 15px;
    position: absolute;
    top: -5px;
    left: 50%;
    transform: translateX(-50%) rotate(45deg);
    width: 15px;
}

.point-gate .notes {
    text-align: center;
}

/* ----------------------------------------
   Facility
---------------------------------------- */

.facility-section {
    background: url(/wp/wp-content/themes/renaissance/images/bg_facility.jpg)
        no-repeat center top;
    background-size: cover;
    padding: 85px 0 35px;
}

.facility-section .section-container {
    /* width: 840px; */
}

.facility-heading {
    margin: 0 auto 16px;
    width: 425px;
}

.facility-lead {
    font-size: 15px;
    font-weight: 500;
    text-align: center;
}

.facility-item {
    align-items: center;
    display: flex;
    gap: 0 15px;
    margin: 40px 0 0 0;
}

.facility-item:nth-of-type(2) {
    flex-direction: row-reverse;
}

.facility-item-text {
    flex: 1;
}

.facility-item-heading {
    color: #31c4ce;
    font-family: var(--font-en);
    font-style: italic;
    font-size: 47px;
    line-height: 1;
    margin: 0 0 9px;
}

.facility-item-text .notes {
    margin-top: 5px;
}

.facility-item-image {
    width: 480px;
}

/* ----------------------------------------
   Plan
---------------------------------------- */

.plan-section {
    background: var(--bg-pink);
    padding: 80px 0 125px;
}

.plan-header-heading {
    margin: 0 auto 22px;
    width: 365px;
}

.plan-header-image {
    display: flex;
    gap: 0 16px;
    justify-content: center;
}

.plan-header-image p {
    align-items: center;
    background: url(/wp/wp-content/themes/renaissance/images/bg_plan_header_text.png)
        no-repeat center;
    background-size: 100%;
    color: #ffffff;
    display: flex;
    font-size: 15px;
    font-weight: 500;
    justify-content: center;
    line-height: 1.5;
    height: 158px;
    margin: 12px 0 0 0;
    text-align: center;
    width: 196px;
}

.plan-header-image img {
    width: 135px;
}

.plan-contents {
    margin: 0 10px;
}

.plan-recommended {
    overflow: hidden;
}

.plan-recommended::after {
    border: 6px solid #ffff00;
    content: "";
    display: block;
    height: 100%;
    pointer-events: none;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
}

.plan-recommended-text {
    background-color: #ffff00;
    font-size: 20px;
    font-weight: 700;
    padding: 9px 0;
    position: absolute;
    top: 0;
    left: 0;
    text-align: center;
    width: 100%;
}

.plan-item {
    background-color: #ffffff;
    border-radius: 20px;
    padding: 25px 30px 38px;
    position: relative;
}

.plan-item:not(:last-child) {
    margin-bottom: 40px;
}

.plan-item.plan-recommended {
    padding-top: 64px;
}

.plan-name {
    color: var(--color-primary);
    font-size: 29px;
    margin: 0 0 18px;
    text-align: center;
}

.plan-item-flex {
    display: flex;
}

.plan-item-left {
    width: 350px;
}

.plan-item-right {
    border-left: 1px solid #dcdddd;
    flex: 1;
    padding: 5px 0 0 30px;
}

.plan-tagline {
    font-size: 15px;
    font-weight: 500;
}

.plan-school-tagline {
    margin-top: -12px;
    margin-bottom: 12px;
    text-align: center;
}

.plan-fee-gymtrial {
    font-size: 20px;
    font-weight: 500;
    line-height: 1.4;
}

.plan-fee {
    align-items: flex-end;
    display: flex;
    font-weight: 500;
    line-height: 1;
}

.plan-fee dt {
    font-size: 17px;
    line-height: 1.5;
}

.plan-fee dd {
    color: var(--color-primary);
    font-size: 20px;
}

.plan-fee dd b {
    font-family: var(--font-en);
    font-size: 80px;
    letter-spacing: -0.02em;
    margin-right: 0.05em;
}

.plan-fee dd span {
    color: var(--color-base);
    font-size: 13px;
}

.plan-inclusions {
    display: flex;
    justify-content: space-between;
}

.plan-inclusions li {
    background-color: #e5e5e5;
    border-radius: 12px;
    color: #989898;
    padding: 0 10px 1px;
}

.plan-inclusions li.is-active {
    background-color: var(--bg-lightpink);
    color: var(--color-base);
}

.inclusions-note {
    color: var(--color-gray);
    margin-top: 14px;
    text-align: center;
}

.plan-hours {
    display: table;
    margin: 8px auto 0;
}

.plan-hours p:not([class]) {
    font-size: 15px;
    text-align: center;
}

.plan-notes {
    margin: 15px 0 0 0;
}

.plan-notes summary + * {
    margin: 33px 0 0 0;
}

.plan-notes .mark::before {
    content: "※";
}

.plan-link-detail {
    color: var(--color-primary);
    display: block;
    font-weight: 500;
    margin: 10px 0;
    text-align: center;
}

.plan-link-detail span {
    padding: 0 15px 0 0;
    position: relative;
}

.plan-link-detail span::before,
.plan-link-detail span::after {
    content: "";
    margin: auto;
    position: absolute;
    top: 1px;
    right: 0;
    bottom: 0;
    vertical-align: middle;
}

.plan-link-detail span::before {
    background-color: var(--color-primary);
    border-radius: 50%;
    height: 12px;
    width: 12px;
}

.plan-link-detail span::after {
    border-top: 1px solid #ffffff;
    border-right: 1px solid #ffffff;
    height: 5px;
    right: 5px;
    transform: rotate(45deg);
    width: 5px;
}

.school-trial-heading {
    background-color: var(--color-primary);
    border-radius: 15px;
    color: #ffffff;
    font-size: 15px;
    margin: 0 auto 18px;
    padding: 3px 0;
    text-align: center;
    width: 310px;
}

.school-trial-flex {
    display: flex;
    gap: 0 20px;
    margin: 0 0 13px;
    justify-content: center;
}

.school-trial-flex-item {
    background-color: var(--bg-lightpink);
    border-radius: 10px;
    padding: 11px 0 15px;
    width: 310px;
}

.school-trial-flex-item dt {
    font-weight: 500;
    margin: 0 0 3px;
    text-align: center;
}

.school-trial-link {
    display: flex;
    gap: 0 10px;
    justify-content: center;
}

.school-trial-link li {
    font-weight: 500;
}

.school-trial-link li .button {
    font-size: 13px;
    padding: 2px 8px;
    text-align: left;
    width: 90px;
}

.school-trial-link li .button::before {
    right: 5px;
}

.school-trial-link li .button::after {
    right: 10px;
}

.school-trial-fee {
    font-size: 15px;
    font-weight: 500;
    text-align: center;
}

.school-trial-fee b {
    color: var(--color-primary);
    font-weight: 500;
    margin-right: 0.25em;
}

.school-trial-fee + .notes {
    text-align: center;
}

.plan-school-campaign {
    border: 1px solid var(--color-primary);
    border-radius: 10px;
    margin: 7px auto 12px;
    overflow: hidden;
    width: 400px;
}

.plan-school-campaign h4 {
    background-color: var(--color-primary);
    color: #ffffff;
    font-size: 17px;
    padding: 5px 0 6px;
    text-align: center;
}

.plan-school-campaign h4 span {
    font-size: 13px;
    margin-left: 1em;
}

.plan-school-campaign dl {
    align-items: center;
    display: flex;
    line-height: 1;
    padding: 5px 0 15px;
    justify-content: center;
}

.plan-school-campaign dl dt {
    font-size: 15px;
    font-weight: 500;
}

.plan-school-campaign dl dt br {
    display: none;
}

.plan-school-campaign dl dd {
    color: var(--color-primary);
    font-size: 20px;
    margin: 0 0 0 18px;
    vertical-align: middle;
}

.plan-school-campaign dl dd b {
    display: inline-block;
    font-family: var(--font-en);
    font-size: 80px;
    letter-spacing: -0.02em;
    margin-right: 0.05em;
}

.online-coupon-code {
    border: 1px solid #cbcbcb;
    border-radius: 10px;
    display: table;
    font-weight: 500;
    margin: 0 0 10px;
    overflow: hidden;
    vertical-align: middle;
}

.online-coupon-code dt,
.online-coupon-code dd {
    display: table-cell;
    line-height: 1;
    text-align: center;
}

.online-coupon-code dt {
    background-color: var(--bg-lightgray);
    vertical-align: inherit;
    width: 110px;
}

.online-coupon-code dd {
    font-family: var(--font-en);
    font-size: 23px;
    padding: 19px 0;
    width: 158px;
}

/* ----------------------------------------
   Need
---------------------------------------- */

.need-section {
    background-color: var(--bg-lightpink);
    padding: 63px 0 80px;
}

.need-section .section-common-heading {
    color: var(--color-base);
}

.need-section .section-common-heading span {
    color: var(--color-primary);
}

.need-lead {
    font-size: 15px;
    font-weight: 500;
    margin: 6px 0 0 0;
    text-align: center;
}

.tab-list {
    display: flex;
    column-gap: 10px;
    margin: 23px auto 30px;
    width: 360px;
}

.tab-item {
    background-color: #ffffff;
    border: 1px solid var(--color-secondary);
    border-radius: 5px;
    color: var(--color-secondary);
    cursor: pointer;
    flex: 1;
    font-size: 17px;
    font-weight: 500;
    padding: 8px 0;
    position: relative;
    text-align: center;
}

.tab-item.is-active::after {
    background-color: var(--color-primary);
    clip-path: polygon(0% 0%, 50% 100%, 100% 0%);
    content: "";
    display: block;
    height: 8px;
    position: absolute;
    bottom: -8px;
    left: 50%;
    transform: translateX(-50%);
    width: 15px;
}

.tab-item.is-active {
    background-color: var(--color-primary);
    color: #ffffff;
}

.tab-panel.is-active {
    display: block;
}

.tab-panel {
    display: none;
}

.need-target-members {
    background-color: #ffffff;
    border-radius: 6px;
    overflow: hidden;
}

.need-target-members dt {
    background-color: var(--color-primary);
    color: #ffffff;
    font-size: 15px;
    padding: 8px 0;
    text-align: center;
}

.need-target-members dd {
    padding: 12px 50px;
}

.target-members-list {
    display: flex;
    flex-wrap: wrap;
    gap: 5px 25px;
    justify-content: center;
}

.target-members-list-row {
    align-items: center;
    flex-direction: column;
}

.target-members-list li {
    font-size: 17px;
    font-weight: 500;
}

.target-members-list-column li,
.target-members-list-row li {
    text-align: left;
    width: 15em;
}

.target-members-list li::before {
    content: "●";
}

.need-block:not(:last-child) {
    margin-bottom: 58px;
}

.need-list .notes {
    font-size: 13px;
}

.need-list li {
    margin: 12px 0 0 0;
}

.need-list li:not(:last-of-type) {
    margin-bottom: 11px;
}

.need-list li summary + .notes {
    margin-top: 8px;
}

.need-list .plus-circle {
    vertical-align: -0.1em;
}

.need-list-text {
    background: url(/wp/wp-content/themes/renaissance/images/icon_checkbox.svg)
        no-repeat left top 0.23em;
    background-size: 16px;
    font-size: 17px;
    font-weight: 700;
    line-height: 1.4;
    padding: 0 0 0 18px;
}

.need-list-text .notes {
    font-weight: 400;
}

.need-list-id-wrap {
    display: flex;
}

.need-list-id-wrap > .need-list-text {
    flex: 0 0 calc(6em + 36px);
}

.need-list-id-detail dl {
    display: flex;
    gap: 0 9px;
}

.need-list-id-detail dl dt {
    flex-shrink: 0;
    font-size: 15px;
    font-weight: 500;
}

.need-list-id-detail dl dd {
    font-size: 14px;
    font-weight: 500;
    padding: 0.06em 0 0 0;
}

.need-list-id-detail dl dd a {
    background: url(/wp/wp-content/themes/renaissance/images/icon_pdf.png)
        no-repeat left top;
    background-size: 1em;
    color: var(--color-primary);
    display: block;
    padding: 0 0 0 1em;
}

.need-list .need-list-id-wrap .plus-circle {
    align-self: flex-end;
    margin-bottom: 0.25em;
}

.payment-notes {
    font-size: 13px;
    font-weight: 500;
    line-height: 1.4;
    margin: 8px 0 3px;
}

.payment-notes span {
    font-weight: 400;
}

.need-notes-cashless {
    border: 1px solid;
    font-size: 14px;
    margin: 16px 0 0 0;
    padding: 12px 40px;
}

/* ----------------------------------------
   Loss
---------------------------------------- */

.loss-section {
    background-color: var(--bg-lightpink);
    padding: 0 0 65px;
}

.loss-section .section-common-header {
    margin-bottom: 10px;
}

.loss-section .section-common-heading {
    color: var(--color-base);
}

.loss-section .section-common-heading span {
    color: var(--color-primary);
}

/* ----------------------------------------
   Admission
---------------------------------------- */

.admission-section {
    padding: 0 0 100px;
}

.admission-lead {
    font-weight: 700;
    margin: 0 0 36px;
    text-align: center;
}

.admission-varies {
    background-color: #fff9e5;
    border-radius: 10px;
    margin: 0 50px 60px;
    padding: 30px 40px 45px;
    position: relative;
}

.admission-varies-heading {
    color: var(--color-primary);
    font-size: 15px;
    font-weight: 700;
    margin: 0 0 20px;
    text-align: center;
}

.admission-varies-flex {
    display: flex;
    gap: 0 20px;
    margin: 0 0 10px;
}

.admission-varies-flex-item {
    flex: 1;
    text-align: center;
}

.admission-varies-flex-item dt {
    font-size: 11px;
    font-weight: 500;
    margin: 0 0 10px;
}

.admission-varies-flex-item dd {
    border: 1px solid #cbcbcb;
    border-radius: 5px;
    overflow: hidden;
}

.admission-varies .arrow {
    bottom: -26px;
}

.club-list {
    border: 1px solid var(--color-primary);
}

.club-list:not(:last-of-type) {
    margin-bottom: 40px;
}

.club-list#list02_sp {
    border-color: #012f6e;
}

.club-list#list03_sp {
    border-color: #3eb58c;
}

.club-list#list04_sp {
    border-color: #f38900;
}

.club-list#list05_sp {
    border-color: #051d3e;
}

.club-list-heading {
    background: var(--bg-lightpink)
        url(/wp/wp-content/themes/renaissance/images/bg_clug_heading.png)
        no-repeat left 215px top 8px;
    background-size: 67px;
    color: var(--color-primary);
    font-size: 20px;
    padding: 28px 0;
    position: relative;
    text-align: center;
}

.club-list-heading:after {
    background: url(/wp/wp-content/themes/renaissance/images/icon_alert_01.svg)
        no-repeat;
    background-size: contain;
    content: "";
    cursor: pointer;
    display: inline-block;
    height: 30px;
    position: absolute;
    top: 50%;
    right: 18px;
    transform: translateY(-50%);
    width: 30px;
}

.club-list-alert {
    display: none;
    margin: 0 auto;
    padding: 20px 30px 18px;
}

.club-list-alert-heading {
    color: var(--bg-red);
    margin: 0 0 8px;
}

.club-list-alert-text {
    line-height: 1.5;
    padding-left: 1em;
    position: relative;
}

.club-list-alert-text::before {
    content: "・";
    position: absolute;
    top: 0;
    left: 0.25em;
}

.club-list .plus-icon {
    display: inline-block;
    height: 10px;
    position: absolute;
    top: 50%;
    left: 55px;
    transform: translateY(-50%);
    width: 10px;
}

.club-list .plus-icon::before,
.club-list .plus-icon::after {
    background-color: var(--color-base);
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    transition: 0.3s;
}

.club-list .plus-icon::before {
    height: 100%;
    width: 2px;
}

.club-list .plus-icon::after {
    height: 2px;
    width: 100%;
}

.club-list details[open] > summary > .plus-icon::before {
    content: none;
}

.area-block {
    border-bottom: 1px solid #ffffff;
}

.area-heading {
    background-color: var(--bg-red);
    color: #ffffff;
    font-size: 21px;
    padding: 12px 30px;
}

.prefecture-name {
    background-color: var(--bg-lightgray);
    font-size: 19px;
    font-weight: 700;
    padding: 12px 30px 12px 80px;
    position: relative;
}

.prefecture-name + ul {
    overflow: hidden;
    transition: height 0.3s ease-out;
}

.club-item {
    border-bottom: 1px solid #e5e5e5;
}

.club-name {
    font-size: 17px;
    font-weight: 700;
    padding: 9px 30px 9px 80px;
    position: relative;
}

.tag-oasis {
    border-radius: 2px;
    background-color: #0071bb;
    color: #ffffff;
    font-size: 13px;
    line-height: 1;
    margin: 0 0 0 10px;
    padding: 0 5px;
}

.club-content {
    overflow: hidden;
    padding: 0 50px 50px;
    transition: height 0.3s ease-out;
}

.club-content .button {
    margin-top: 20px;
    margin-bottom: 25px;
}

.club-address {
    display: flex;
    gap: 0 8px;
    margin: 6px 0 0 0;
}

.club-address dt {
    width: 48px;
}

.club-address dt span {
    background-color: #808080;
    border-radius: 2px;
    color: #ffffff;
    display: inline-block;
    font-size: 11px;
    text-align: center;
    width: 100%;
}

.club-address dd {
    width: calc(100% - 48px);
}

.club-map {
    aspect-ratio: 680 / 330;
    margin: 25px 0 0 0;
}

.club_info_body .club-map {
    margin-top: 13px;
}

.club-map iframe {
    height: 100%;
    width: 100%;
}

/* ----------------------------------------
   Trial
---------------------------------------- */

.trial-section {
    background-color: var(--bg-lightpink);
    padding: 65px 0;
}

.trial-block {
    background-color: #ffffff;
    border-radius: 10px;
    padding: 35px 50px;
}

.trial-block + .trial-block {
    margin-top: 25px;
}

.trial-heading {
    margin: 0 auto;
    width: 325px;
}

.trial-illust {
    margin: 12px auto;
    width: 157px;
}

.trial-button-group {
    display: flex;
    gap: 0 20px;
}

h2 + .trial-button-group {
    margin-top: 25px;
}

.trial-button-group li {
    flex: 1;
}

.trial-button-group .button {
    width: 100%;
}

.trial-coupon-group {
    margin: 18px 0 0 0;
}

.trial-coupon-group p {
    text-align: center;
}

.trial-coupon-text {
    font-weight: 700;
}

.trial-coupon-image {
    margin: 16px auto 0;
    width: 315px;
}

.trial-coupon-image a {
    transition: 0.3s;
}

.trial-coupon-image a:hover {
    opacity: 0.8;
}

.trial-coupon-notes {
    font-size: 10px;
    font-weight: 500;
    margin: 5px 0 0 0;
}

.trial-notes {
    color: var(--color-gray);
    margin: 30px 0 0 0;
}

.trial-notes-heading {
    font-size: 19px;
    margin: 0 0 8px;
    text-align: center;
}

.trial-notes-subheading {
    font-weight: 400;
}

.trial-notes-list li::before {
    content: "●";
    font-size: 0.7em;
    margin: 0 0.2em 0 0;
    vertical-align: 0.1em;
}

/* ----------------------------------------
   FAQ
---------------------------------------- */

.faq-section {
    padding: 0 0 46px;
}

.faq-section .section-container {
    padding: 0 50px;
}

.faq-item {
    border-bottom: 1px solid #e5e5e5;
    padding: 32px 0;
}

.faq-question {
    font-size: 17px;
    font-weight: 500;
    line-height: 1.5;
    padding: 0 60px 0 35px;
    position: relative;
}

.faq-question::before {
    color: var(--color-primary);
    content: "Q.";
    font-size: 13px;
    font-weight: 500;
    position: absolute;
    left: 18px;
}

.faq-question .plus-icon {
    display: inline-block;
    height: 14px;
    position: absolute;
    top: 6px;
    right: 30px;
    width: 14px;
}

.faq-question .plus-icon::before,
.faq-question .plus-icon::after {
    background-color: var(--color-secondary);
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    transition: 0.3s;
}

.faq-question .plus-icon::before {
    height: 100%;
    width: 2px;
}

.faq-question .plus-icon::after {
    height: 2px;
    width: 100%;
}

details[open] .faq-question .plus-icon::before {
    content: none;
}

.faq-answer {
    color: var(--color-gray);
    font-size: 15px;
    overflow: hidden;
    padding: 15px 60px 0 35px;
    position: relative;
    transition: height 0.3s ease-out;
}

.faq-answer::before {
    color: var(--color-primary);
    content: "A.";
    font-weight: 500;
    position: absolute;
    left: 20px;
}

.faq-answer p + p:not(.notes) {
    margin-top: 20px;
}

.faq-bottom-text {
    font-size: 17px;
    font-weight: 500;
    margin: 30px 0 0 0;
    text-align: center;
}

.faq-bottom-text br {
    display: none;
}

/* ----------------------------------------
   Others
---------------------------------------- */

.others {
    background-color: var(--bg-lightgray);
    padding: 0 0 60px;
}

.others .section-common-header.has-bg {
    background: var(--bg-lightgray);
}

.others .section-common-header.has-bg .section-common-heading {
    color: #012f6e;
}

.others-list {
    display: flex;
    gap: 0 20px;
    margin: 0 auto;
    justify-content: center;
    width: 720px;
}

.others-list li {
    max-width: 350px;
}

.others-list li a {
    transition: 0.3s;
}

.others-list li a:hover {
    opacity: 0.8;
}

/* Media Queries
-------------------------------------------------- */

@media only screen and (max-width: 768px) {
    :root {
        --container-width: max(89.74vw, 350px);
    }

    body {
        line-height: 1.5;
        padding-bottom: 46px;
    }

    .sp-only {
        display: block;
    }

    .pc-only {
        display: none;
    }

    /* ========================================
   Header
======================================== */

    .header {
        padding: 8px 3px 3px;
    }

    .header-logo {
        margin: 0 auto;
        position: static;
        width: 135px;
    }

    .header-text {
        font-size: 17px;
        margin: 0.25em 0 0;
    }

    /* nav */
    .fixed-nav {
        padding: 5px 0;
        position: static;
        top: auto;
    }

    .fixed-nav.fixed-bottom {
        box-shadow: 0 -2px 8px rgba(0, 0, 0, 0.1);
        position: fixed;
        bottom: 0;
        left: 0;
    }

    .nav-list li {
        background-size: 20px;
    }

    .nav-list li:not(:first-child) {
        border-left-color: #e5e5e5;
    }

    .nav-list li a {
        font-size: 11px;
        padding: 20px 18px 0;
    }

    /* ========================================
   Footer
======================================== */

    .footer {
        padding: 42px 0 12px;
    }

    .footer-contact {
        flex-direction: column;
        flex-wrap: wrap;
        row-gap: 17px;
    }

    .footer-contact dl {
        padding: 0;
        width: 100%;
    }

    .footer-contact dl:last-child {
        border-left: none;
    }

    .footer-contact dl dt {
        font-size: 16px;
        min-height: initial;
    }

    .footer-contact dl:first-child dt {
        font-size: 20px;
    }

    .footer-contact dl dd {
        margin-top: 13px;
    }

    .copyright {
        margin-top: 40px;
    }

    /* ========================================
   共通要素（ボタン・見出し・レイアウトなど）
======================================== */

    /* entry */
    .entry {
        animation: anime_cvbtn 0.5s ease 0s infinite alternate;
        background: linear-gradient(-90deg, #00d001 48%, #00c901 52%);
        border-radius: 33px;
        color: #ffffff;
        display: block;
        font-size: 20px;
        font-weight: 700;
        margin: 35px auto 0;
        padding: 18px 0;
        position: relative;
        text-align: center;
        width: 310px;
    }

    .entry::after {
        border-right: 2px solid #ffffff;
        border-bottom: 2px solid #ffffff;
        content: "";
        display: inline-block;
        height: 14px;
        margin-top: -7px;
        position: absolute;
        top: 50%;
        right: 18px;
        transform: rotate(-45deg);
        width: 14px;
    }

    @keyframes anime_cvbtn {
        from {
            transform: scale(0.95, 0.95);
        }
        to {
            transform: scale(1, 1);
        }
    }

    .entry-sticky.is-visible {
        display: none;
    }

    /* ========================================
   各セクションごとの要素
======================================== */

    /* ----------------------------------------
   MV
---------------------------------------- */

    .hero-area {
        background-image: url(/wp/wp-content/themes/renaissance/images/bg_hero_sp.png),
            var(--bg-pink);
        margin-top: 0;
        padding-top: 9px;
        padding-bottom: 25px;
    }

    /* mv */
    .mv-section {
        margin-bottom: 12px;
        width: 100%;
        max-width: var(--container-width);
    }

    /* campaign */
    .campaign-section .section-container {
        width: var(--container-width);
    }

    .campaign-heading {
        margin-bottom: 16px;
        width: 100%;
    }

    .campaign-period {
        font-size: 15px;
        margin-bottom: 38px;
    }

    .campaign-period span {
        font-size: 33px;
    }

    .campaign-block {
        flex-direction: column;
        flex-wrap: wrap;
        row-gap: 35px;
    }

    .campaign-item {
        padding: 30px 20px 15px;
    }

    .campaign-item-heading {
        width: 270px;
    }

    /* ----------------------------------------
   News
---------------------------------------- */

    .news-section {
        padding-top: 40px;
        padding-bottom: 45px;
    }

    .news-post:not(:has(a)),
    .news-post a {
        padding: 10px 50px 16px 0;
    }

    .news-date {
        margin-bottom: 4px;
    }

    .news-heading {
        font-size: 15px;
    }

    /* ----------------------------------------
   Information
---------------------------------------- */

    .information-section {
        background-image: url(/wp/wp-content/themes/renaissance/images/bg_information_01_sp.jpg);
        background-size: cover;
        padding-top: 40px;
        padding-bottom: 35px;
    }

    .information-section .section-container {
        background-position: top 144px center;
        padding-top: 0;
    }

    .information-heading {
        margin-bottom: 30px;
        width: 304px;
    }

    .information-text {
        margin-bottom: 140px;
        width: 209px;
    }

    .information-text-number {
        top: 64px;
        left: 0;
        width: 114px;
    }

    .information-text-number.fade-in.is-visible {
        top: 44px;
    }

    /* ----------------------------------------
   Concern
---------------------------------------- */

    .concern-intro {
        background-image: url(/wp/wp-content/themes/renaissance/images/bg_concern_intro_01_sp.jpg);
        background-size: cover;
        padding: 38px 10px 34px;
    }

    .concern-intro-heading {
        margin-bottom: 22px;
        width: 100%;
        max-width: var(--container-width);
    }

    .concern-intro-balloon {
        width: 100%;
        max-width: var(--container-width);
    }

    .concern-intro-balloon li:first-child {
        margin-left: 14px;
        width: 130px;
    }

    .concern-intro-balloon li:nth-child(2) {
        top: 14px;
        width: 148px;
    }

    .concern-intro-balloon li:nth-child(3) {
        margin-top: 40px;
        margin-left: 56px;
        width: 146px;
    }

    .concern-intro .arrow {
        bottom: -20px;
    }

    /* point */
    .concern-point {
        padding-top: 30px;
        padding-bottom: 40px;
    }

    .concern-point-heading {
        margin-bottom: 40px;
        width: 340px;
    }

    .concern-point-item {
        padding: 24px 20px 20px;
    }

    .point-item-icon {
        top: -12px;
        left: 50%;
        transform: translateX(-50%);
        width: 68px;
    }

    .point-item-flex {
        display: block;
    }

    .point-item-image {
        margin-bottom: 11px;
        width: 100%;
    }

    .point-item-heading {
        margin-bottom: 3px;
        letter-spacing: -0.05em;
        white-space: nowrap;
    }

    .point-item-text p {
        margin-right: 0;
    }

    .point-item-text p:has(img) {
        margin-top: 10px;
    }

    .point-gate {
        margin-top: 14px;
    }

    .gate-flow {
        border: none;
        flex-direction: column;
        flex-wrap: wrap;
        margin: 0;
        padding: 0;
    }

    .gate-flow li {
        padding: 0;
    }

    .gate-flow li:nth-child(2) {
        border: none;
    }

    .gate-flow dl {
        display: flex;
        gap: 0 8px;
    }

    .gate-flow dl dt {
        background-color: #ffffff;
        border: 1px solid var(--color-primary);
        color: var(--color-primary);
    }

    .gate-flow dl dd br {
        display: none;
    }

    .gate-text {
        font-size: 14px;
        white-space: nowrap;
    }

    .point-gate .notes {
        text-align: left;
    }

    /* ----------------------------------------
   Facility
---------------------------------------- */

    .facility-section {
        background: none;
        padding-top: 35px;
        padding-bottom: 12px;
    }

    .facility-section .section-container {
        width: 100%;
        max-width: var(--container-width);
    }

    .facility-heading {
        margin-bottom: 12px;
        width: 328px;
    }

    .facility-item,
    .facility-item:nth-of-type(2) {
        flex-direction: column-reverse;
    }

    .facility-item {
        margin-top: 20px;
        position: relative;
    }

    .facility-item + .facility-item {
        margin-top: 7px;
    }

    .facility-item-heading {
        -webkit-text-stroke: 5px #ffffff;
        paint-order: stroke;
        font-size: 33px;
        position: absolute;
        top: 12px;
        right: 34px;
    }

    .facility-item:nth-of-type(2) .facility-item-heading {
        right: auto;
        left: 34px;
    }

    .facility-item p {
        padding: 0 20px;
    }

    .facility-item-text .notes {
        margin-top: 0;
    }

    .facility-item-image {
        margin-bottom: 4px;
        width: 100%;
    }

    /* ----------------------------------------
   Plan
---------------------------------------- */

    .plan-section {
        padding: 30px 0 40px;
    }

    .plan-header-heading {
        margin-bottom: 18px;
        width: 290px;
    }

    .plan-header-image {
        margin-bottom: -32px;
        gap: 0;
    }

    .plan-header-image p {
        margin: 0 -16px 0 0;
    }

    .plan-contents {
        margin-inline: 0;
    }

    .plan-item {
        padding: 24px 20px 32px;
    }

    .plan-item:not(:last-child) {
        margin-bottom: 25px;
    }

    .plan-recommended::after {
        border-width: 5px;
    }

    .plan-name {
        font-size: 25px;
        line-height: 1.3;
        margin-bottom: 6px;
    }

    .plan-item-flex {
        flex-direction: column;
        flex-wrap: wrap;
    }

    .plan-item-left {
        width: 100%;
    }

    .plan-item-right {
        border-left: none;
        padding: 15px 0 0 0;
    }

    .plan-tagline {
        margin-bottom: 5px;
        text-align: center;
    }

    .plan-school-tagline {
        margin-top: 0;
    }

    .plan-fee-gymtrial {
        text-align: center;
    }

    .plan-fee {
        justify-content: center;
    }

    .plan-fee dd b {
        font-size: 74px;
    }

    .inclusions-note {
        margin-top: 10px;
    }

    .plan-hours {
        margin-top: 5px;
    }

    .plan-notes {
        margin-top: 6px;
    }

    .plan-notes summary {
        text-align: center;
    }

    .plan-notes summary + * {
        margin-top: 6px;
    }

    .plan-link-detail {
        margin: 6px 0;
    }

    .school-trial-heading {
        margin-bottom: 7px;
        width: 100%;
    }

    .school-trial-flex {
        flex-direction: column;
        flex-wrap: wrap;
        gap: 8px 0;
        margin-bottom: 2px;
    }

    .school-trial-flex-item {
        padding: 4px 8px 10px;
        width: 100%;
    }

    .school-trial-link {
        justify-content: flex-start;
    }

    .school-trial-fee {
        text-align: left;
    }

    .school-trial-fee + .notes {
        text-align: left;
    }

    .plan-school-campaign {
        margin-bottom: 7px;
        width: 100%;
    }

    .plan-school-campaign dl dt {
        line-height: 1.5;
    }

    .plan-school-campaign dl dt br {
        display: block;
    }

    .online-coupon-code {
        margin-top: 5px;
        margin-inline: auto;
    }

    .plan-online-button {
        margin-top: 14px;
        margin-bottom: 20px;
    }

    /* ----------------------------------------
   Need
---------------------------------------- */

    .need-section {
        padding-top: 44px;
        padding-bottom: 42px;
    }

    .need-lead {
        margin-top: 2px;
    }

    .tab-list {
        margin-top: 28px;
        margin-bottom: 30px;
        width: 100%;
    }

    .need-target-members dd {
        padding-inline: 0;
    }

    .need-block:not(:last-child) {
        margin-bottom: 36px;
    }

    .need-list-text {
        margin-bottom: 4px;
    }

    .need-list-text br {
        display: none;
    }

    .need-list-text .notes {
        display: block;
    }

    .need-list-id-wrap {
        flex-wrap: wrap;
        margin: 0 0 4px;
    }

    .need-list-id-wrap .need-list-text {
        width: 100%;
    }

    .need-notes-cashless {
        padding: 10px 14px;
    }

    /* ----------------------------------------
   Admission
---------------------------------------- */

    .admission-section {
        padding-bottom: 24px;
    }

    .admission-section .section-container {
        width: 100%;
    }

    .admission-lead {
        margin-bottom: 8px;
    }

    .admission-varies {
        margin: 0 auto 40px;
        padding: 22px 20px 20px;
        width: var(--container-width);
    }

    .admission-varies-heading {
        font-size: 15px;
        margin-bottom: 16px;
    }

    .admission-varies-flex {
        gap: 0 10px;
        margin-bottom: 7px;
    }

    .admission-varies-flex-item dt {
        font-size: 11px;
        margin-bottom: 7px;
    }

    .admission-varies-flex-item dd {
        border-width: 2px;
    }

    .club-list {
        border: none;
    }

    .club-list-heading {
        background-position: left 20px top 8px;
        font-size: 20px;
        padding: 30px 0;
    }

    .club-list-alert {
        padding-inline: 0;
        width: var(--container-width);
    }

    .club-list .plus-icon {
        left: 25px;
    }

    .club-list .plus-icon::before {
        width: 1px;
    }

    .club-list .plus-icon::after {
        height: 1px;
    }

    .area-heading {
        font-size: 21px;
        padding: 13px 20px;
    }

    .prefecture-name {
        font-size: 19px;
        padding: 12px 20px 12px 50px;
    }

    .club-name {
        font-size: 17px;
        padding: 12px 20px 12px 50px;
    }

    .club-content {
        padding: 0 30px 30px;
    }

    .club-content .button {
        margin-top: 8px;
        margin-bottom: 12px;
    }

    .club-map {
        margin-top: 20px;
    }

    .club_info_body .club-map {
        margin-top: 8px;
    }

    /* ----------------------------------------
   Trial
---------------------------------------- */

    .trial-section {
        padding: 35px 0 30px;
    }

    .trial-block {
        padding: 25px 17px;
    }

    .trial-block + .trial-block {
        margin-top: 20px;
    }

    .trial-heading {
        width: 100%;
    }

    .trial-illust {
        margin-top: 10px;
        width: 165px;
    }

    .trial-button-group {
        flex-direction: column;
        flex-wrap: wrap;
        gap: 14px 0;
    }

    h2 + .trial-button-group {
        margin-top: 22px;
    }

    .trial-coupon-group {
        margin-top: 15px;
    }

    .trial-coupon-image {
        margin-top: 15px;
        width: 100%;
    }

    .trial-notes {
        margin-top: 25px;
    }

    .trial-notes-heading {
        font-size: 19px;
        margin-bottom: 21px;
    }

    /* ----------------------------------------
   FAQ
---------------------------------------- */

    .faq-section {
        padding-bottom: 31px;
    }

    .faq-section .section-container {
        padding-inline: 0;
    }

    .faq-section .section-common-header {
        margin-bottom: 0;
    }

    .faq-item {
        padding: 23px 0;
    }

    .faq-question {
        font-size: 15px;
        padding: 0 28px 0 30px;
    }

    .faq-question::before {
        left: 15px;
    }

    .faq-question .plus-icon {
        height: 10px;
        right: 14px;
        width: 10px;
    }

    .faq-question .plus-icon::before {
        width: 1px;
    }

    .faq-question .plus-icon::after {
        height: 1px;
    }

    .faq-answer {
        padding: 12px 28px 0 30px;
    }

    .faq-answer::before {
        left: 15px;
    }

    .faq-answer p + p:not(.notes) {
        margin-top: 26px;
    }

    .faq-bottom-text {
        font-size: 15px;
        margin-top: 23px;
    }

    .faq-bottom-text br {
        display: block;
    }

    /* ----------------------------------------
   Others
---------------------------------------- */

    .others {
        background-color: #ffffff;
        padding: 0 0 18px;
    }

    .others-list {
        flex-direction: column;
        flex-wrap: wrap;
        gap: 10px 0;
        width: 100%;
    }
}

/*------------------------------------------------------------*/
/* reserve_popup_tour
/*------------------------------------------------------------*/
#reserve_popup_tour {
    position: relative;
    width: 100%;
    max-width: 900px;
    margin: 0 auto;
    padding: 0 0 30px 0;
    text-align: center;
    background-color: #ffffff;
}

#reserve_popup_tour h3 {
    width: 100%;
    color: #ffffff;
    font-size: 24px;
    box-sizing: border-box;
    margin: 0 auto;
    padding: 10px 20px;
    background-color: #15923b;
    border-top: 3px solid #11761f;
    border-bottom: 3px solid #11761f;
}

#reserve_popup_tour p {
    margin: 20px 0 10px;
    font-size: 14px;
    text-align: center;
}

#reserve_popup_tour a {
    box-sizing: border-box;
    display: block;
    width: 80%;
    margin: 30px auto;
    padding: 20px 20px;
    font-size: 14px;
    color: #ffffff;
    background-color: #15923b;
    border-radius: 10px;
}

#reserve_popup_tour a em {
    font-size: 24px;
    font-weight: bold;
}

#reserve_popup_tour select {
    width: 60%;
}

#reserve_popup_tour .border_green {
    width: 80%;
    margin: 30px auto;
    padding: 20px 20px;
    border: 3px solid #15923b;
    border-radius: 10px;
}

#reserve_popup_tour .border_green p {
    margin: 0;
    color: #15923b;
}

#reserve_popup_tour .border_green a {
    padding: 0;
    margin: 20px auto;
    font-size: 18px;
    font-weight: bold;
    color: #15923b;
    background-color: transparent;
}

#reserve_popup_tour .border_green small {
    display: block;
    font-size: 12px;
    text-align: left;
}

@media screen and (min-width: 600px) {
    #reserve_popup_tour p {
        font-size: 16px;
    }

    #reserve_popup_tour a {
        font-size: 16px;
    }

    #reserve_popup_tour a em {
        font-size: 28px;
    }

    #reserve_popup_tour .border_green a {
        font-size: 28px;
    }

    #reserve_popup_tour .border_green small {
        text-align: center;
    }

    #reserve_popup_tour .pcn {
        display: none;
    }
}

#reserve_popup_taiken {
    position: relative;
    width: 100%;
    max-width: 900px;
    margin: 0 auto;
    padding: 0 0 30px 0;
    text-align: center;
    background-color: #ffffff;
}

#reserve_popup_taiken h3 {
    width: 100%;
    color: #ffffff;
    font-size: 24px;
    box-sizing: border-box;
    margin: 0 auto;
    padding: 10px 20px;
    background-color: #15923b;
    border-top: 3px solid #11761f;
    border-bottom: 3px solid #11761f;
}

#reserve_popup_taiken p {
    margin: 20px 0 10px;
    font-size: 14px;
    text-align: center;
}

#reserve_popup_taiken a {
    box-sizing: border-box;
    display: block;
    width: 80%;
    margin: 30px auto;
    padding: 20px 20px;
    font-size: 14px;
    color: #ffffff;
    background-color: #15923b;
    border-radius: 10px;
}

#reserve_popup_taiken a em {
    font-size: 24px;
    font-weight: bold;
}

#reserve_popup_taiken select {
    width: 60%;
}

#reserve_popup_taiken .border_green {
    width: 80%;
    margin: 30px auto;
    padding: 20px 20px;
    border: 3px solid #15923b;
    border-radius: 10px;
}

#reserve_popup_taiken .border_green p {
    margin: 0;
    color: #15923b;
}

#reserve_popup_taiken .border_green a {
    padding: 0;
    margin: 20px auto;
    font-size: 18px;
    font-weight: bold;
    color: #15923b;
    background-color: transparent;
}

#reserve_popup_taiken .border_green small {
    display: block;
    font-size: 12px;
    text-align: left;
}

@media screen and (min-width: 600px) {
    #reserve_popup_taiken p {
        font-size: 16px;
    }

    #reserve_popup_taiken a {
        font-size: 16px;
    }

    #reserve_popup_taiken a em {
        font-size: 28px;
    }

    #reserve_popup_taiken .border_green a {
        font-size: 28px;
    }

    #reserve_popup_taiken .border_green small {
        text-align: center;
    }

    #reserve_popup_taiken .pcn {
        display: none;
    }
}

/*------------------------------------------------------------*/
/* reserve_popup_taiken_tennis
/*------------------------------------------------------------*/
#reserve_popup_taiken_tennis {
    position: relative;
    width: 100%;
    max-width: 900px;
    margin: 0 auto;
    padding: 0 0 30px 0;
    text-align: center;
    background-color: #ffffff;
}

#reserve_popup_taiken_tennis h3 {
    width: 100%;
    color: #ffffff;
    font-size: 24px;
    box-sizing: border-box;
    margin: 0 auto;
    padding: 10px 20px;
    background-color: #15923b;
    border-top: 3px solid #11761f;
    border-bottom: 3px solid #11761f;
}

#reserve_popup_taiken_tennis p {
    margin: 20px 0 10px;
    font-size: 14px;
    text-align: center;
}

#reserve_popup_taiken_tennis a {
    box-sizing: border-box;
    display: block;
    width: 80%;
    margin: 30px auto;
    padding: 20px 20px;
    font-size: 14px;
    color: #ffffff;
    background-color: #15923b;
    border-radius: 10px;
}

#reserve_popup_taiken_tennis a em {
    font-size: 16px;
    font-weight: bold;
}

#reserve_popup_taiken_tennis select {
    width: 60%;
}

#reserve_popup_taiken_tennis .border_green {
    width: 80%;
    margin: 30px auto;
    padding: 20px 20px;
    border: 3px solid #15923b;
    border-radius: 10px;
}

#reserve_popup_taiken_tennis .border_green p {
    margin: 0;
    color: #15923b;
}

#reserve_popup_taiken_tennis .border_green a {
    padding: 0;
    margin: 20px auto;
    font-size: 18px;
    font-weight: bold;
    color: #15923b;
    background-color: transparent;
}

#reserve_popup_taiken_tennis .border_green small {
    display: block;
    font-size: 12px;
    text-align: left;
}

@media screen and (min-width: 600px) {
    #reserve_popup_taiken_tennis p {
        font-size: 16px;
    }

    #reserve_popup_taiken_tennis a {
        font-size: 16px;
    }

    #reserve_popup_taiken_tennis a em {
        font-size: 28px;
    }

    #reserve_popup_taiken_tennis .border_green a {
        font-size: 28px;
    }

    #reserve_popup_taiken_tennis .border_green small {
        text-align: center;
    }

    #reserve_popup_taiken_tennis .pcn {
        display: none;
    }
}

/*------------------------------------------------------------*/
/* reserve_popup_taiken_swim
/*------------------------------------------------------------*/
#reserve_popup_taiken_swim {
    position: relative;
    width: 100%;
    max-width: 900px;
    margin: 0 auto;
    padding: 0 0 30px 0;
    text-align: center;
    background-color: #ffffff;
}

#reserve_popup_taiken_swim h3 {
    width: 100%;
    color: #ffffff;
    font-size: 24px;
    box-sizing: border-box;
    margin: 0 auto;
    padding: 10px 20px;
    background-color: #15923b;
    border-top: 3px solid #11761f;
    border-bottom: 3px solid #11761f;
}

#reserve_popup_taiken_swim p {
    margin: 20px 0 10px;
    font-size: 14px;
    text-align: center;
}

#reserve_popup_taiken_swim a {
    box-sizing: border-box;
    display: block;
    width: 80%;
    margin: 30px auto;
    padding: 20px 20px;
    font-size: 14px;
    color: #ffffff;
    background-color: #15923b;
    border-radius: 10px;
}

#reserve_popup_taiken_swim a em {
    font-size: 16px;
    font-weight: bold;
}

#reserve_popup_taiken_swim select {
    width: 60%;
}

#reserve_popup_taiken_swim .border_green {
    width: 80%;
    margin: 30px auto;
    padding: 20px 20px;
    border: 3px solid #15923b;
    border-radius: 10px;
}

#reserve_popup_taiken_swim .border_green p {
    margin: 0;
    color: #15923b;
}

#reserve_popup_taiken_swim .border_green a {
    padding: 0;
    margin: 20px auto;
    font-size: 18px;
    font-weight: bold;
    color: #15923b;
    background-color: transparent;
}

#reserve_popup_taiken_swim .border_green small {
    display: block;
    font-size: 12px;
    text-align: left;
}

@media screen and (min-width: 600px) {
    #reserve_popup_taiken_swim p {
        font-size: 16px;
    }

    #reserve_popup_taiken_swim a {
        font-size: 16px;
    }

    #reserve_popup_taiken_swim a em {
        font-size: 28px;
    }

    #reserve_popup_taiken_swim .border_green a {
        font-size: 28px;
    }

    #reserve_popup_taiken_swim .border_green small {
        text-align: center;
    }

    #reserve_popup_taiken_swim .pcn {
        display: none;
    }
}

/*------------------------------------------------------------*/
/* reserve_popup_taiken_golf
/*------------------------------------------------------------*/
#reserve_popup_taiken_golf {
    position: relative;
    width: 100%;
    max-width: 900px;
    margin: 0 auto;
    padding: 0 0 30px 0;
    text-align: center;
    background-color: #ffffff;
}

#reserve_popup_taiken_golf h3 {
    width: 100%;
    color: #ffffff;
    font-size: 24px;
    box-sizing: border-box;
    margin: 0 auto;
    padding: 10px 20px;
    background-color: #15923b;
    border-top: 3px solid #11761f;
    border-bottom: 3px solid #11761f;
}

#reserve_popup_taiken_golf p {
    margin: 20px 0 10px;
    font-size: 14px;
    text-align: center;
}

#reserve_popup_taiken_golf a {
    box-sizing: border-box;
    display: block;
    width: 80%;
    margin: 30px auto;
    padding: 20px 20px;
    font-size: 14px;
    color: #ffffff;
    background-color: #15923b;
    border-radius: 10px;
}

#reserve_popup_taiken_golf a em {
    font-size: 16px;
    font-weight: bold;
}

#reserve_popup_taiken_golf select {
    width: 60%;
}

#reserve_popup_taiken_golf .border_green {
    width: 80%;
    margin: 30px auto;
    padding: 20px 20px;
    border: 3px solid #15923b;
    border-radius: 10px;
}

#reserve_popup_taiken_golf .border_green p {
    margin: 0;
    color: #15923b;
}

#reserve_popup_taiken_golf .border_green a {
    padding: 0;
    margin: 20px auto;
    font-size: 18px;
    font-weight: bold;
    color: #15923b;
    background-color: transparent;
}

#reserve_popup_taiken_golf .border_green small {
    display: block;
    font-size: 12px;
    text-align: left;
}

@media screen and (min-width: 600px) {
    #reserve_popup_taiken_golf p {
        font-size: 16px;
    }

    #reserve_popup_taiken_golf a {
        font-size: 16px;
    }

    #reserve_popup_taiken_golf a em {
        font-size: 28px;
    }

    #reserve_popup_taiken_golf .border_green a {
        font-size: 28px;
    }

    #reserve_popup_taiken_golf .border_green small {
        text-align: center;
    }

    #reserve_popup_taiken_golf .pcn {
        display: none;
    }
}

/*------------------------------------------------------------*/
/* reserve_popup_taiken_jtennis
/*------------------------------------------------------------*/
#reserve_popup_taiken_jtennis {
    position: relative;
    width: 100%;
    max-width: 900px;
    margin: 0 auto;
    padding: 0 0 30px 0;
    text-align: center;
    background-color: #ffffff;
}

#reserve_popup_taiken_jtennis h3 {
    width: 100%;
    color: #ffffff;
    font-size: 24px;
    box-sizing: border-box;
    margin: 0 auto;
    padding: 10px 20px;
    background-color: #15923b;
    border-top: 3px solid #11761f;
    border-bottom: 3px solid #11761f;
}

#reserve_popup_taiken_jtennis p {
    margin: 20px 0 10px;
    font-size: 14px;
    text-align: center;
}

#reserve_popup_taiken_jtennis a {
    box-sizing: border-box;
    display: block;
    width: 80%;
    margin: 30px auto;
    padding: 20px 20px;
    font-size: 14px;
    color: #ffffff;
    background-color: #15923b;
    border-radius: 10px;
}

#reserve_popup_taiken_jtennis a em {
    font-size: 16px;
    font-weight: bold;
}

#reserve_popup_taiken_jtennis select {
    width: 60%;
}

#reserve_popup_taiken_jtennis .border_green {
    width: 80%;
    margin: 30px auto;
    padding: 20px 20px;
    border: 3px solid #15923b;
    border-radius: 10px;
}

#reserve_popup_taiken_jtennis .border_green p {
    margin: 0;
    color: #15923b;
}

#reserve_popup_taiken_jtennis .border_green a {
    padding: 0;
    margin: 20px auto;
    font-size: 18px;
    font-weight: bold;
    color: #15923b;
    background-color: transparent;
}

#reserve_popup_taiken_jtennis .border_green small {
    display: block;
    font-size: 12px;
    text-align: left;
}

@media screen and (min-width: 600px) {
    #reserve_popup_taiken_jtennis p {
        font-size: 16px;
    }

    #reserve_popup_taiken_jtennis a {
        font-size: 16px;
    }

    #reserve_popup_taiken_jtennis a em {
        font-size: 28px;
    }

    #reserve_popup_taiken_jtennis .border_green a {
        font-size: 28px;
    }

    #reserve_popup_taiken_jtennis .border_green small {
        text-align: center;
    }

    #reserve_popup_taiken_jtennis .pcn {
        display: none;
    }
}

/*------------------------------------------------------------*/
/* reserve_popup_taiken_jswim
/*------------------------------------------------------------*/
#reserve_popup_taiken_jswim {
    position: relative;
    width: 100%;
    max-width: 900px;
    margin: 0 auto;
    padding: 0 0 30px 0;
    text-align: center;
    background-color: #ffffff;
}

#reserve_popup_taiken_jswim h3 {
    width: 100%;
    color: #ffffff;
    font-size: 24px;
    box-sizing: border-box;
    margin: 0 auto;
    padding: 10px 20px;
    background-color: #15923b;
    border-top: 3px solid #11761f;
    border-bottom: 3px solid #11761f;
}

#reserve_popup_taiken_jswim p {
    margin: 20px 0 10px;
    font-size: 14px;
    text-align: center;
}

#reserve_popup_taiken_jswim a {
    box-sizing: border-box;
    display: block;
    width: 80%;
    margin: 30px auto;
    padding: 20px 20px;
    font-size: 14px;
    color: #ffffff;
    background-color: #15923b;
    border-radius: 10px;
}

#reserve_popup_taiken_jswim a em {
    font-size: 16px;
    font-weight: bold;
}

#reserve_popup_taiken_jswim select {
    width: 60%;
}

#reserve_popup_taiken_jswim .border_green {
    width: 80%;
    margin: 30px auto;
    padding: 20px 20px;
    border: 3px solid #15923b;
    border-radius: 10px;
}

#reserve_popup_taiken_jswim .border_green p {
    margin: 0;
    color: #15923b;
}

#reserve_popup_taiken_jswim .border_green a {
    padding: 0;
    margin: 20px auto;
    font-size: 18px;
    font-weight: bold;
    color: #15923b;
    background-color: transparent;
}

#reserve_popup_taiken_jswim .border_green small {
    display: block;
    font-size: 12px;
    text-align: left;
}

@media screen and (min-width: 600px) {
    #reserve_popup_taiken_jswim p {
        font-size: 16px;
    }

    #reserve_popup_taiken_jswim a {
        font-size: 16px;
    }

    #reserve_popup_taiken_jswim a em {
        font-size: 28px;
    }

    #reserve_popup_taiken_jswim .border_green a {
        font-size: 28px;
    }

    #reserve_popup_taiken_jswim .border_green small {
        text-align: center;
    }

    #reserve_popup_taiken_jswim .pcn {
        display: none;
    }
}

/* club_list
	----------------------------------------------------- */

.club_list {
    width: 100%;
}

.club_list h2 {
    color: #ffffff;
    font-size: 21px;
    line-height: 1.4;
    margin: 0 0 20px;
    padding: 17px 20px;
    position: relative;
}

#list01_sp h2 {
    background-color: #d62248;
}

#list02_sp h2 {
    background-color: #012f6e;
}

#list03_sp h2 {
    background-color: #3eb58c;
}

#list04_sp h2 {
    background-color: #f38900;
}

#list05_sp h2 {
    background-color: #051d3e;
}

.club_list h2:after {
    background: url(/wp/wp-content/themes/renaissance/images/icon_alert_01.svg)
        no-repeat;
    background-size: contain;
    content: "";
    cursor: pointer;
    display: inline-block;
    height: 30px;
    position: absolute;
    top: 50%;
    right: 18px;
    transform: translateY(-50%);
    width: 30px;
}

.club_list .alert {
    display: none;
    margin: 0 auto;
    padding: 0 30px 18px;
}

@media screen and (max-width: 767px) {
    .club_list .alert {
        padding-inline: 0;
        width: var(--container-width);
    }
}

.club_list .alert p.midashi {
    margin-bottom: 8px;
}

#list02_sp .alert p.midashi {
    color: #012f6e;
}

#list03_sp .alert p.midashi {
    color: #3eb58c;
}

#list04_sp .alert p.midashi {
    color: #f38900;
}

#list05_sp .alert p.midashi {
    color: #051d3e;
}

.club_list .alert p.txt {
    line-height: 1.5;
    padding-left: 1em;
    position: relative;
}

.club_list .alert p.txt::before {
    content: "・";
    position: absolute;
    top: 0;
    left: 0.25em;
}

.club_list .club_info {
    margin: 18px 0 0 0;
    width: 100%;
}

.club_list .club_info .club {
    color: #ffffff;
    font-size: 17px;
    font-weight: 700;
    line-height: 1.4;
    padding: 13px 10px;
    text-align: center;
}

#list01_sp .club_info .club {
    background-color: #d62248;
}

#list02_sp .club_info .club {
    background-color: #012f6e;
}

#list03_sp .club_info .club {
    background-color: #3eb58c;
}

#list04_sp .club_info .club {
    background-color: #f38900;
}

#list05_sp .club_info .club {
    background-color: #051d3e;
}

.club_list .club_info .club a {
    color: #ffffff;
}

.club_list .club_info_body {
    padding: 0 5px;
}

.club_list .club_info_body .button {
    margin-top: 20px;
}

#list02_sp .club_info_body .button {
    background-color: #012f6e;
}

#list02_sp .club_info_body .button::after {
    border-top-color: var(--color-primary);
    border-right-color: var(--color-primary);
}

.club_list .club_info dl {
    display: flex;
    flex-wrap: wrap;
    font-size: 15px;
    line-height: 1.4;
}

.club_list .club_info dl dt {
    font-weight: bold;
    padding: 7px 0;
    width: 75px;
}

.club_list .club_info dl dd {
    padding: 7px 0;
    width: calc(100% - 75px);
}

.club_list .club_info dl dd a {
    color: #0000ff;
}

/* tabs
	----------------------------------------------------- */

#tabs {
    margin: 0 auto;
    padding: 0 30px;
}

.club_list #tabs {
    padding-bottom: 30px;
}

@media screen and (max-width: 767px) {
    #tabs {
        padding: 0;
        width: var(--container-width);
    }

    .club_list #tabs {
        padding-bottom: 0;
    }
}

#tabs .tab {
    background-color: var(--bg-lightgray);
    border-radius: 8px;
    padding: 20px;
    width: 100%;
}

#tabs .tab:not(:last-of-type) {
    margin-bottom: 10px;
}

#tabs .tab button {
    color: #666666;
    cursor: pointer;
    display: block;
    font-size: 19px;
    font-weight: 700;
    line-height: 1.2;
    position: relative;
    text-align: left;
    width: 100%;
}

#tabs .tab button:before {
    position: absolute;
    top: 50%;
    margin-top: -14px;
    right: 0;
    display: block;
    content: "";
    width: 28px;
    height: 28px;
    background-color: #b3b3b3;
    border-radius: 50%;
}

#tabs .tab button:after {
    display: block;
    content: "";
    position: absolute;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 0 5px 7px 5px;
    border-color: transparent transparent #fff transparent;
    right: 9px;
    top: 50%;
    margin-top: -2px;
    transition: all 0.4s ease-out;
    transform-origin: 50% 50%;
    transform: rotate(180deg);
}

#tabs .tab button.open:after {
    margin-top: -4px;
    transform: rotate(0deg);
}

#tabs .tab .tab_inner {
    display: none;
}
