/**
 * AI Bridge - セクションブロック スタイル
 */

/* 基本スタイル */
.aibridge-section {
    position: relative;
    width: 100%;
    box-sizing: border-box;
}

.aibridge-section__inner {
    width: 100%;
    padding-left: 20px;
    padding-right: 20px;
    box-sizing: border-box;
}

/* 幅広対応 - main-content内で広がる */
.aibridge-section.alignwide {
    max-width: 1200px;
    width: 100%;
    margin-left: auto;
    margin-right: auto;
}

/* 全幅対応 - main-content内で左右端まで広がる */
.aibridge-section.alignfull {
    max-width: none;
    width: 100%;
    position: relative;
    left: 0;
    transform: none;
    margin-left: 0;
    margin-right: 0;
}

/* alignfull時は内側パディングも削除（インラインスタイルを上書き） */
.aibridge-section.alignfull > .aibridge-section__inner {
    padding-left: 0 !important;
    padding-right: 0 !important;
}

/* スタイルバリエーション */
.aibridge-section--default {
    /* デフォルトスタイル */
}

.aibridge-section--card {
    background: #fff;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
    border-radius: 12px;
    margin-top: 20px;
    margin-bottom: 20px;
}

.aibridge-section--gradient {
    background: linear-gradient(135deg, var(--primary-color, #0066cc) 0%, var(--accent-color, #17a2b8) 100%);
    color: #fff;
}

.aibridge-section--gradient h1,
.aibridge-section--gradient h2,
.aibridge-section--gradient h3,
.aibridge-section--gradient h4,
.aibridge-section--gradient h5,
.aibridge-section--gradient h6,
.aibridge-section--gradient p,
.aibridge-section--gradient a {
    color: inherit;
}

.aibridge-section--bordered {
    border: 2px solid var(--primary-color, #0066cc);
    border-radius: 8px;
}

/* オーバーレイ */
.aibridge-section__overlay {
    pointer-events: none;
}

/* 段落フォントサイズ */
.aibridge-section p,
.aibridge-section .wp-block-paragraph {
    font-size: var(--section-paragraph-size, 16px);
}

/* 見出しフォントサイズ */
.aibridge-section h1,
.aibridge-section h2,
.aibridge-section h3,
.aibridge-section h4,
.aibridge-section h5,
.aibridge-section h6,
.aibridge-section .wp-block-heading {
    font-size: var(--section-heading-size, 28px);
}

/* セクション内の見出し - デフォルトの水平線を非表示（装飾スタイルは除く） */
.aibridge-section h1:not([class*="is-style-aibridge"]),
.aibridge-section h2:not([class*="is-style-aibridge"]),
.aibridge-section h3:not([class*="is-style-aibridge"]),
.aibridge-section h4:not([class*="is-style-aibridge"]),
.aibridge-section h5:not([class*="is-style-aibridge"]),
.aibridge-section h6:not([class*="is-style-aibridge"]),
.page-content .aibridge-section h1:not([class*="is-style-aibridge"]),
.page-content .aibridge-section h2:not([class*="is-style-aibridge"]),
.page-content .aibridge-section h3:not([class*="is-style-aibridge"]),
.page-content .aibridge-section h4:not([class*="is-style-aibridge"]),
.page-content .aibridge-section h5:not([class*="is-style-aibridge"]),
.page-content .aibridge-section h6:not([class*="is-style-aibridge"]),
.page-main-content .aibridge-section h1:not([class*="is-style-aibridge"]),
.page-main-content .aibridge-section h2:not([class*="is-style-aibridge"]),
.page-main-content .aibridge-section h3:not([class*="is-style-aibridge"]),
.page-main-content .aibridge-section h4:not([class*="is-style-aibridge"]),
.page-main-content .aibridge-section h5:not([class*="is-style-aibridge"]),
.page-main-content .aibridge-section h6:not([class*="is-style-aibridge"]) {
    border-bottom: none !important;
    border: none !important;
}

.aibridge-section h2,
.page-content .aibridge-section h2,
.page-main-content .aibridge-section h2 {
    margin-bottom: 20px;
}

/* エディター内スタイル */
.editor-styles-wrapper .aibridge-section {
    margin-left: 0;
    margin-right: 0;
}

.editor-styles-wrapper .aibridge-section.alignwide {
    max-width: 1200px;
    width: calc(100% + 48px);
    margin-left: -24px;
    margin-right: -24px;
    left: auto;
    transform: none;
}

.editor-styles-wrapper .aibridge-section.alignfull {
    width: calc(100% + 48px);
    max-width: none;
    margin-left: -24px;
    margin-right: -24px;
    left: auto;
    transform: none;
}

/* レスポンシブ */
@media (max-width: 1240px) {
    .aibridge-section.alignwide {
        max-width: 100%;
        width: 100%;
    }
}

@media (max-width: 1024px) {
    .aibridge-section__inner {
        padding-left: 30px;
        padding-right: 30px;
    }
}

@media (max-width: 768px) {
    /* モバイルではサイドバーが非表示になるため100%で問題なし */
    .aibridge-section.alignwide,
    .aibridge-section.alignfull {
        width: 100%;
        max-width: 100%;
    }

    .aibridge-section {
        padding-top: 40px !important;
        padding-bottom: 40px !important;
    }

    .aibridge-section__inner {
        padding-left: 20px;
        padding-right: 20px;
    }
}

/* アニメーション対応 */
.aibridge-section[data-aos] {
    opacity: 0;
    transition: opacity 0.6s ease, transform 0.6s ease;
}

.aibridge-section[data-aos].aos-animate {
    opacity: 1;
}
