/* ============================================================
   藤立病院デザイン - Front CSS
   フロント公開ページでのブロック表示スタイル
   すべて .fjt-article 配下でのみ適用
   ============================================================ */

/* ─────────────────────────────────
   黄色マーカー(エディタのドロップダウン内の装飾ボタンで付与)
   ───────────────────────────────── */
.fjt-article .fjtd-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 の定義がないため、
   フロントでもサイズ切替が反映されるよう定義
   ───────────────────────────────── */
.fjt-article p.has-small-font-size,
.fjt-article .has-small-font-size {
    font-size: 20.8px !important;
    line-height: 1.7 !important;
}
.fjt-article p.has-medium-font-size,
.fjt-article .has-medium-font-size {
    font-size: 25.6px !important;
    line-height: 1.75 !important;
}
.fjt-article p.has-large-font-size,
.fjt-article .has-large-font-size {
    font-size: 32px !important;
    line-height: 1.6 !important;
}
.fjt-article p.has-x-large-font-size,
.fjt-article .has-x-large-font-size {
    font-size: 38.4px !important;
    line-height: 1.5 !important;
}

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

/* ─────────────────────────────────
   ① fjtd/sub-heading（偽見出し）― 本家配色
   h4等を使わない、見た目だけの見出し。<p>ラッパー
   ───────────────────────────────── */
.fjt-article .fjtd-sub-heading-wrap {
    display: block !important;
    margin: 24px 0 12px !important;
    padding: 0 !important;
    background: transparent !important;
    border: none !important;
}
.fjt-article .fjtd-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;
}
.fjt-article .fjtd-sub-heading::before {
    content: "" !important;
    flex: 0 0 auto !important;
    width: 6px !important;
    height: 20px !important;
    background: #00adec !important;
    border-radius: 2px !important;
}

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

/* ─────────────────────────────────
   ② fjtd/table-caption(テーブルキャプション)
   ───────────────────────────────── */
.fjt-article .fjtd-table-caption {
    display: block !important;
    background: #00adec !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;
}
.fjt-article .fjtd-table-caption__text {
    color: #fff !important;
    font-weight: 700 !important;
    font-size: inherit !important;
    line-height: inherit !important;
}

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

/* ─────────────────────────────────
   ②-b fjtd-table-note（表の下の注釈・出典など）
   案1：グレーの小さめテキスト。控えめに添える。
   ───────────────────────────────── */
.fjt-article .fjtd-table-note {
    font-size: 12.5px !important;
    color: #888 !important;
    line-height: 1.6 !important;
    margin: 6px 0 16px !important;
}

/* ─────────────────────────────────
   ③ fjtd/author-comment(筆者コメント)
   <aside>化に伴い、<blockquote>用のリセットは不要に
   ただし aside のブラウザデフォルトもほぼ無いので影響なし
   ───────────────────────────────── */
/* 案A：吹き出し（スピーチバブル）。名前は非表示・本文のみ。アバターは任意設定 */
.fjt-article .fjtd-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;
}
.fjt-article .fjtd-author-comment::before,
.fjt-article .fjtd-author-comment::after {
    content: none !important;
    display: none !important;
}
.fjt-article .fjtd-author-comment__avatar-wrap {
    flex: 0 0 52px !important;
    width: 52px !important;
    height: 52px !important;
}
.fjt-article .fjtd-author-comment__avatar {
    width: 52px !important;
    height: 52px !important;
    max-width: 52px !important;
    border-radius: 50% !important;
    border: 2px solid #00adec !important;
    object-fit: cover !important;
    display: block !important;
    margin: 0 !important;
    padding: 0 !important;
    box-sizing: border-box !important;
}
.fjt-article .fjtd-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;
}
.fjt-article .fjtd-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;
}
.fjt-article .fjtd-author-comment__name {
    display: none !important;
}
.fjt-article .fjtd-author-comment__text {
    font-size: 16px !important;
    line-height: 1.8 !important;
    color: #333 !important;
}
.fjt-article .fjtd-author-comment__text p {
    font-size: 16px !important;
    line-height: 1.8 !important;
    margin: 0 0 12px !important;
    color: #333 !important;
}
.fjt-article .fjtd-author-comment__text p:last-child {
    margin-bottom: 0 !important;
}

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

/* ─────────────────────────────────
   ⑤ fjtd/compare-box + compare-col(対比ブロック)
   ───────────────────────────────── */
.fjt-article .fjtd-compare-box {
    display: flex !important;
    gap: 20px !important;
    margin: 24px 0 !important;
    padding: 0 !important;
    background: transparent !important;
    border: none !important;
}
.fjt-article .fjtd-compare-col {
    flex: 1 1 0 !important;
    padding: 20px 22px !important;
    border-radius: 6px !important;
    box-sizing: border-box !important;
    margin: 0 !important;
}
.fjt-article .fjtd-compare-col--pros {
    background: #e8f6fd !important;
    border: 2px solid #00adec !important;
}
.fjt-article .fjtd-compare-col--cons {
    background: #f3f4f6 !important;
    border: 2px solid #94a3b8 !important;
}
.fjt-article .fjtd-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;
}
.fjt-article .fjtd-compare-col--pros .fjtd-compare-col__head {
    color: #00adec !important;
    border-bottom: 2px solid #00adec !important;
}
.fjt-article .fjtd-compare-col--cons .fjtd-compare-col__head {
    color: #475569 !important;
    border-bottom: 2px solid #94a3b8 !important;
}
.fjt-article .fjtd-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;
}
.fjt-article .fjtd-compare-col--pros .fjtd-compare-col__icon { background: #00adec !important; }
.fjt-article .fjtd-compare-col--cons .fjtd-compare-col__icon { background: #64748b !important; }
.fjt-article .fjtd-compare-col__heading {
    font-weight: 700 !important;
    font-size: 16px !important;
    line-height: 1.4 !important;
}
/* compare内のリスト */
.fjt-article .fjtd-compare-col__body ul,
.fjt-article .fjtd-compare-col__body ol {
    margin: 0 !important;
    padding: 0 !important;
    list-style: none !important;
    border: none !important;
    background: none !important;
}
.fjt-article .fjtd-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;
}
.fjt-article .fjtd-compare-col__body li::marker { content: none !important; display: none !important; }
.fjt-article .fjtd-compare-col--pros .fjtd-compare-col__body li::before {
    content: "・" !important;
    position: absolute !important;
    left: 2px !important;
    top: 3px !important;
    color: #00adec !important;
    font-weight: 700 !important;
    font-size: 18px !important;
}
.fjt-article .fjtd-compare-col--cons .fjtd-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;
}
.fjt-article .fjtd-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) {
    .fjt-article .fjtd-compare-box {
        flex-direction: column !important;
        gap: 12px !important;
    }
}

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

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

/* ─────────────────────────────────
   ⑥ fjtd/faq + faq-item(FAQ)
   構造: <dl class="fjtd-faq"><dt class="fjtd-faq-item__question">...</dt><dd class="fjtd-faq-item__answer">...</dd>...</dl>
   dlのデフォルト margin/indent リセット、dt/dd で個別スタイル
   ───────────────────────────────── */
.fjt-article .fjtd-faq {
    margin: 24px 0 !important;
    padding: 0 !important;
    background: transparent !important;
    border-top: 1px solid #e5e7eb !important;
    border-bottom: 1px solid #e5e7eb !important;
}
.fjt-article .fjtd-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;
}
.fjt-article .fjtd-faq .fjtd-faq-item__question:first-of-type {
    border-top: none !important;
}
.fjt-article .fjtd-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;
}
.fjt-article .fjtd-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;
}
.fjt-article .fjtd-faq-item__badge--q { background: #00adec !important; }
.fjt-article .fjtd-faq-item__badge--a { background: #fff !important; color: #00adec !important; border: 1.5px solid #00adec !important; }
.fjt-article .fjtd-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;
}
.fjt-article .fjtd-faq-item__answer-body {
    flex: 1 1 auto !important;
    font-size: 16px !important;
    color: #333 !important;
    line-height: 1.75 !important;
}
.fjt-article .fjtd-faq-item__answer-body p {
    font-size: 16px !important;
    line-height: 1.75 !important;
    margin: 0 0 10px !important;
    color: #333 !important;
}
.fjt-article .fjtd-faq-item__answer-body p:last-child { margin-bottom: 0 !important; }

/* ─────────────────────────────────
   ⑦ fjtd/references + reference-item(参考・引用元)
   <ol><li> 構造に変更。list-styleはCSSでリセットして見た目維持
   ───────────────────────────────── */
.fjt-article .fjtd-references {
    margin: 28px 0 !important;
    padding: 0 !important;
    background: transparent !important;
    border: none !important;
}
.fjt-article .fjtd-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;
}
/* ミニマル：番号・枠なし。リンクのみを行間広めで縦並び */
.fjt-article ol.fjtd-references__list,
.fjt-article .fjtd-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;
}
.fjt-article li.fjtd-reference-item,
.fjt-article .fjtd-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;
}
.fjt-article .fjtd-reference-item::before {
    content: none !important;
    display: none !important;
}
.fjt-article .fjtd-reference-item::marker { content: none !important; display: none !important; }
.fjt-article .fjtd-reference-item a {
    color: #00adec !important;
    text-decoration: underline !important;
    word-break: break-word !important;
}
.fjt-article .fjtd-reference-item a:hover { color: #0093c9 !important; }
.fjt-article .fjtd-reference-item__source {
    color: #707070 !important;
    font-size: 0.95em !important;
    margin-left: 2px !important;
}
/* 空のreference-item（nameなし）は何も表示しない */
.fjt-article .fjtd-reference-item--empty {
    display: none !important;
}

/* ─────────────────────────────────
   ⑧ fjtd/step-flow + step-item(ステップフロー)
   構造: <ol class="fjtd-step-flow"><li class="fjtd-step-item">...</li></ol>
   ブラウザ標準番号マーカー(1. 2. 3.)はlist-style/::markerで打ち消し、
   CSS counterによる中抜き丸番号の描画を維持
   ───────────────────────────────── */
.fjt-article .fjtd-step-flow {
    margin: 24px 0 !important;
    padding: 0 !important;
    background: transparent !important;
    border: none !important;
    counter-reset: fjtd-step-counter !important;
    list-style: none !important;
}
.fjt-article .fjtd-step-item {
    padding: 0 0 22px !important;
    border: none !important;
    counter-increment: fjtd-step-counter !important;
    position: relative !important;
    margin: 0 !important;
    background: transparent !important;
    list-style: none !important;
}
.fjt-article .fjtd-step-item::marker {
    content: none !important;
    display: none !important;
}
/* 縦の連結線：丸番号の中心(left16px)を通す。最後の項目は線なし */
.fjt-article .fjtd-step-item::before {
    content: "" !important;
    position: absolute !important;
    left: 15px !important;
    top: 0 !important;
    bottom: 0 !important;
    width: 2px !important;
    background: #b8e4f7 !important;
    z-index: 0 !important;
}
.fjt-article .fjtd-step-item:last-child {
    padding-bottom: 0 !important;
}
.fjt-article .fjtd-step-item:last-child::before {
    display: none !important;
}
.fjt-article .fjtd-step-item__content {
    padding-left: 48px !important;
    position: relative !important;
    min-height: 32px !important;
}
.fjt-article .fjtd-step-item__content::before {
    content: counter( fjtd-step-counter ) !important;
    position: absolute !important;
    left: 0 !important;
    top: 0 !important;
    width: 32px !important;
    height: 32px !important;
    background: #00adec !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;
}
.fjt-article .fjtd-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;
}
.fjt-article .fjtd-step-item__body {
    font-size: 16px !important;
    color: #333 !important;
    line-height: 1.75 !important;
}
.fjt-article .fjtd-step-item__body p {
    font-size: 16px !important;
    line-height: 1.75 !important;
    margin: 0 0 10px !important;
    color: #333 !important;
}
.fjt-article .fjtd-step-item__body p:last-child { margin-bottom: 0 !important; }

/* ─────────────────────────────────
   ⑩ fjtd/box-list（ボックスリスト）― 本家配色・白い角丸ボックス
   タイトル空欄時は .fjtd-box-list__header が存在しない
   ───────────────────────────────── */
.fjt-article .fjtd-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;
}
.fjt-article .fjtd-box-list__header {
    display: block !important;
    padding: 0 !important;
    margin: 0 0 12px !important;
    border: none !important;
    background: transparent !important;
}
.fjt-article .fjtd-box-list__title-bar { display: none !important; }
.fjt-article .fjtd-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: #00adec !important;
    border-radius: 999px !important;
}
.fjt-article .fjtd-box-list__body {
    padding: 0 !important;
    background: transparent !important;
    margin: 0 !important;
}
.fjt-article .fjtd-box-list > .fjtd-box-list__body:first-child {
    padding-top: 0 !important;
}

/* 箱内のリスト装飾 */
.fjt-article .fjtd-box-list ul,
.fjt-article .fjtd-box-list ul.wp-block-list {
    margin: 0 !important;
    padding: 0 !important;
    list-style: none !important;
    border: none !important;
    background: none !important;
}
.fjt-article .fjtd-box-list ul li,
.fjt-article .fjtd-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;
}
.fjt-article .fjtd-box-list ul li::marker,
.fjt-article .fjtd-box-list ul.wp-block-list li::marker {
    content: none !important;
    display: none !important;
}
.fjt-article .fjtd-box-list ul li::before,
.fjt-article .fjtd-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: #00adec !important;
    border-radius: 50% !important;
}
.fjt-article .fjtd-box-list ul li + li,
.fjt-article .fjtd-box-list ul.wp-block-list li + li {
    border-top: none !important;
}

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


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

/* ヘッダー（「目次」バッジ＋任意サブテキスト） */
.fjt-article .fjtd-toc__head {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    padding-bottom: 10px !important;
    border-bottom: 1px dashed #e5e7eb !important;
}
.fjt-article .fjtd-toc__badge {
    display: inline-block !important;
    padding: 3px 12px !important;
    background: #fff !important;
    color: #00adec !important;
    border: 1px solid #00adec !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;
}
.fjt-article .fjtd-toc__title {
    color: #999 !important;
    font-size: 12px !important;
    font-weight: 400 !important;
    flex: 1 1 auto !important;
}

/* リスト本体 */
.fjt-article .fjtd-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.）を確実に消す */
.fjt-article .fjtd-toc__list > li::marker,
.fjt-article .fjtd-toc__item::marker {
    content: "" !important;
}
.fjt-article .fjtd-toc__sublist {
    list-style: none !important;
    margin: 2px 0 4px 0 !important;
    padding: 0 0 0 24px !important;
    border: none !important;
}
.fjt-article .fjtd-toc__item {
    margin: 0 !important;
    padding: 0 !important;
    position: relative !important;
    transition: opacity 0.25s ease !important;
}
.fjt-article .fjtd-toc__item--h2 {
    padding: 6px 0 6px 2px !important;
    font-size: 14px !important;
    font-weight: 500 !important;
}
.fjt-article .fjtd-toc__item--h3 {
    padding: 3px 0 3px 14px !important;
    font-size: 13px !important;
    color: #666 !important;
}
.fjt-article .fjtd-toc__item--h3::before {
    content: '–';
    position: absolute;
    left: 0;
    top: 3px;
    color: #bbb;
}
.fjt-article .fjtd-toc__link {
    color: #333 !important;
    text-decoration: none !important;
    line-height: 1.6 !important;
    transition: color 0.15s ease;
}
.fjt-article .fjtd-toc__link:hover,
.fjt-article .fjtd-toc__link:focus {
    color: #00adec !important;
    text-decoration: none !important;
}

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

/* 「表示／閉じる」ボタン */
.fjt-article .fjtd-toc__toggle {
    display: block !important;
    width: 100% !important;
    margin: 6px 0 !important;
    padding: 9px 12px !important;
    background: #fff !important;
    color: #00adec !important;
    border: 1px solid #00adec !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;
}
.fjt-article .fjtd-toc__toggle::after { content: ' ▼' !important; font-size: 10px !important; }
.fjt-article .fjtd-toc:not(.fjtd-toc--collapsed) .fjtd-toc__toggle::after { content: ' ▲' !important; }
.fjt-article .fjtd-toc__toggle:hover { background: #00adec !important; color: #fff !important; }

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

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

/* =====================================================
   ⑬ 業者カード・軽量版（fjtd/agent-card / 名前＋ロゴのみ）
   - 表示：サービス名 → その下にロゴ画像、のみ
   - 枠線・区切り線・背景なし（素のまま本文になじむ）
   - スペック行／CTA／★評価は廃止（v0.2.6）
   ===================================================== */
.fjt-article .fjtd-agent-card {
    background: transparent !important;
    border: none !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    margin: 24px 0 !important;
    padding: 0 !important;
}
.fjt-article .fjtd-agent-card__name {
    font-size: 19px !important;
    font-weight: 700 !important;
    color: #333 !important;
    line-height: 1.4 !important;
    margin: 0 0 16px !important;
    padding-bottom: 12px !important;
    border-bottom: 2px solid #333 !important;
}
.fjt-article .fjtd-agent-card__logo {
    text-align: center !important;
    padding: 0 !important;
    border: none !important;
}
.fjt-article .fjtd-agent-card__logo img {
    max-width: 200px !important;
    max-height: 54px !important;
    width: auto !important;
    height: auto !important;
    object-fit: contain !important;
    display: inline-block !important;
    margin: 0 auto !important;
}
/* SVG由来ロゴ：しっかり大きく表示（案B） */
.fjt-article .fjtd-agent-card__logo--svg img {
    max-width: 360px !important;
    max-height: 100px !important;
}

/* ─────────────────────────────────
   lead-card（項目がタイトル＋説明の2段になる導入カード）
   ※自動成型でまれに使用。ボックスリストと同系の見た目にそろえる
   ───────────────────────────────── */
.fjt-article .fjtd-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;
}
.fjt-article .fjtd-lead-card-title {
    display: inline-block !important;
    margin: 0 0 12px !important;
    padding: 5px 16px !important;
    background: #00adec !important;
    color: #fff !important;
    border-radius: 999px !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    letter-spacing: 0.02em !important;
}
.fjt-article .fjtd-lead-card-list {
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
}
.fjt-article .fjtd-lead-card-list--numbered { counter-reset: fjtd-lead !important; }
.fjt-article .fjtd-lead-card-list--numbered > li {
    position: relative !important;
    counter-increment: fjtd-lead !important;
    padding: 10px 0 10px 34px !important;
    border-top: 1px solid #f1f3f5 !important;
}
.fjt-article .fjtd-lead-card-list--numbered > li:first-child { border-top: none !important; }
.fjt-article .fjtd-lead-card-list--numbered > li::before {
    content: counter(fjtd-lead) !important;
    position: absolute !important;
    left: 0 !important;
    top: 10px !important;
    width: 24px !important;
    height: 24px !important;
    background: #00adec !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;
}
.fjt-article .fjtd-lead-card-item-title {
    display: block !important;
    font-weight: 700 !important;
    color: #333 !important;
    font-size: 15px !important;
}
.fjt-article .fjtd-lead-card-item-body {
    display: block !important;
    color: #555 !important;
    font-size: 14px !important;
    line-height: 1.7 !important;
    margin-top: 2px !important;
}
