/* ============================================================
   お金の講座デザイン - Front CSS
   フロント公開ページでのブロック表示スタイル
   すべて .okz-article 配下でのみ適用
   ============================================================ */

/* ─────────────────────────────────
   黄色マーカー(エディタのドロップダウン内の装飾ボタンで付与)
   ───────────────────────────────── */
.okz-article .okzd-marker-yellow {
    background: linear-gradient(transparent 60%, #ffe08a 60%) !important;
    padding: 0 2px !important;
    color: inherit !important;
}

/* ─────────────────────────────────
   Gutenberg フォントサイズプリセット対応 (S/M/L/XL)
   テーマ側に .has-*-font-size の定義がないため、
   フロントでもサイズ切替が反映されるよう定義
   ───────────────────────────────── */
.okz-article p.has-small-font-size,
.okz-article .has-small-font-size {
    font-size: 1.3rem !important;
    line-height: 1.7 !important;
}
.okz-article p.has-medium-font-size,
.okz-article .has-medium-font-size {
    font-size: 1.6rem !important;
    line-height: 1.75 !important;
}
.okz-article p.has-large-font-size,
.okz-article .has-large-font-size {
    font-size: 2rem !important;
    line-height: 1.6 !important;
}
.okz-article p.has-x-large-font-size,
.okz-article .has-x-large-font-size {
    font-size: 2.4rem !important;
    line-height: 1.5 !important;
}

/* ─────────────────────────────────
   wp-block-table の下マージンを詰める
   テーマ側の 2em が広すぎるため、表と次の段落の間隔を適正化
   ───────────────────────────────── */
.okz-article .wp-block-table {
    margin-bottom: 1em !important;
}

/* ─────────────────────────────────
   ① okzd/sub-heading（偽見出し）― 本家配色
   h4等を使わない、見た目だけの見出し。<p>ラッパー
   ───────────────────────────────── */
.okz-article .okzd-sub-heading-wrap {
    display: block !important;
    margin: 24px 0 12px !important;
    padding: 0 !important;
    background: transparent !important;
    border: none !important;
}
.okz-article .okzd-sub-heading {
    display: inline-flex !important;
    align-items: center !important;
    gap: 10px !important;
    font-size: 18px !important;
    font-weight: 700 !important;
    color: #333 !important;
    line-height: 1.5 !important;
    letter-spacing: 0.02em !important;
}
.okz-article .okzd-sub-heading::before {
    content: "" !important;
    flex: 0 0 auto !important;
    width: 6px !important;
    height: 20px !important;
    background: #F0465A !important;
    border-radius: 2px !important;
}

/* 親（大見出し）＝ベタ帯（本家メインカラー）。手動 .is-parent / サブ見出しが連続する先頭 */
.okz-article .okzd-sub-heading-wrap.is-parent,
.okz-article .okzd-sub-heading-wrap:has(+ .okzd-sub-heading-wrap) {
    margin: 28px 0 14px !important;
}
.okz-article .okzd-sub-heading-wrap.is-parent .okzd-sub-heading,
.okz-article .okzd-sub-heading-wrap:has(+ .okzd-sub-heading-wrap) .okzd-sub-heading {
    display: block !important;
    background: #F0465A !important;
    color: #fff !important;
    font-size: 17px !important;
    padding: 9px 16px !important;
    border-radius: 4px !important;
    letter-spacing: 0.02em !important;
}
.okz-article .okzd-sub-heading-wrap.is-parent .okzd-sub-heading::before,
.okz-article .okzd-sub-heading-wrap:has(+ .okzd-sub-heading-wrap) .okzd-sub-heading::before {
    display: none !important;
}
/* 連続3つ以上：2つ目以降（直前もサブ見出し）は通常に戻す（.is-parent手動指定は優先） */
.okz-article .okzd-sub-heading-wrap + .okzd-sub-heading-wrap:not(.is-parent) .okzd-sub-heading {
    display: inline-flex !important;
    background: none !important;
    color: #333 !important;
    font-size: 18px !important;
    padding: 0 !important;
    border-radius: 0 !important;
}
.okz-article .okzd-sub-heading-wrap + .okzd-sub-heading-wrap:not(.is-parent) .okzd-sub-heading::before {
    display: inline-block !important;
}

/* ─────────────────────────────────
   ② okzd/table-caption(テーブルキャプション)
   ───────────────────────────────── */
.okz-article .okzd-table-caption {
    display: block !important;
    background: #F0465A !important;
    color: #fff !important;
    font-size: 16px !important;
    font-weight: 700 !important;
    padding: 10px 16px !important;
    margin: 20px 0 0 !important;
    border: none !important;
    line-height: 1.5 !important;
    letter-spacing: 0.02em !important;
    border-radius: 0 !important;
}
.okz-article .okzd-table-caption__text {
    color: #fff !important;
    font-weight: 700 !important;
    font-size: inherit !important;
    line-height: inherit !important;
}

/* キャプション直後のテーブルは間隔を詰める */
.okz-article .okzd-table-caption + table,
.okz-article .okzd-table-caption + figure,
.okz-article .okzd-table-caption + .wp-block-table {
    margin-top: 0 !important;
}
.okz-article .okzd-table-caption + .wp-block-table > table,
.okz-article .okzd-table-caption + figure > table {
    margin-top: 0 !important;
}

/* ─────────────────────────────────
   ③ okzd/author-comment(筆者コメント)
   <aside>化に伴い、<blockquote>用のリセットは不要に
   ただし aside のブラウザデフォルトもほぼ無いので影響なし
   ───────────────────────────────── */
/* 案A：吹き出し（スピーチバブル）。名前は非表示・本文のみ。アバターは任意設定 */
.okz-article .okzd-author-comment {
    display: flex !important;
    gap: 14px !important;
    align-items: flex-start !important;
    margin: 28px 0 !important;
    padding: 0 !important;
    background: none !important;
    border: none !important;
    border-radius: 0 !important;
    box-sizing: border-box !important;
    quotes: none !important;
}
.okz-article .okzd-author-comment::before,
.okz-article .okzd-author-comment::after {
    content: none !important;
    display: none !important;
}
.okz-article .okzd-author-comment__avatar-wrap {
    flex: 0 0 52px !important;
    width: 52px !important;
    height: 52px !important;
}
.okz-article .okzd-author-comment__avatar {
    width: 52px !important;
    height: 52px !important;
    max-width: 52px !important;
    border-radius: 50% !important;
    border: 2px solid #F0465A !important;
    object-fit: cover !important;
    display: block !important;
    margin: 0 !important;
    padding: 0 !important;
    box-sizing: border-box !important;
}
.okz-article .okzd-author-comment__body {
    position: relative !important;
    flex: 1 1 auto !important;
    min-width: 0 !important;
    background: #f9fafb !important;
    border: 1px solid #e5e7eb !important;
    border-radius: 12px !important;
    padding: 12px 16px !important;
}
.okz-article .okzd-author-comment__body::before {
    content: "" !important;
    position: absolute !important;
    left: -7px !important;
    top: 18px !important;
    width: 12px !important;
    height: 12px !important;
    background: #f9fafb !important;
    border-left: 1px solid #e5e7eb !important;
    border-bottom: 1px solid #e5e7eb !important;
    transform: rotate(45deg) !important;
}
.okz-article .okzd-author-comment__name {
    display: none !important;
}
.okz-article .okzd-author-comment__text {
    font-size: 16px !important;
    line-height: 1.8 !important;
    color: #333 !important;
}
.okz-article .okzd-author-comment__text p {
    font-size: 16px !important;
    line-height: 1.8 !important;
    margin: 0 0 12px !important;
    color: #333 !important;
}
.okz-article .okzd-author-comment__text p:last-child {
    margin-bottom: 0 !important;
}

/* スマホ対応:狭い画面でもレイアウトを維持(縦積みしない、アバターを少し小さく) */
@media (max-width: 560px) {
    .okz-article .okzd-author-comment {
        gap: 12px !important;
    }
    .okz-article .okzd-author-comment__avatar-wrap,
    .okz-article .okzd-author-comment__avatar {
        flex-basis: 44px !important;
        width: 44px !important;
        height: 44px !important;
        max-width: 44px !important;
    }
    .okz-article .okzd-author-comment__text,
    .okz-article .okzd-author-comment__text p {
        font-size: 15px !important;
    }
}

/* ─────────────────────────────────
   ⑤ okzd/compare-box + compare-col(対比ブロック)
   ───────────────────────────────── */
.okz-article .okzd-compare-box {
    display: flex !important;
    gap: 20px !important;
    margin: 24px 0 !important;
    padding: 0 !important;
    background: transparent !important;
    border: none !important;
}
.okz-article .okzd-compare-col {
    flex: 1 1 0 !important;
    padding: 20px 22px !important;
    border-radius: 6px !important;
    box-sizing: border-box !important;
    margin: 0 !important;
}
.okz-article .okzd-compare-col--pros {
    background: #fff5f6 !important;
    border: 2px solid #F0465A !important;
}
.okz-article .okzd-compare-col--cons {
    background: #f3f4f6 !important;
    border: 2px solid #94a3b8 !important;
}
.okz-article .okzd-compare-col__head {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    font-size: 16px !important;
    font-weight: 700 !important;
    padding-bottom: 8px !important;
    margin-bottom: 12px !important;
}
.okz-article .okzd-compare-col--pros .okzd-compare-col__head {
    color: #F0465A !important;
    border-bottom: 2px solid #F0465A !important;
}
.okz-article .okzd-compare-col--cons .okzd-compare-col__head {
    color: #475569 !important;
    border-bottom: 2px solid #94a3b8 !important;
}
.okz-article .okzd-compare-col__icon {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 26px !important;
    height: 26px !important;
    border-radius: 50% !important;
    color: #fff !important;
    font-weight: 700 !important;
    font-size: 14px !important;
    flex: 0 0 26px !important;
    line-height: 1 !important;
}
.okz-article .okzd-compare-col--pros .okzd-compare-col__icon { background: #F0465A !important; }
.okz-article .okzd-compare-col--cons .okzd-compare-col__icon { background: #64748b !important; }
.okz-article .okzd-compare-col__heading {
    font-weight: 700 !important;
    font-size: 16px !important;
    line-height: 1.4 !important;
}
/* compare内のリスト */
.okz-article .okzd-compare-col__body ul,
.okz-article .okzd-compare-col__body ol {
    margin: 0 !important;
    padding: 0 !important;
    list-style: none !important;
    border: none !important;
    background: none !important;
}
.okz-article .okzd-compare-col__body li {
    font-size: 15px !important;
    line-height: 1.65 !important;
    padding: 5px 0 5px 18px !important;
    position: relative !important;
    margin: 0 !important;
    color: #333 !important;
    background: none !important;
    list-style: none !important;
}
.okz-article .okzd-compare-col__body li::marker { content: none !important; display: none !important; }
.okz-article .okzd-compare-col--pros .okzd-compare-col__body li::before {
    content: "・" !important;
    position: absolute !important;
    left: 2px !important;
    top: 3px !important;
    color: #F0465A !important;
    font-weight: 700 !important;
    font-size: 18px !important;
}
.okz-article .okzd-compare-col--cons .okzd-compare-col__body li::before {
    content: "・" !important;
    position: absolute !important;
    left: 2px !important;
    top: 3px !important;
    color: #64748b !important;
    font-weight: 700 !important;
    font-size: 18px !important;
}
.okz-article .okzd-compare-col__body p {
    font-size: 15px !important;
    line-height: 1.7 !important;
    margin: 0 0 8px !important;
    color: #333 !important;
}

/* スマホ:縦積み */
@media (max-width: 700px) {
    .okz-article .okzd-compare-box {
        flex-direction: column !important;
        gap: 12px !important;
    }
}

/* ─────────────────────────────────
   ⑨ okzd/warning-box(警告ボックス・タイトルなし版)
   構造: <aside class="okzd-warning-box">
           <div class="okzd-warning-box__body">
             <span class="okzd-warning-box__icon">⚠</span>
             <div class="okzd-warning-box__content">本文</div>
           </div>
         </aside>
   ───────────────────────────────── */
/* 案E：ビッグアイコン＋仕切り線（背景なし）／警告色＝アンバー */
.okz-article .okzd-warning-box {
    border: none !important;
    border-radius: 0 !important;
    margin: 24px 0 !important;
    background: none !important;
    padding: 0 !important;
}
.okz-article .okzd-warning-box__body {
    padding: 0 !important;
    display: flex !important;
    align-items: flex-start !important;
    gap: 16px !important;
    background: transparent !important;
}
.okz-article .okzd-warning-box__icon {
    flex: 0 0 auto !important;
    color: #fcc214 !important;
    font-size: 28px !important;
    line-height: 1.2 !important;
    font-weight: 400 !important;
    margin-top: 0 !important;
}
.okz-article .okzd-warning-box__content {
    flex: 1 1 auto !important;
    font-size: 16px !important;
    color: #333 !important;
    line-height: 1.8 !important;
    border-left: 1px solid #f7e3a8 !important;
    padding-left: 16px !important;
}
.okz-article .okzd-warning-box__content p {
    font-size: 16px !important;
    line-height: 1.8 !important;
    margin: 0 0 10px !important;
    color: #333 !important;
}
.okz-article .okzd-warning-box__content p:last-child {
    margin-bottom: 0 !important;
}
.okz-article .okzd-warning-box__content ul,
.okz-article .okzd-warning-box__content ol {
    margin: 6px 0 !important;
    padding: 0 0 0 24px !important;
    background: none !important;
    border: none !important;
}
.okz-article .okzd-warning-box__content li {
    font-size: 16px !important;
    line-height: 1.75 !important;
    margin: 3px 0 !important;
}

/* ── 旧構造（v1.13.1以前: head + body 形式）への後方互換 ── */
.okz-article .okzd-warning-box__head {
    background: #fcc214 !important;
    color: #333 !important;
    font-size: 1.45rem !important;
    font-weight: 700 !important;
    padding: 10px 16px !important;
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    border: none !important;
}
.okz-article .okzd-warning-box__head-icon {
    font-size: 1.3rem !important;
    line-height: 1 !important;
    color: #333 !important;
}
.okz-article .okzd-warning-box__head-text {
    flex: 1 1 auto !important;
    font-size: 1.45rem !important;
    font-weight: 700 !important;
    color: #333 !important;
    line-height: 1.4 !important;
}

/* ─────────────────────────────────
   ⑥ okzd/faq + faq-item(FAQ)
   構造: <dl class="okzd-faq"><dt class="okzd-faq-item__question">...</dt><dd class="okzd-faq-item__answer">...</dd>...</dl>
   dlのデフォルト margin/indent リセット、dt/dd で個別スタイル
   ───────────────────────────────── */
.okz-article .okzd-faq {
    margin: 24px 0 !important;
    padding: 0 !important;
    background: transparent !important;
    border-top: 1px solid #e5e7eb !important;
    border-bottom: 1px solid #e5e7eb !important;
}
.okz-article .okzd-faq-item__question {
    display: flex !important;
    gap: 12px !important;
    align-items: flex-start !important;
    line-height: 1.7 !important;
    margin: 0 !important;
    padding: 20px 0 0 !important;
    border-top: 1px solid #e5e7eb !important;
    background: transparent !important;
}
.okz-article .okzd-faq .okzd-faq-item__question:first-of-type {
    border-top: none !important;
}
.okz-article .okzd-faq-item__answer {
    display: flex !important;
    gap: 12px !important;
    align-items: flex-start !important;
    line-height: 1.7 !important;
    margin: 0 !important;
    padding: 10px 0 20px !important;
    background: transparent !important;
}
.okz-article .okzd-faq-item__badge {
    flex: 0 0 auto !important;
    box-sizing: border-box !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-width: 26px !important;
    height: 24px !important;
    padding: 0 8px !important;
    border-radius: 4px !important;
    font-family: Arial, "Helvetica Neue", sans-serif !important;
    font-weight: 700 !important;
    font-size: 14px !important;
    color: #fff !important;
    margin-top: 3px !important;
    letter-spacing: 0.03em !important;
    line-height: 1 !important;
}
.okz-article .okzd-faq-item__badge--q { background: #F0465A !important; }
.okz-article .okzd-faq-item__badge--a { background: #fff !important; color: #F0465A !important; border: 1.5px solid #F0465A !important; }
.okz-article .okzd-faq-item__question-text {
    flex: 1 1 auto !important;
    font-size: 16px !important;
    font-weight: 700 !important;
    color: #333 !important;
    line-height: 1.6 !important;
}
.okz-article .okzd-faq-item__answer-body {
    flex: 1 1 auto !important;
    font-size: 16px !important;
    color: #333 !important;
    line-height: 1.75 !important;
}
.okz-article .okzd-faq-item__answer-body p {
    font-size: 16px !important;
    line-height: 1.75 !important;
    margin: 0 0 10px !important;
    color: #333 !important;
}
.okz-article .okzd-faq-item__answer-body p:last-child { margin-bottom: 0 !important; }

/* ─────────────────────────────────
   ⑦ okzd/references + reference-item(参考・引用元)
   <ol><li> 構造に変更。list-styleはCSSでリセットして見た目維持
   ───────────────────────────────── */
.okz-article .okzd-references {
    margin: 28px 0 !important;
    padding: 0 !important;
    background: transparent !important;
    border: none !important;
}
.okz-article .okzd-references__title {
    font-size: 16px !important;
    font-weight: 700 !important;
    color: #333 !important;
    padding: 0 !important;
    margin: 0 0 12px !important;
    border: none !important;
    background: none !important;
    letter-spacing: 0.02em !important;
    line-height: 1.5 !important;
}
/* ミニマル：番号・枠なし。リンクのみを行間広めで縦並び */
.okz-article ol.okzd-references__list,
.okz-article .okzd-references__list {
    border: none !important;
    padding: 0 !important;
    margin: 0 !important;
    list-style: none !important;
    background: none !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 12px !important;
}
.okz-article li.okzd-reference-item,
.okz-article .okzd-reference-item {
    padding: 0 !important;
    border: none !important;
    font-size: 14px !important;
    line-height: 1.7 !important;
    position: static !important;
    margin: 0 !important;
    list-style: none !important;
    background: transparent !important;
    display: block !important;
    color: #333 !important;
}
.okz-article .okzd-reference-item::before {
    content: none !important;
    display: none !important;
}
.okz-article .okzd-reference-item::marker { content: none !important; display: none !important; }
.okz-article .okzd-reference-item a {
    color: #F0465A !important;
    text-decoration: underline !important;
    word-break: break-word !important;
}
.okz-article .okzd-reference-item a:hover { color: #c93a4b !important; }
.okz-article .okzd-reference-item__source {
    color: #707070 !important;
    font-size: 0.95em !important;
    margin-left: 2px !important;
}
/* 空のreference-item（nameなし）は何も表示しない */
.okz-article .okzd-reference-item--empty {
    display: none !important;
}

/* ─────────────────────────────────
   ⑧ okzd/step-flow + step-item(ステップフロー)
   構造: <ol class="okzd-step-flow"><li class="okzd-step-item">...</li></ol>
   ブラウザ標準番号マーカー(1. 2. 3.)はlist-style/::markerで打ち消し、
   CSS counterによる中抜き丸番号の描画を維持
   ───────────────────────────────── */
.okz-article .okzd-step-flow {
    margin: 24px 0 !important;
    padding: 0 !important;
    background: transparent !important;
    border: none !important;
    counter-reset: okzd-step-counter !important;
    list-style: none !important;
}
.okz-article .okzd-step-item {
    padding: 0 0 22px !important;
    border: none !important;
    counter-increment: okzd-step-counter !important;
    position: relative !important;
    margin: 0 !important;
    background: transparent !important;
    list-style: none !important;
}
.okz-article .okzd-step-item::marker {
    content: none !important;
    display: none !important;
}
/* 縦の連結線：丸番号の中心(left16px)を通す。最後の項目は線なし */
.okz-article .okzd-step-item::before {
    content: "" !important;
    position: absolute !important;
    left: 15px !important;
    top: 0 !important;
    bottom: 0 !important;
    width: 2px !important;
    background: #fbd6da !important;
    z-index: 0 !important;
}
.okz-article .okzd-step-item:last-child {
    padding-bottom: 0 !important;
}
.okz-article .okzd-step-item:last-child::before {
    display: none !important;
}
.okz-article .okzd-step-item__content {
    padding-left: 48px !important;
    position: relative !important;
    min-height: 32px !important;
}
.okz-article .okzd-step-item__content::before {
    content: counter( okzd-step-counter ) !important;
    position: absolute !important;
    left: 0 !important;
    top: 0 !important;
    width: 32px !important;
    height: 32px !important;
    background: #F0465A !important;
    border: none !important;
    color: #fff !important;
    border-radius: 50% !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-family: Arial, sans-serif !important;
    font-weight: 700 !important;
    font-size: 14px !important;
    line-height: 1 !important;
    box-sizing: border-box !important;
    z-index: 1 !important;
}
.okz-article .okzd-step-item__title {
    font-size: 16px !important;
    font-weight: 700 !important;
    color: #333 !important;
    margin: 0 0 6px !important;
    line-height: 1.5 !important;
    padding-top: 5px !important;
}
.okz-article .okzd-step-item__body {
    font-size: 16px !important;
    color: #333 !important;
    line-height: 1.75 !important;
}
.okz-article .okzd-step-item__body p {
    font-size: 16px !important;
    line-height: 1.75 !important;
    margin: 0 0 10px !important;
    color: #333 !important;
}
.okz-article .okzd-step-item__body p:last-child { margin-bottom: 0 !important; }

/* ─────────────────────────────────
   ⑩ okzd/box-list（ボックスリスト）― 本家配色・白い角丸ボックス
   タイトル空欄時は .okzd-box-list__header が存在しない
   ───────────────────────────────── */
.okz-article .okzd-box-list {
    margin: 28px 0 !important;
    padding: 18px 20px !important;
    background: #fff !important;
    border: 1px solid #e5e7eb !important;
    border-radius: 12px !important;
    box-shadow: 0 4px 10px rgba(15,23,42,.06) !important;
    overflow: visible !important;
}
.okz-article .okzd-box-list__header {
    display: block !important;
    padding: 0 !important;
    margin: 0 0 12px !important;
    border: none !important;
    background: transparent !important;
}
.okz-article .okzd-box-list__title-bar { display: none !important; }
.okz-article .okzd-box-list__title {
    display: inline-block !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    color: #fff !important;
    line-height: 1.5 !important;
    letter-spacing: 0.02em !important;
    margin: 0 !important;
    padding: 5px 16px !important;
    background: #F0465A !important;
    border-radius: 999px !important;
}
.okz-article .okzd-box-list__body {
    padding: 0 !important;
    background: transparent !important;
    margin: 0 !important;
}
.okz-article .okzd-box-list > .okzd-box-list__body:first-child {
    padding-top: 0 !important;
}

/* 箱内のリスト装飾 */
.okz-article .okzd-box-list ul,
.okz-article .okzd-box-list ul.wp-block-list {
    margin: 0 !important;
    padding: 0 !important;
    list-style: none !important;
    border: none !important;
    background: none !important;
}
.okz-article .okzd-box-list ul li,
.okz-article .okzd-box-list ul.wp-block-list li {
    position: relative !important;
    margin: 0 !important;
    padding: 8px 0 8px 22px !important;
    font-size: 15px !important;
    line-height: 1.7 !important;
    color: #333 !important;
    list-style: none !important;
    background: none !important;
    border: none !important;
}
.okz-article .okzd-box-list ul li::marker,
.okz-article .okzd-box-list ul.wp-block-list li::marker {
    content: none !important;
    display: none !important;
}
.okz-article .okzd-box-list ul li::before,
.okz-article .okzd-box-list ul.wp-block-list li::before {
    content: "" !important;
    position: absolute !important;
    left: 4px !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    width: 7px !important;
    height: 7px !important;
    background: #F0465A !important;
    border-radius: 50% !important;
}
.okz-article .okzd-box-list ul li + li,
.okz-article .okzd-box-list ul.wp-block-list li + li {
    border-top: none !important;
}

/* 任意で導入文として段落を置いた場合 */
.okz-article .okzd-box-list .okzd-box-list__body p {
    font-size: 15px !important;
    line-height: 1.75 !important;
    margin: 0 0 10px !important;
    color: #333 !important;
}
.okz-article .okzd-box-list .okzd-box-list__body p:last-child {
    margin-bottom: 0 !important;
}

/* ============================================================
   ⑪ okzd/business-card（業者カード）
   パターン3：薄背景フレーム型 / J案：青アンダーライン型グリッド
   PC・スマホとも 3列×2行 をキープ。値はCSS太字（strong不使用）
   ============================================================ */
.okz-article .okzd-business-card {
    background: #f4f6fb !important;
    padding: 4px !important;
    border-radius: 6px !important;
    margin: 24px 0 !important;
}
.okz-article .okzd-business-card__inner {
    background: #fff !important;
    border-radius: 4px !important;
    overflow: hidden !important;
}
.okz-article .okzd-business-card__head {
    padding: 24px 22px 20px !important;
    text-align: center !important;
}
.okz-article .okzd-business-card__logo {
    margin-bottom: 14px !important;
    display: block !important;
}
.okz-article .okzd-business-card__logo img {
    display: inline-block !important;
    max-width: 220px !important;
    max-height: 65px !important;
    width: auto !important;
    height: auto !important;
    margin: 0 auto !important;
    object-fit: contain !important;
}
.okz-article .okzd-business-card__heading {
    font-size: 20px !important;
    font-weight: 500 !important;
    color: #122352 !important;
    line-height: 1.55 !important;
    text-align: center !important;
    margin: 0 !important;
    padding: 0 8px !important;
    letter-spacing: 0.02em !important;
}
.okz-article .okzd-business-card__grid {
    display: grid !important;
    grid-template-columns: 1fr 1fr 1fr !important;
    gap: 0 !important;
    background: #fff !important;
    border-top: 1px solid #e1e7f3 !important;
    margin: 0 !important;
    padding: 0 !important;
}
.okz-article .okzd-business-card__cell {
    text-align: center !important;
    padding: 18px 4px 16px !important;
    background: #fff !important;
    border-right: 1px solid #eef1f6 !important;
    border-bottom: 1px solid #eef1f6 !important;
}
/* 3列目（3, 6番目）は右ボーダーなし */
.okz-article .okzd-business-card__cell:nth-child(3n) {
    border-right: none !important;
}
/* 2行目（4, 5, 6番目）は下ボーダーなし */
.okz-article .okzd-business-card__cell:nth-child(n+4) {
    border-bottom: none !important;
}
.okz-article .okzd-business-card__label {
    display: block !important;
    margin: 0 !important;
    font-size: 11px !important;
    color: #5a6776 !important;
    font-weight: 500 !important;
    letter-spacing: 0.04em !important;
    line-height: 1.2 !important;
    background: transparent !important;
}
.okz-article .okzd-business-card__label::after {
    content: '' !important;
    display: block !important;
    width: 1.8em !important;
    margin: 6px auto 0 !important;
    border-bottom: 2px solid #1d3994 !important;
}
.okz-article .okzd-business-card__value {
    display: block !important;
    margin: 8px 0 0 !important;
    padding: 0 !important;
    font-size: 17px !important;
    color: #2c2c2a !important;
    font-weight: 700 !important;
    line-height: 1.3 !important;
    background: transparent !important;
}
.okz-article .okzd-business-card__value--circle {
    font-size: 24px !important;
    color: #1d3994 !important;
    line-height: 1 !important;
    margin-top: 10px !important;
}
.okz-article .okzd-business-card__value--circle.is-cross {
    color: #b23a48 !important;
}

/* スマートフォン対応（375px幅でも3列キープ） */
@media (max-width: 600px) {
    .okz-article .okzd-business-card__head {
        padding: 18px 12px 14px !important;
    }
    .okz-article .okzd-business-card__logo img {
        max-width: 160px !important;
        max-height: 50px !important;
    }
    .okz-article .okzd-business-card__heading {
        font-size: 14px !important;
        padding: 0 4px !important;
        line-height: 1.5 !important;
    }
    .okz-article .okzd-business-card__cell {
        padding: 12px 2px 10px !important;
    }
    .okz-article .okzd-business-card__label {
        font-size: 9px !important;
        letter-spacing: 0 !important;
    }
    .okz-article .okzd-business-card__label::after {
        margin-top: 4px !important;
    }
    .okz-article .okzd-business-card__value {
        font-size: 12px !important;
        margin-top: 6px !important;
    }
    .okz-article .okzd-business-card__value--circle {
        font-size: 17px !important;
        margin-top: 8px !important;
    }
}

/* ─────────────────────────────────
   ⑪ okzd/toc（目次）案D：枠なしフラット
   - 上下に細い区切り線のみ、枠なし
   - 「CONTENTS」のラベル＋連番ゼロ埋め（01, 02, 03...）
   - <details><summary> でJSなしでも開閉動作
   - デフォルトは閉じた状態
   ───────────────────────────────── */
/* ============================================================
   目次（okzd/toc）― 本家配色。最初の5件表示／6件目以降は透過＋「表示」ボタン
   ============================================================ */
.okz-article .okzd-toc {
    margin: 28px 0 !important;
    padding: 16px 18px !important;
    background: #fff !important;
    border: 1px solid #e5e7eb !important;
    border-radius: 12px !important;
}
/* 見出しが0件なら目次自体を非表示 */
.okz-article .okzd-toc--empty { display: none !important; }

/* ヘッダー（「目次」バッジ＋任意サブテキスト） */
.okz-article .okzd-toc__head {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    padding-bottom: 10px !important;
    border-bottom: 1px dashed #e5e7eb !important;
}
.okz-article .okzd-toc__badge {
    display: inline-block !important;
    padding: 3px 12px !important;
    background: #fff !important;
    color: #F0465A !important;
    border: 1px solid #F0465A !important;
    border-radius: 999px !important;
    font-size: 12px !important;
    font-weight: 700 !important;
    letter-spacing: 0.06em !important;
    line-height: 1.5 !important;
    flex: 0 0 auto !important;
}
.okz-article .okzd-toc__title {
    color: #999 !important;
    font-size: 12px !important;
    font-weight: 400 !important;
    flex: 1 1 auto !important;
}

/* リスト本体 */
.okz-article .okzd-toc__list {
    list-style: none !important;
    list-style-type: none !important;
    counter-reset: none !important;
    margin: 0 !important;
    padding: 10px 2px 2px !important;
    background: transparent !important;
    border: none !important;
}
/* ol の自動番号（1. 2. 3.）を確実に消す */
.okz-article .okzd-toc__list > li::marker,
.okz-article .okzd-toc__item::marker {
    content: "" !important;
}
.okz-article .okzd-toc__sublist {
    list-style: none !important;
    margin: 2px 0 4px 0 !important;
    padding: 0 0 0 24px !important;
    border: none !important;
}
.okz-article .okzd-toc__item {
    margin: 0 !important;
    padding: 0 !important;
    position: relative !important;
    transition: opacity 0.25s ease !important;
}
.okz-article .okzd-toc__item--h2 {
    padding: 6px 0 6px 2px !important;
    font-size: 14px !important;
    font-weight: 500 !important;
}
.okz-article .okzd-toc__item--h3 {
    padding: 3px 0 3px 14px !important;
    font-size: 13px !important;
    color: #666 !important;
}
.okz-article .okzd-toc__item--h3::before {
    content: '–';
    position: absolute;
    left: 0;
    top: 3px;
    color: #bbb;
}
.okz-article .okzd-toc__link {
    color: #333 !important;
    text-decoration: none !important;
    line-height: 1.6 !important;
    transition: color 0.15s ease;
}
.okz-article .okzd-toc__link:hover,
.okz-article .okzd-toc__link:focus {
    color: #F0465A !important;
    text-decoration: none !important;
}

/* 折りたたみ時は6行目以降（H2・H3問わず）を非表示にしてコンパクトに */
.okz-article .okzd-toc--collapsed .okzd-toc__row--over {
    display: none !important;
}

/* 「表示／閉じる」ボタン */
.okz-article .okzd-toc__toggle {
    display: block !important;
    width: 100% !important;
    margin: 6px 0 !important;
    padding: 9px 12px !important;
    background: #fff !important;
    color: #F0465A !important;
    border: 1px solid #F0465A !important;
    border-radius: 999px !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    cursor: pointer !important;
    transition: background 0.15s ease, color 0.15s ease !important;
}
.okz-article .okzd-toc__toggle::after { content: ' ▼' !important; font-size: 10px !important; }
.okz-article .okzd-toc:not(.okzd-toc--collapsed) .okzd-toc__toggle::after { content: ' ▲' !important; }
.okz-article .okzd-toc__toggle:hover { background: #F0465A !important; color: #fff !important; }

/* スクロール時のヘッダー固定オフセット */
.okz-article h2[id],
.okz-article h3[id] { scroll-margin-top: 80px; }

/* スマホ */
@media screen and (max-width: 600px) {
    .okz-article .okzd-toc { padding: 14px 14px !important; }
    .okz-article .okzd-toc__sublist { padding-left: 20px !important; }
    .okz-article .okzd-toc__item--h2 { font-size: 13px !important; }
    .okz-article .okzd-toc__item--h3 { font-size: 12px !important; }
}

/* =====================================================
   ⑬ 業者カード・汎用（okzd/agent-card / 案2ミニマル・角丸なし）
   ===================================================== */
.okz-article .okzd-agent-card {
    display: flex !important;
    background: #fff !important;
    border: 1px solid #e7e9ef !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    overflow: hidden !important;
    margin: 24px 0 !important;
}
.okz-article .okzd-agent-card__side {
    flex: 0 0 150px !important;
    background: #fff !important;
    border-right: 1px solid #f0f2f7 !important;
    padding: 20px 16px !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 10px !important;
    text-align: center !important;
}
.okz-article .okzd-agent-card__logo img {
    max-width: 120px !important;
    height: auto !important;
    display: block !important;
}
.okz-article .okzd-agent-card__rating {
    line-height: 1.2 !important;
}
.okz-article .okzd-agent-card__stars {
    display: block !important;
    color: #f5a623 !important;
    font-size: 14px !important;
    letter-spacing: 1px !important;
}
.okz-article .okzd-agent-card__stars-empty {
    color: #dfe3ec !important;
}
.okz-article .okzd-agent-card__rating-num {
    display: block !important;
    font-size: 20px !important;
    font-weight: 800 !important;
    color: #122352 !important;
    margin-top: 2px !important;
}
.okz-article .okzd-agent-card__cta {
    width: 100% !important;
}
.okz-article .okzd-agent-card__cta a {
    display: inline-block !important;
    background: #1d3994 !important;
    color: #fff !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    padding: 8px 14px !important;
    border-radius: 0 !important;
    text-decoration: none !important;
}
.okz-article .okzd-agent-card__main {
    flex: 1 1 auto !important;
    padding: 18px 22px !important;
    min-width: 0 !important;
}
.okz-article .okzd-agent-card__tags {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 6px !important;
    margin-bottom: 10px !important;
}
.okz-article .okzd-agent-card__tag {
    display: inline-block !important;
    background: #fff !important;
    color: #7a8699 !important;
    border: 1px solid #e0e4ec !important;
    border-radius: 0 !important;
    font-size: 11px !important;
    font-weight: 600 !important;
    padding: 2px 8px !important;
    line-height: 1.5 !important;
}
.okz-article .okzd-agent-card__tag.is-cat {
    background: #fff !important;
    color: #7a8699 !important;
}
.okz-article .okzd-agent-card__name {
    font-size: 17px !important;
    font-weight: 700 !important;
    color: #122352 !important;
    margin: 0 0 12px !important;
    line-height: 1.5 !important;
}
.okz-article .okzd-agent-card__specs {
    margin: 0 !important;
    padding: 0 !important;
}
.okz-article .okzd-agent-card__spec {
    display: flex !important;
    gap: 12px !important;
    padding: 9px 0 !important;
    border-bottom: 1px solid #f4f5f9 !important;
    margin: 0 !important;
}
.okz-article .okzd-agent-card__spec:last-child {
    border-bottom: none !important;
}
.okz-article .okzd-agent-card__spec-label {
    flex: 0 0 110px !important;
    font-size: 13px !important;
    color: #8a93a3 !important;
    margin: 0 !important;
    font-weight: 400 !important;
}
.okz-article .okzd-agent-card__spec-value {
    flex: 1 1 auto !important;
    text-align: left !important;
    font-size: 13px !important;
    color: #1a2540 !important;
    font-weight: 600 !important;
    margin: 0 !important;
    word-break: break-word !important;
}
/* スマホ：縦積み */
@media (max-width: 600px) {
    .okz-article .okzd-agent-card {
        flex-direction: column !important;
    }
    .okz-article .okzd-agent-card__side {
        flex: none !important;
        border-right: none !important;
        border-bottom: 1px solid #f0f2f7 !important;
        flex-direction: column !important;
        align-items: center !important;
        justify-content: center !important;
        text-align: center !important;
        gap: 8px !important;
    }
    .okz-article .okzd-agent-card__cta {
        width: auto !important;
    }
    .okz-article .okzd-agent-card__spec-label {
        flex: 0 0 96px !important;
    }
}

/* ─────────────────────────────────
   lead-card（項目がタイトル＋説明の2段になる導入カード）
   ※自動成型でまれに使用。ボックスリストと同系の見た目にそろえる
   ───────────────────────────────── */
.okz-article .okzd-lead-card {
    margin: 28px 0 !important;
    padding: 18px 20px !important;
    background: #fff !important;
    border: 1px solid #e5e7eb !important;
    border-radius: 12px !important;
    box-shadow: 0 4px 10px rgba(15,23,42,.06) !important;
}
.okz-article .okzd-lead-card-title {
    display: inline-block !important;
    margin: 0 0 12px !important;
    padding: 5px 16px !important;
    background: #F0465A !important;
    color: #fff !important;
    border-radius: 999px !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    letter-spacing: 0.02em !important;
}
.okz-article .okzd-lead-card-list {
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
}
.okz-article .okzd-lead-card-list--numbered { counter-reset: okzd-lead !important; }
.okz-article .okzd-lead-card-list--numbered > li {
    position: relative !important;
    counter-increment: okzd-lead !important;
    padding: 10px 0 10px 34px !important;
    border-top: 1px solid #f1f3f5 !important;
}
.okz-article .okzd-lead-card-list--numbered > li:first-child { border-top: none !important; }
.okz-article .okzd-lead-card-list--numbered > li::before {
    content: counter(okzd-lead) !important;
    position: absolute !important;
    left: 0 !important;
    top: 10px !important;
    width: 24px !important;
    height: 24px !important;
    background: #F0465A !important;
    color: #fff !important;
    border-radius: 50% !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-family: Arial, "Helvetica Neue", sans-serif !important;
}
.okz-article .okzd-lead-card-item-title {
    display: block !important;
    font-weight: 700 !important;
    color: #333 !important;
    font-size: 15px !important;
}
.okz-article .okzd-lead-card-item-body {
    display: block !important;
    color: #555 !important;
    font-size: 14px !important;
    line-height: 1.7 !important;
    margin-top: 2px !important;
}
