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

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

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

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

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

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

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

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

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

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

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

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

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

/* ── 旧構造（v1.13.1以前: head + body 形式）への後方互換 ── */
.ht-article .htd-warning-box__head {
    background: #E1262E !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;
}
.ht-article .htd-warning-box__head-icon {
    font-size: 20.8px !important;
    line-height: 1 !important;
    color: #fff !important;
}
.ht-article .htd-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;
}

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

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

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

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

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

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


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

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

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

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

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

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

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

/* =====================================================
   ⑬ 業者カード・軽量版（hontube/agent-card / 名前＋ロゴのみ）
   - 表示：サービス名 → その下にロゴ画像、のみ
   - 枠線・区切り線・背景なし（素のまま本文になじむ）
   - スペック行／CTA／★評価は廃止（v0.2.6）
   ===================================================== */
.ht-article .htd-agent-card {
    background: transparent !important;
    border: none !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    margin: 24px 0 !important;
    padding: 0 !important;
}
.ht-article .htd-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;
}
.ht-article .htd-agent-card__logo {
    text-align: center !important;
    padding: 0 !important;
    border: none !important;
}
.ht-article .htd-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） */
.ht-article .htd-agent-card__logo--svg img {
    max-width: 360px !important;
    max-height: 100px !important;
}

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

/* ──────────────────────────────────────────────
   ランキングカード（hontube/ranking-card）
   ────────────────────────────────────────────── */
.htd-rank-card {
    display: flex;
    align-items: center;
    gap: 14px;
    border: 1px solid #e7e7ea;
    border-radius: 10px;
    padding: 14px;
    margin: 0 0 12px;
    background: #fff;
}
.htd-rank-card__no {
    flex: 0 0 34px;
    width: 34px;
    height: 34px;
    border-radius: 50%;
    background: #9a9aa2;
    color: #fff;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 16px;
}
.htd-rank-card__no.is-1 { background: #E1262E; }
.htd-rank-card__no.is-2 { background: #8a8a92; }
.htd-rank-card__no.is-3 { background: #a9a9b0; }
.htd-rank-card__logo {
    flex: 0 0 70px;
    width: 70px;
    height: 50px;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}
.htd-rank-card__logo img {
    max-width: 100%;
    max-height: 100%;
    height: auto;
    object-fit: contain;
}
.htd-rank-card__body {
    flex: 1 1 auto;
    min-width: 0;
}
.htd-rank-card__name {
    margin: 0;
    font-size: 16px;
    font-weight: 700;
    color: #2B2E3A;
}
.htd-rank-card__pr {
    margin: 4px 0 0;
    font-size: 13px;
    color: #5c5c63;
    line-height: 1.5;
}
.htd-rank-card__btn {
    flex: 0 0 auto;
    display: inline-block;
    background: #E1262E;
    color: #fff;
    text-decoration: none;
    font-size: 14px;
    padding: 9px 16px;
    border-radius: 6px;
    white-space: nowrap;
}
.htd-rank-card__btn:hover { background: #b81c23; color: #fff; }
@media ( max-width: 600px ) {
    .htd-rank-card { flex-wrap: wrap; }
    .htd-rank-card__body { flex: 1 1 100%; order: 3; }
    .htd-rank-card__btn { width: 100%; text-align: center; order: 4; }
}
