/* クラス紹介セクション */
.class-section-boxed {
    background-color: transparent;
}

/* widget間のmargin */
.class-element.class-widget:not(:last-child) {
    margin-block-end: 20px;
    margin-bottom: 20px;
}

.class-section-title-padding {
    padding: 3% 0% 2% 0%;
}

/* クラス紹介タイトルセクション専用のpadding - PC/タブレット版のみ */
@media (min-width: 768px) {
    .class-section[data-id="5ee435cb"] {
        padding: 19px 0 !important;
    }
}

.class-container {
    max-width: 1140px;
    margin: 0 auto;
    padding: 0;
}

/* PC/タブレット版のみ - 子要素にpadding適用 */
.class-column-gap-default > .class-column > .class-element-populated {
    padding: 0 10px;
}

.class-column-gap-default {
    gap: 20px;
}

.class-column {
    text-align: center;
}

.class-col-100 {
    width: 100%;
    text-align: center;
    display: block;
}

/* タイトル */
.class-heading-title {
    font-family: "Noto Sans JP", sans-serif;
    font-size: 20px;
    font-weight: 600;
    text-align: center;
    margin-bottom: 20px;
    color: #333;
}

/* 画像 */
.class-widget-container {
    text-align: left;
    width: 100%;
}

.class-widget-image img {
    max-width: 100%;
    height: auto;
    display: block;
    margin: 0 auto;
}

.class-inner-section .class-widget-image img {
    width: 100%;
    height: auto;
    object-fit: fill;
}

/* タイトル画像の高さ統一 */
.class-main-title,
.class-gymnastics-title,
.class-video-title,
.class-core-title,
.class-adult-title {
    text-align: center;
}

.class-main-title .class-widget-container,
.class-gymnastics-title .class-widget-container,
.class-video-title .class-widget-container,
.class-core-title .class-widget-container,
.class-adult-title .class-widget-container {
    text-align: center;
    display: block;
    width: 100%;
}

/* 各タイトル画像のwidget-containerのpadding - PC/タブレット版のみ */
@media (min-width: 768px) {
    /* 教室動画タイトル */
    .class-element[data-id="77befd24"] > .class-widget-container {
        padding: 0 0 34px 0;
    }

    /* 大人クラスタイトル */
    .class-element[data-id="741e73b"] > .class-widget-container {
        padding: 45px 0 56px 0;
    }
}

.class-main-title img,
.class-gymnastics-title img,
.class-video-title img,
.class-core-title img,
.class-adult-title img {
    height: 70px;
    max-width: 100%;
    display: block;
    margin: 0 auto;
}

/* クラス紹介セクション背景画像 */
.class-intro-bg {
    background-image: url("/school/img/group-116.png");
    background-position: center center;
}

/* 2カラムレイアウト */
.class-inner-section .class-container {
    display: flex;
    flex-wrap: wrap;
    gap: 0;
    align-items: normal;
}

.class-col-50 {
    flex: 0 0 calc(50% - 15px);
    max-width: calc(50% - 15px);
    display: flex;
}

.class-inner-column .class-widget-wrap {
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: center;
    width: 100%;
}

.class-col-33 {
    flex: 0 0 calc(33.333% - 20px);
    max-width: calc(33.333% - 20px);
}

/* カラム内のpadding */
.class-column-gap-default > .class-column > .class-widget-wrap {
    padding: 10px;
}

.class-widget-wrap.class-element-populated {
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-items: center;
}

.class-widget-wrap > .class-element {
    width: 100%;
}

/* セクション間の余白 */
.class-kindergarten-section {
    padding: 0% 0% 2% 0%;
}

/* 各クラスセクションの個別padding設定 - PC/タブレット版のみ */
@media (min-width: 768px) {
    /* 体操体幹 小学生向けクラス */
    .class-section[data-id="29003a58"] {
        padding: 0 !important;
    }

    /* 体操体幹 教室動画（両方とも同じpadding） */
    .class-section[data-id="36c914a0"] {
        padding: 3% 0% 3% 0% !important;
    }

    /* 体幹トレーニングクラス タイトル */
    .class-section[data-id="80962da"] {
        padding: 57px 0 !important;
    }

    /* 体幹トレーニング 小学生向けクラス */
    .class-section[data-id="938aa59"] {
        padding: 0 !important;
    }

    /* 体幹トレーニング 中学生向けクラス */
    .class-section[data-id="1feac4f"] {
        padding: 0 !important;
    }

    /* 大人クラスタイトル */
    .class-section[data-id="e55fba4"] {
        padding: 0 !important;
    }

    /* 大人トレーニング動画 */
    .class-section[data-id="b4647a4"] {
        padding: 0 !important;
    }
}

/* 女性向けクラス、男性向けクラス、YouTubeチャンネルバナー - PC/タブレット版のみ */
@media (min-width: 768px) {
    /* 女性向けクラス */
    .class-section[data-id="6401dfd"] {
        padding: 0 0 76px !important;
    }

    /* 男性向けクラス */
    .class-section[data-id="65c24ab"] {
        padding: 0 0 76px !important;
    }

    /* YouTubeチャンネルバナー */
    .class-section[data-id="676981b"] {
        padding: 38px 0 95px !important;
    }
}

/* 背景色バリエーション */
.class-kindergarten-bg,
.class-elementary-bg,
.class-elementary-core-bg,
.class-green-bg {
    background-color: #078E2C;
}

.class-red-bg {
    background-color: #D81527;
}

/* 共通セクションスタイル */
.class-kindergarten-bg > .class-widget-wrap > .class-widget-heading,
.class-elementary-bg > .class-widget-wrap > .class-widget-heading,
.class-elementary-core-bg > .class-widget-wrap > .class-widget-heading,
.class-green-bg > .class-widget-wrap > .class-widget-heading,
.class-red-bg > .class-widget-wrap > .class-widget-heading {
    margin: 0 0 20px 0;
}

/* PC/タブレット版のみ */
@media (min-width: 768px) {
    .class-kindergarten-bg > .class-widget-wrap > .class-widget-heading .class-widget-container,
    .class-elementary-bg > .class-widget-wrap > .class-widget-heading .class-widget-container,
    .class-elementary-core-bg > .class-widget-wrap > .class-widget-heading .class-widget-container,
    .class-green-bg > .class-widget-wrap > .class-widget-heading .class-widget-container,
    .class-red-bg > .class-widget-wrap > .class-widget-heading .class-widget-container {
        padding: 1% 0% 0% 1%;
    }
}

.class-kindergarten-bg > .class-widget-wrap > .class-widget-heading .class-heading-title,
.class-elementary-bg > .class-widget-wrap > .class-widget-heading .class-heading-title,
.class-elementary-core-bg > .class-widget-wrap > .class-widget-heading .class-heading-title,
.class-green-bg > .class-widget-wrap > .class-widget-heading .class-heading-title,
.class-red-bg > .class-widget-wrap > .class-widget-heading .class-heading-title {
    color: #ffffff;
    font-size: 32px;
    line-height: 32px;
    font-weight: 600;
    text-align: left;
}

.class-content-white {
    background-color: #ffffff;
    margin: 0;
}

/* 各白いボックスのpadding（Elementorスタイルと同等） */
.class-element[data-id="268a1afb"],
.class-element[data-id="783c9fe8"],
.class-element[data-id="3251477"],
.class-element[data-id="d5016a4"],
.class-element[data-id="014562c"],
.class-element[data-id="aad2f6d"] {
    transition: background 0.3s, border 0.3s, border-radius 0.3s, box-shadow 0.3s;
    padding: 2% 2% 2% 2% !important;
}

.class-core-bg {
    background-color: #F5F5F5;
}

.class-content-bg {
    background-color: #ffffff;
}

/* テキストエディタ */
.class-widget-text-editor {
    font-family: "Noto Sans JP", sans-serif;
    font-size: 16px;
    line-height: 32px;
    color: #000000;
    text-align: left;
}

.class-widget-text-editor p {
    margin-bottom: 15px;
    line-height: 32px;
}

/* inner sectionのheading */
.class-inner-section .class-heading-title {
    font-size: 24px;
    font-weight: 700;
    line-height: 1.4;
    margin-bottom: 20px;
    text-align: left;
}

/* class-section内のすべてのh2のmargin-bottomを削除 */
.class-section h2 {
    margin-bottom: 0 !important;
}

/* inner sectionの大きめの見出し */
.class-inner-heading .class-heading-title {
    font-family: "Noto Sans JP", sans-serif;
    font-size: 25px;
    font-weight: 600;
    line-height: 2.1em;
    color: #000000;
}

/* 体幹トレーニングクラスの見出し（体操体幹より小さい） - PC/タブレット版のみ */
@media (min-width: 768px) {
    .class-element[data-id="3e5a9b8"] .class-heading-title,
    .class-element[data-id="1b775dc"] .class-heading-title,
    .class-element[data-id="6c85cdd"] .class-heading-title,
    .class-element[data-id="d47b3a2"] .class-heading-title {
        font-size: 20px !important;
        line-height: 42px !important;
    }
}

/* ビデオ */
.class-video {
    width: 100%;
    height: auto;
    aspect-ratio: 16/9;
    display: block;
}

.class-wrapper {
    text-align: center;
}

/* レスポンシブ - タブレット */
@media (max-width: 1100px) {
    .class-col-50 {
        flex: 0 0 100%;
        max-width: 100%;
    }
    
    .class-heading-title {
        font-size: 18px;
    }
    
    .class-widget-text-editor {
        font-size: 14px;
    }
}

/* スマホで非表示 */
.class-sp-hidden {
    display: inline;
}

@media (max-width: 767px) {
    .class-sp-hidden {
        display: none;
    }
}

/* レスポンシブ - モバイル */
@media (max-width: 767px) {
    .class-section {
        padding-left: 1%;
        padding-right: 1%;
    }
    
    .class-section-title-padding {
        padding: 5% 0% 5% 0%;
    }

    /* 「クラスのご紹介」セクション専用（id="class"）のモバイルpadding調整 */
    #class.class-section-title-padding {
        padding: 10px;
    }
    
    .class-main-title img,
    .class-gymnastics-title img,
    .class-core-title img,
    .class-adult-title img {
        height: 35px;
    }
    
    /* 教室動画タイトル画像のみ */
    .class-video-title.class-section-title-padding img {
        width: 135px;
        height: auto;
    }
    
    .class-col-50,
    .class-col-33 {
        flex: 0 0 100%;
        max-width: 100%;
    }
    
    .class-content-white {
        padding: 20px;
    }
    
    .class-heading-title {
        font-size: 16px;
    }
    
    .class-kindergarten-bg > .class-widget-wrap > .class-widget-heading .class-heading-title,
    .class-elementary-bg > .class-widget-wrap > .class-widget-heading .class-heading-title,
    .class-elementary-core-bg > .class-widget-wrap > .class-widget-heading .class-heading-title,
    .class-green-bg > .class-widget-wrap > .class-widget-heading .class-heading-title,
    .class-red-bg > .class-widget-wrap > .class-widget-heading .class-heading-title {
        font-size: 20px;
        text-align: center;
    }
    
    .class-kindergarten-section {
        padding: 0% 1% 5% 1%;
    }
    
    .class-widget-text-editor {
        font-size: 13px;
        line-height: 1.9em;
    }
    
    .class-widget-text-editor p {
        font-size: 13px;
        line-height: 1.9em;
    }

    /* 各クラス小見出しの下余白を10pxに調整（天地中央揃え用） */
    .class-kindergarten-bg > .class-widget-wrap > .class-widget-heading,
    .class-elementary-bg > .class-widget-wrap > .class-widget-heading,
    .class-elementary-core-bg > .class-widget-wrap > .class-widget-heading,
    .class-green-bg > .class-widget-wrap > .class-widget-heading,
    .class-red-bg > .class-widget-wrap > .class-widget-heading {
        margin: 0 0 10px 0;
    }
    
    /* 小学生向けクラスの説明テキスト - モバイル */
    .class-element[data-id="5b09ab40"] .class-widget-container p {
        font-size: 13px;
        line-height: 1.9em;
    }
    
    /* inner sectionの大きめの見出し - モバイル */
    .class-inner-heading .class-heading-title {
        font-size: 15px;
        line-height: 1.6em;
    }
}


/* クラスカルーセルのスタイル */
.class-widget-image-carousel {
    background-color: #ffffff;
    padding: 0em 2em 2em 2em;
}

.class-image-carousel-wrapper.swiper {
    width: 100%;
    padding: 0;
}

/* タブレット・PC限定でpaddingを適用 */
@media (min-width: 768px) {
    .class-image-carousel-wrapper.swiper {
        padding: 10px !important;
    }
}

.class-image-carousel .swiper-wrapper {
    align-items: center;
}

.class-image-carousel .swiper-slide {
    height: 230px;
}

.class-image-carousel .swiper-slide-inner {
    margin: 0;
    display: block;
    width: 100%;
    height: 100%;
}

.class-image-carousel .swiper-slide-image {
    width: 100%;
    height: 230px;
    display: block;
    border-radius: 0;
    object-fit: cover;
    object-position: center center;
}

/* スマホ版でのスタイル調整 */
@media (max-width: 767px) {
    .class-widget-image-carousel {
        padding: 20px;
    }
    
    .class-image-carousel .swiper-slide {
        height: 200px;
    }
    
    .class-image-carousel .swiper-slide-image {
        height: 200px;
    }
}
