/* ═══════════════════════════════════════════════════════════════
   PROSE.CSS — Single Post Article (FSE prose layout)
   조건부 로드: functions.php is_singular('post') 분기
   원본: style.css 에서 분리 (B-lite Phase 2A, 2026-04-29)

   포함 범위:
   - Article 헤더 (breadcrumb / title / meta / abstract)
   - Sticky TOC sidebar + 2-col layout
   - Academic prose styling (.fnc-prose-academic)
   - Data table, footnotes, single-wide overrides
   - Article callouts (callout / eval-table / quadrant / tag)
   ═══════════════════════════════════════════════════════════════ */

/* ═══════════════════════════════════════════════════════════════
   Single Article / Report Template — Academic Layout
   ═══════════════════════════════════════════════════════════════ */

/* ── Breadcrumb ──────────────────────────────────────────────── */
.fnc-article-breadcrumbs {
    display: flex !important;
    align-items: center !important;
    gap: 0.5rem !important;
    flex-wrap: wrap;
    font-family: var(--wp--preset--font-family--label);
    font-size: 0.7rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: rgba(64, 73, 61, 0.6);
    margin-bottom: 2rem !important;
}
.fnc-article-breadcrumbs a {
    color: inherit;
    text-decoration: none;
    transition: color .15s;
}
.fnc-article-breadcrumbs a:hover { color: var(--wp--preset--color--primary); }
.fnc-article-breadcrumbs .sep {
    font-family: 'Material Symbols Outlined';
    font-feature-settings: 'liga';
    font-size: 0.85rem;
    line-height: 1;
}
.fnc-article-breadcrumbs .current {
    color: var(--wp--preset--color--primary);
    font-weight: 600;
}

/* ── Article header (title + meta + download) ────────────────── */
.fnc-article-header {
    padding: 1rem 0 4rem 0;
}
.fnc-article-header .wp-block-post-title {
    font-family: var(--wp--preset--font-family--headline) !important;
    font-size: clamp(1.875rem, 3.4vw, 2.75rem) !important;
    font-weight: 800 !important;
    letter-spacing: -0.02em !important;
    line-height: 1.2 !important;
    margin: 0 0 2rem 0 !important;
    color: var(--wp--preset--color--on-surface);
}
.fnc-article-header .wp-block-post-title .fnc-article-subtitle {
    display: block;
    font-family: var(--wp--preset--font-family--body);
    font-size: clamp(0.9375rem, 1.2vw, 1.125rem);
    font-weight: 500;
    letter-spacing: -0.005em;
    line-height: 1.5;
    color: var(--wp--preset--color--on-surface-variant);
    margin-top: 0.875rem;
    opacity: 0.88;
}
/* Meta row — Grid 기반: labels(row1) + values(row2) + button(span both rows, right) */
.fnc-article-meta-row {
    display: grid !important;
    grid-template-columns: repeat(3, auto) 1fr !important;
    grid-template-rows: auto auto !important;
    column-gap: 2.5rem !important;
    row-gap: 0.4rem !important;
    align-items: end !important;
    border-top: 1px solid rgba(191, 202, 186, 0.35);
    padding-top: 2rem !important;
}
.fnc-article-meta-row .fnc-article-meta-item {
    display: contents;     /* let label and value participate in the parent grid */
}
.fnc-article-meta-row .fnc-article-meta-item label {
    grid-row: 1;
    margin: 0 !important;
}
.fnc-article-meta-row .fnc-article-meta-item .value,
.fnc-article-meta-row .fnc-article-meta-item .badge {
    grid-row: 2;
    align-self: end;
    margin: 0 !important;
    line-height: 1.4 !important;
}
.fnc-article-meta-row > .fnc-article-meta-item:nth-of-type(1) label,
.fnc-article-meta-row > .fnc-article-meta-item:nth-of-type(1) .value,
.fnc-article-meta-row > .fnc-article-meta-item:nth-of-type(1) .badge { grid-column: 1; }
.fnc-article-meta-row > .fnc-article-meta-item:nth-of-type(2) label,
.fnc-article-meta-row > .fnc-article-meta-item:nth-of-type(2) .value,
.fnc-article-meta-row > .fnc-article-meta-item:nth-of-type(2) .badge { grid-column: 2; }
.fnc-article-meta-row > .fnc-article-meta-item:nth-of-type(3) label,
.fnc-article-meta-row > .fnc-article-meta-item:nth-of-type(3) .value,
.fnc-article-meta-row > .fnc-article-meta-item:nth-of-type(3) .badge { grid-column: 3; }
.fnc-article-meta-item label {
    display: block;
    font-family: var(--wp--preset--font-family--label);
    font-size: 0.65rem;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    color: rgba(64, 73, 61, 0.55);
    margin-bottom: 0.35rem;
}
.fnc-article-meta-item .value {
    font-family: var(--wp--preset--font-family--body);
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--wp--preset--color--on-surface);
}
.fnc-article-meta-item .badge {
    display: inline-flex;
    align-items: center;
    padding: 0.2rem 0.55rem;
    border-radius: 0.25rem;
    background: var(--wp--preset--color--secondary-container);
    color: var(--wp--preset--color--on-secondary-container);
    font-family: var(--wp--preset--font-family--label);
    font-size: 0.65rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
}
.fnc-article-version-badge {
    display: inline-block;
    font-size: 0.6875rem;
    font-weight: 700;
    color: var(--wp--preset--color--on-surface-variant);
    font-family: var(--wp--preset--font-family--label);
    letter-spacing: 0.03em;
    white-space: nowrap;
    opacity: 0.7;
}
/* ── Abstract ────────────────────────────────────────────────── */
.fnc-article-abstract-section {
    padding-top: 4rem !important;
    padding-bottom: 4rem !important;
}
.fnc-article-abstract-grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 1rem !important;
    align-items: start;
}
.fnc-article-abstract-section h2 {
    font-family: var(--wp--preset--font-family--headline) !important;
    font-size: 1.5rem !important;
    font-weight: 700 !important;
    color: var(--wp--preset--color--primary) !important;
    margin: 0 !important;
}
.fnc-article-abstract-box {
    background: var(--wp--preset--color--surface-container-lowest);
    padding: 2.5rem;
    border-radius: 0.875rem;
    box-shadow: 0 1px 3px rgba(13, 99, 27,0.04);
}
.fnc-article-abstract-box p,
.fnc-article-abstract-box .wp-block-post-excerpt__excerpt {
    font-family: var(--wp--preset--font-family--body);
    font-size: 1.125rem !important;
    line-height: 1.7 !important;
    color: var(--wp--preset--color--on-surface-variant) !important;
    font-style: normal !important;
    margin: 0 !important;
}
.fnc-article-abstract-box p + p {
    margin-top: 1em !important;
}

/* ── Main 2-column layout (sticky sidebar + content) ─────────── */
.fnc-article-main {
    display: grid !important;
    grid-template-columns: 220px 1fr !important;
    gap: 1rem !important;
    align-items: start !important;
}
.fnc-prose-academic {
    --wp--style--global--content-size: 100% !important;
    --wp--style--global--wide-size: 100% !important;
    max-width: none !important;
}

/* ── Sticky TOC sidebar ──────────────────────────────────────── */
.fnc-article-sidebar {
    position: sticky;
    top: 100px;
}
.fnc-article-sidebar h3 {
    font-family: var(--wp--preset--font-family--headline) !important;
    font-size: 0.7rem !important;
    font-weight: 700 !important;
    letter-spacing: 0.15em !important;
    text-transform: uppercase !important;
    color: rgba(64, 73, 61, 0.5) !important;
    margin: 0 0 1.5rem 0 !important;
}
.fnc-article-toc {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
}
.fnc-article-toc li {
    margin: 0 0 1rem 0 !important;
}
.fnc-article-toc a {
    display: block;
    font-family: var(--wp--preset--font-family--body);
    font-size: 0.875rem;
    font-weight: 500;
    color: rgba(64, 73, 61, 0.6);
    padding-left: 1rem;
    border-left: 2px solid transparent;
    text-decoration: none;
    transition: all .15s;
    line-height: 1.5;
}
.fnc-article-toc a:hover {
    color: var(--wp--preset--color--on-surface);
    border-left-color: var(--wp--preset--color--outline-variant);
}
.fnc-article-toc a.is-active,
.fnc-article-toc li:first-child a {
    color: var(--wp--preset--color--primary);
    border-left-color: var(--wp--preset--color--primary);
    font-weight: 600;
}

/* ── TOC anchor scroll offset (clears sticky header) ─────── */
.fnc-prose-academic .wp-block-post-content h2 {
    scroll-margin-top: 6.5rem;
}

.fnc-key-metric-callout {
    margin-top: 3rem;
    padding: 1.5rem;
    border-radius: 0.75rem;
    background: var(--wp--preset--color--surface-container-high);
    border-left: 4px solid var(--wp--preset--color--secondary);
}
.fnc-key-metric-callout label {
    display: block;
    font-family: var(--wp--preset--font-family--headline);
    font-size: 0.7rem;
    font-weight: 700;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    color: var(--wp--preset--color--secondary);
    margin-bottom: 0.5rem;
}
.fnc-key-metric-callout .num {
    display: block;
    font-family: var(--wp--preset--font-family--headline);
    font-size: 1.875rem;
    font-weight: 700;
    color: var(--wp--preset--color--on-surface);
    margin-bottom: 0.25rem;
}
.fnc-key-metric-callout .desc {
    font-size: 0.7rem;
    color: var(--wp--preset--color--on-surface-variant);
    line-height: 1.45;
}

/* ── Academic prose styling for post content ─────────────────── */
.fnc-prose-academic .wp-block-post-content > h2 {
    font-family: var(--wp--preset--font-family--headline) !important;
    font-size: 1.875rem !important;
    font-weight: 700 !important;
    letter-spacing: -0.015em !important;
    margin: 3rem 0 1.5rem 0 !important;
    color: var(--wp--preset--color--on-surface) !important;
    line-height: 1.3 !important;
}
.fnc-prose-academic .wp-block-post-content > h3 {
    font-family: var(--wp--preset--font-family--headline) !important;
    font-size: 1.375rem !important;
    font-weight: 700 !important;
    margin: 2rem 0 1rem 0 !important;
    color: var(--wp--preset--color--on-surface) !important;
}
.fnc-prose-academic .wp-block-post-content > h4 {
    font-family: var(--wp--preset--font-family--headline) !important;
    font-size: 1rem !important;
    font-weight: 700 !important;
    margin: 1.5rem 0 0.5rem 0 !important;
    color: var(--wp--preset--color--on-surface) !important;
    letter-spacing: -0.01em !important;
}

/* ── 차트·인포그래픽 중앙 정렬 ───────────────────────────── */
figure.fnc-chart-inline {
    display: block !important;
    margin: 2rem auto !important;
}
figure.fnc-chart-inline > svg {
    display: block !important;
    margin: 0 auto !important;
}
/* 차트 figcaption — 박스 없이, 번호(strong)만 굵게 */
figure.fnc-chart-inline figcaption {
    background: none !important;
    color: var(--wp--preset--color--on-surface) !important;
    font-family: var(--wp--preset--font-family--headline) !important;
    font-size: 1rem !important;
    font-weight: 400 !important;
    font-style: normal !important;
    letter-spacing: -0.01em !important;
    padding: 0 0 0.5rem 0 !important;
    margin: 0 !important;
    border: none !important;
    text-align: center !important;
}
figure.fnc-chart-inline figcaption strong {
    font-weight: 700 !important;
}
.fnc-chart-caption {
    display: block !important;
    text-align: center !important;
    font-family: var(--wp--preset--font-family--label) !important;
    font-size: 0.75rem !important;
    color: var(--wp--preset--color--on-surface-variant) !important;
    margin-top: 0.5rem !important;
}
.fnc-table-title {
    margin-top: 1.75rem !important;
    margin-bottom: 0.5rem !important;
    color: var(--wp--preset--color--on-surface) !important;
    font-family: var(--wp--preset--font-family--headline) !important;
    font-size: 1rem !important;
    font-weight: 700 !important;
    line-height: 1.45 !important;
}
.fnc-prose-academic .wp-block-post-content > p {
    font-family: var(--wp--preset--font-family--body) !important;
    font-size: 1.0625rem !important;
    line-height: 1.85 !important;
    margin-bottom: 1.5rem !important;
    color: var(--wp--preset--color--on-surface-variant) !important;
}
.fnc-prose-academic .wp-block-post-content blockquote,
.fnc-prose-academic .wp-block-post-content > .wp-block-quote {
    border-left: 4px solid var(--wp--preset--color--primary) !important;
    padding: 0.5rem 0 0.5rem 1.5rem !important;
    font-style: italic;
    margin: 2rem 0 !important;
    color: var(--wp--preset--color--secondary) !important;
    font-size: 1.125rem !important;
    line-height: 1.7 !important;
}
.fnc-prose-academic .wp-block-post-content blockquote.fnc-quote-center {
    border-left: none !important;
    padding-left: 0 !important;
    text-align: center !important;
}
.fnc-prose-academic .wp-block-post-content figure.wp-block-image,
.fnc-prose-academic .wp-block-post-content > .wp-block-image {
    margin: 3rem 0 !important;
    border-radius: 1rem;
    overflow: hidden;
    box-shadow: 0 25px 50px -12px rgba(13, 99, 27,0.18);
}
.fnc-prose-academic .wp-block-post-content figcaption {
    background: var(--wp--preset--color--surface-container-low);
    padding: 1rem !important;
    text-align: center;
    font-family: var(--wp--preset--font-family--label);
    font-size: 0.7rem;
    color: var(--wp--preset--color--on-surface-variant);
    font-style: italic;
    margin: 0 !important;
}

/* ── 모바일: L1·아카이브 등 alignfull 섹션의 좌우 padding 축소 ───────
   L0/L1 페이지는 각 섹션이 alignfull wp:group 에 padding=var(--spacing--70)
   (≈ 3.375rem / 54px) 을 갖고 있어 데스크톱에서는 적절하지만 모바일
   (iPhone 390px)에서는 좌우 54×2=108px 가 먹혀 콘텐츠 실폭이 282px 에 그친다.
   모바일에서만 이 횡 padding 을 1.25rem 수준으로 축소해 콘텐츠 폭을 확보.
   세로(top/bottom) padding 은 var(--spacing--70) 그대로 유지 — 리듬 보존. */
@media (max-width: 640px) {
    :root {
        /* WP has-global-padding 이 쓰는 root padding 토큰도 같이 축소 */
        --wp--style--root--padding-left: 1.25rem;
        --wp--style--root--padding-right: 1.25rem;
    }
    /* alignfull wp:group 은 물론, alignfull wp:cover (L0/L1 Hero)까지 커버 */
    main .wp-block-group.alignfull,
    main .wp-block-cover.alignfull {
        padding-left: 1.25rem !important;
        padding-right: 1.25rem !important;
    }
}

/* ── 모바일 오버플로우 가드 ──────────────────────────────────────
   본문 테이블·이미지·SVG·긴 문자열이 뷰포트를 넘지 않도록 컨테이너에서
   가로 스크롤을 제한하고, 테이블은 그 자체로 가로 스크롤을 허용한다.
   데스크톱에서는 기존 동작 유지. */
.fnc-prose-academic .wp-block-post-content {
    overflow-wrap: break-word;
    word-break: keep-all; /* 한글 어절 단위 줄바꿈 유지 */
}
.fnc-prose-academic .wp-block-post-content img,
.fnc-prose-academic .wp-block-post-content svg,
.fnc-prose-academic .wp-block-post-content video,
.fnc-prose-academic .wp-block-post-content iframe {
    max-width: 100%;
    height: auto;
}
/* ── fnc-data-table 완전 재설계 ────────────────────────────────── */

/* 컨테이너 */
figure.fnc-data-table,
.wp-block-table.fnc-data-table {
    margin: 2rem 0 !important;
    border-radius: 10px !important;
    overflow: hidden !important;
    border: 1px solid var(--wp--preset--color--outline-variant) !important;
    box-shadow: 0 1px 4px rgba(0,0,0,.06) !important;
}

/* figcaption — 박스 없이 굵은 텍스트만 */
figure.fnc-data-table figcaption,
.wp-block-table.fnc-data-table figcaption {
    background: none !important;
    color: var(--wp--preset--color--on-surface) !important;
    font-family: var(--wp--preset--font-family--headline) !important;
    font-size: 1rem !important;
    font-weight: 700 !important;
    font-style: normal !important;
    letter-spacing: -0.01em !important;
    padding: 0 0 0.5rem 0 !important;
    margin: 0 !important;
    border: none !important;
    text-align: left !important;
}

/* table 기본 */
figure.fnc-data-table table,
.wp-block-table.fnc-data-table table {
    width: 100% !important;
    border-collapse: collapse !important;
    border-spacing: 0 !important;
    font-family: var(--wp--preset--font-family--body) !important;
    font-size: 0.9375rem !important;
    margin: 0 !important;
    background: #fff !important;
}

/* thead */
figure.fnc-data-table table thead th,
.wp-block-table.fnc-data-table table thead th {
    background: var(--wp--preset--color--primary) !important;
    color: #fff !important;
    font-family: var(--wp--preset--font-family--label) !important;
    font-size: 0.8rem !important;
    font-weight: 700 !important;
    letter-spacing: 0.05em !important;
    text-transform: uppercase !important;
    padding: 0.65rem 1rem !important;
    text-align: left !important;
    border: none !important;
    white-space: nowrap !important;
}

/* tbody rows */
figure.fnc-data-table table tbody tr,
.wp-block-table.fnc-data-table table tbody tr {
    border-bottom: 1px solid var(--wp--preset--color--outline-variant) !important;
    transition: background .12s !important;
}
figure.fnc-data-table table tbody tr:last-child,
.wp-block-table.fnc-data-table table tbody tr:last-child {
    border-bottom: none !important;
}
figure.fnc-data-table table tbody tr:nth-child(even),
.wp-block-table.fnc-data-table table tbody tr:nth-child(even) {
    background: var(--wp--preset--color--surface-container-low) !important;
}

/* tbody cells */
figure.fnc-data-table table tbody td,
.wp-block-table.fnc-data-table table tbody td {
    padding: 0.65rem 1rem !important;
    color: var(--wp--preset--color--on-surface-variant) !important;
    font-size: 0.9375rem !important;
    line-height: 1.55 !important;
    border: none !important;
    vertical-align: top !important;
}
figure.fnc-data-table table tbody td:first-child,
.wp-block-table.fnc-data-table table tbody td:first-child {
    color: var(--wp--preset--color--on-surface) !important;
    font-weight: 600 !important;
}

/* 캡션 단락 (article 1 — <p><strong>) → 테이블 위 */
.fnc-prose-academic .wp-block-post-content > p:has(> strong:only-child):has(+ figure.fnc-data-table),
.fnc-prose-academic .wp-block-post-content > p:has(> strong:only-child):has(+ .wp-block-table.fnc-data-table) {
    margin-bottom: 0.375rem !important;
    color: var(--wp--preset--color--on-surface) !important;
    font-weight: 700 !important;
}
.fnc-prose-academic .wp-block-post-content > p:has(> strong:only-child) + figure.fnc-data-table,
.fnc-prose-academic .wp-block-post-content > p:has(> strong:only-child) + .wp-block-table.fnc-data-table {
    margin-top: 0 !important;
}

/* ── 테이블 출처 — fnc-table-source 클래스 또는 p > small 패턴 ── */
figure.fnc-data-table:has(+ .fnc-table-source),
.wp-block-table.fnc-data-table:has(+ .fnc-table-source),
figure.fnc-data-table:has(+ p > em:only-child),
.wp-block-table.fnc-data-table:has(+ p > em:only-child),
figure.fnc-data-table:has(+ p > small),
.wp-block-table.fnc-data-table:has(+ p > small) {
    margin-bottom: 0 !important;
}

figure.fnc-data-table + p:has(> small),
.wp-block-table.fnc-data-table + p:has(> small) {
    margin-block-start: 0.375rem !important;
    margin-bottom: 2rem !important;
    padding-left: 0.125rem !important;
    font-size: 0.8125rem !important;
    line-height: 1.6 !important;
    color: #6b7280 !important;
}
.fnc-table-source {
    display: block !important;
    margin-top: 0.25rem !important;
    margin-bottom: 2rem !important;
    padding-left: 0.125rem !important;
    font-size: 0.875rem !important;
    line-height: 1.7 !important;
    color: #4b5563 !important;
    font-style: normal !important;
    font-weight: 400 !important;
    opacity: 1 !important;
    visibility: visible !important;
}
/* 마크다운 <em>-only 출처 단락도 동일 처리 */
.fnc-prose-academic .wp-block-post-content > figure.fnc-data-table + p:has(> em:only-child),
.fnc-prose-academic .wp-block-post-content > .wp-block-table.fnc-data-table + p:has(> em:only-child) {
    margin-top: 0.25rem !important;
    margin-bottom: 2rem !important;
    font-size: 0.8125rem !important;
    line-height: 1.6 !important;
    color: var(--wp--preset--color--on-surface-variant) !important;
}

/* 모바일 스크롤 */
.fnc-prose-academic .wp-block-post-content .wp-block-table {
    overflow-x: auto;
}
@media (max-width: 720px) {
    /* 모바일에서 포스트 콘텐츠 래퍼가 뷰포트를 넘어 수평 스크롤되지 않도록 */
    .fnc-prose-academic .wp-block-post-content {
        overflow-x: clip;
    }
    /* 테이블은 내부에서 가로 스크롤하되 자연 넓이 허용 — 컬럼 압축 방지 */
    .fnc-prose-academic .wp-block-post-content .wp-block-table table {
        width: auto;
        min-width: 100%;
    }
    .fnc-prose-academic .wp-block-post-content .wp-block-table th,
    .fnc-prose-academic .wp-block-post-content .wp-block-table td {
        white-space: normal;
        padding: .65rem .75rem !important;
        font-size: .88rem !important;
    }
    .fnc-prose-academic .wp-block-post-content pre,
    .fnc-prose-academic .wp-block-post-content code {
        max-width: 100%;
        overflow-x: auto;
    }
}

/* ── Footnotes ───────────────────────────────────────────────── */
.fnc-series-nav {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: .75rem 1rem;
    margin: 2.5rem 0;
    padding: 1rem 0;
    border-top: 1px solid var(--wp--preset--color--outline-variant);
    border-bottom: 1px solid var(--wp--preset--color--outline-variant);
}
.fnc-series-nav__back,
.fnc-series-nav__next {
    display: inline-flex;
    align-items: center;
    gap: .375rem;
    font-size: .9rem;
    font-weight: 500;
    color: var(--wp--preset--color--primary);
    text-decoration: none;
    transition: opacity .15s;
}
.fnc-series-nav__back:hover,
.fnc-series-nav__next:hover { opacity: .7; }
.fnc-series-nav__back .material-symbols-outlined,
.fnc-series-nav__next .material-symbols-outlined { font-size: 20px; }

.fnc-article-footnotes {
    margin-top: 6rem !important;
    padding-top: 3rem !important;
    border-top: 1px solid rgba(191,202,186,0.4);
}

/* single-wide 템플릿: fnc-prose-academic + 본문 width 통일 */
.fnc-single-wide .fnc-prose-academic {
    max-width: 860px !important;
    margin-left: auto !important;
    margin-right: auto !important;
}
/* theme.json contentSize(820px)가 wp-block-post-content를 제한하므로 해제 */
.fnc-single-wide .fnc-prose-academic .wp-block-post-content,
.fnc-single-wide .fnc-prose-academic .wp-block-post-content > * {
    max-width: 100% !important;
}
/* 타이틀 블록 좌측 고정 —
   WP constrained layout 이 h1에 max-width:820px + margin:auto!important 를 주입해
   블록 자체가 중앙으로 밀림. 이걸 해제하고 prose 영역 왼쪽 끝에 붙임. */
.fnc-single-wide .fnc-article-header .wp-block-post-title {
    max-width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    text-align: left !important;
}
/* 콘텐츠 내 kifc-essay-header 도 동일 처리 (max-width:860px;margin:0 auto 해제) */
.fnc-single-wide .kifc-essay-header {
    max-width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
}
.fnc-single-wide .fnc-article-abstract-section h2 {
    text-align: left !important;
}

/* single-wide 모바일 반응형 */
@media (max-width: 768px) {
    .fnc-single-wide .wp-block-group[style*="padding-right:var(--wp--preset--spacing--70)"] {
        padding-left: var(--wp--preset--spacing--50) !important;
        padding-right: var(--wp--preset--spacing--50) !important;
    }
    .fnc-single-wide .fnc-article-header .wp-block-post-title {
        font-size: clamp(1.5rem, 5vw, 2.25rem) !important;
    }
    .fnc-single-wide .fnc-article-meta-row {
        column-gap: 1.5rem !important;
    }
    .fnc-single-wide .fnc-article-abstract-grid {
        grid-template-columns: 1fr !important;
        gap: 0.75rem !important;
    }
    .fnc-single-wide .fnc-prose-academic {
        max-width: 100% !important;
    }
}
.fnc-article-footnotes h4 {
    font-family: var(--wp--preset--font-family--headline) !important;
    font-size: 0.7rem !important;
    font-weight: 700 !important;
    letter-spacing: 0.15em !important;
    text-transform: uppercase !important;
    color: rgba(64, 73, 61, 0.5) !important;
    margin: 0 0 2rem 0 !important;
}

/* ── Hide template chrome for posts that embed full essay HTML ──
   .kifc-essay        : 자체 header가 있어 WP 타이틀까지 모두 숨김
   .kifc-l2body-wrap  : 자체 타이틀 없음 → WP 타이틀은 유지, 나머지 chrome만 숨김
   .kifc-l2hero-wrap  : 자체 히어로(breadcrumb+타이틀+subtitle+meta) → 테마 header·breadcrumb 모두 숨김
*/
body.single-post:has(.kifc-essay) .fnc-article-header .wp-block-post-title,
body.single-post:has(.kifc-essay) .fnc-article-abstract-section,
body.single-post:has(.kifc-essay) .fnc-article-sidebar,
body.single-post:has(.kifc-l2hero-wrap) .fnc-article-header,
body.single-post:has(.kifc-l2hero-wrap) .fnc-article-breadcrumbs {
    display: none !important;
}
/* 참고문헌 footer 는 .kifc-essay 에서도 노출 — JS 가 본문의 h2/h3 '참고문헌'
   이하 요소를 이 footer 로 이동시키므로, 숨기면 참고문헌이 사라진다. */
body.single-post:has(.kifc-essay) .fnc-article-footnotes {
    display: block !important;
    max-width: 1060px;
    margin-left: auto;
    margin-right: auto;
}
/* 이동 완료 전(또는 미매칭 시)의 기본 플레이스홀더 단락은 숨겨 중복 방지 */
body.single-post:has(.kifc-essay) .fnc-article-footnotes > p:only-of-type {
    display: none;
}
/* kifc-l2body-wrap 포스트: 참고문헌 폭·정렬을 본문과 동일하게 */
body.single-post:has(.kifc-l2body-wrap) .fnc-article-footnotes > p:only-of-type {
    display: none;
}
body.single-post:has(.kifc-essay) .fnc-article-main,
body.single-post:has(.kifc-l2body-wrap) .fnc-article-main {
    grid-template-columns: 1fr !important;
}

/* L2 body 글: 헤더-본문 사이 간격 압축 */
body.single-post:has(.kifc-l2body-wrap) .fnc-article-header {
    padding: 1rem 0 0.5rem 0 !important;
}
body.single-post:has(.kifc-l2body-wrap) main > .wp-block-group:nth-of-type(3) {
    padding-top: 0 !important;
}
body.single-post:has(.kifc-l2body-wrap) .fnc-prose-academic { padding-top: 0 !important; }
body.single-post:has(.kifc-l2body-wrap) .kifc-l2body-wrap { padding-top: 1.5rem !important; }
body.single-post:has(.kifc-l2body-wrap) .kifc-l2body-inner { max-width: 100% !important; }
body.single-post:has(.kifc-l2body-wrap) .kifc-l2body-wrap { padding-left: 0 !important; padding-right: 0 !important; }

/* L2 hero가 있을 때: 첫 컨테이너(breadcrumb+header 영역)의 상·하 패딩 제거 */
body.single-post:has(.kifc-l2hero-wrap) main > .wp-block-group:nth-of-type(1) {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
}
body.single-post:has(.kifc-l2hero-wrap) .kifc-l2hero-wrap {
    max-width: 1060px !important;
    margin: 0 auto !important;
}
/* L2 글 상단 featured image 는 원본 3:2 비율이 너무 길어서 2/3 로 크롭 → 9:4 */
body.single-post:has(.kifc-l2hero-wrap) .wp-block-post-featured-image {

/* ─── Article Body Components (callouts·tables·tags·quadrant) ─── */
/* ── Article callouts (본문 내 강조 박스) ────────────────────
 * 타임라인·평가 매트릭스 등 본문 시각화를 블록으로 감싼다.
 * `.fnc-article-callout` 는 figure 태그 전제. 내부는 semantic HTML. */
.fnc-article-callout {
    margin: 2.5rem 0 !important;
    padding: 1.75rem 1.75rem 1.5rem;
    background: var(--wp--preset--color--surface-container-low);
    border: 1px solid var(--wp--preset--color--outline-variant);
    border-radius: 0.75rem;
}
.fnc-article-callout--wide {
    padding: 2rem;
}
.fnc-article-callout--info {
    background: linear-gradient(90deg, rgba(203, 255, 194, 0.28) 0%, var(--wp--preset--color--surface-container-low) 100%);
    border-color: rgba(13, 99, 27, 0.22);
    border-left: 4px solid var(--wp--preset--color--primary);
}
.fnc-article-callout--info .fnc-pill {
    background: var(--wp--preset--color--primary-container);
    color: var(--wp--preset--color--on-primary);
}
.fnc-article-callout--info .fnc-callout-title {
    color: var(--wp--preset--color--primary);
}
.fnc-article-callout--info p {
    font-size: 0.9375rem !important;
    line-height: 1.7 !important;
    margin: 0 0 0.75rem 0 !important;
    color: var(--wp--preset--color--on-surface);
}
.fnc-article-callout--info p:last-child { margin-bottom: 0 !important; }
.fnc-article-callout--info strong {
    color: var(--wp--preset--color--primary);
    font-weight: 700;
}
.fnc-callout-header {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    margin-bottom: 1.25rem;
}
.fnc-callout-title {
    font-family: var(--wp--preset--font-family--headline);
    font-size: 1rem !important;
    font-weight: 700 !important;
    color: var(--wp--preset--color--on-surface);
    margin: 0 !important;
    letter-spacing: -0.01em;
}
.fnc-callout-meta {
    display: block;
    margin-top: 1rem;
    padding-top: 0.75rem;
    border-top: 1px solid var(--wp--preset--color--outline-variant);
    font-family: var(--wp--preset--font-family--label);
    font-size: 0.75rem;
    color: var(--wp--preset--color--on-surface-variant);
    line-height: 1.5;
}

.fnc-timeline-compact {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}
.fnc-timeline-compact > li {
    display: grid;
    grid-template-columns: 90px 1fr;
    gap: 1rem;
    padding: 0.5rem 0;
    border-bottom: 1px dashed var(--wp--preset--color--outline-variant);
    font-size: 0.9375rem;
    line-height: 1.5;
}
.fnc-timeline-compact > li:last-child { border-bottom: 0; }
.fnc-timeline-compact .fnc-when {
    font-family: var(--wp--preset--font-family--label);
    font-weight: 700;
    font-size: 0.8125rem;
    color: var(--wp--preset--color--primary);
    letter-spacing: 0.02em;
}
.fnc-timeline-compact .fnc-what {
    color: var(--wp--preset--color--on-surface);
}
@media (max-width: 560px) {
    .fnc-timeline-compact > li {
        grid-template-columns: 70px 1fr;
        gap: 0.75rem;
    }
}

.fnc-eval-table {
    width: 100%;
    border-collapse: collapse;
    margin: 0.25rem 0 !important;
    font-size: 0.875rem;
    background: var(--wp--preset--color--surface-container-lowest);
    border-radius: 0.5rem;
    overflow: hidden;
}
.fnc-eval-table thead {
    background: var(--wp--preset--color--surface-container);
}
.fnc-eval-table th {
    font-family: var(--wp--preset--font-family--label);
    font-weight: 700;
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--wp--preset--color--on-surface-variant);
    padding: 0.625rem 0.875rem;
    text-align: left;
    border-bottom: 1px solid var(--wp--preset--color--outline-variant);
}
.fnc-eval-table td {
    padding: 0.625rem 0.875rem;
    border-bottom: 1px solid var(--wp--preset--color--outline-variant);
    color: var(--wp--preset--color--on-surface);
    vertical-align: middle;
}
.fnc-eval-table tbody tr:last-child td { border-bottom: 0; }
.fnc-eval-table tbody tr:hover { background: var(--wp--preset--color--surface-container-low); }
.fnc-eval-table td:first-child {
    font-weight: 600;
    font-size: 0.9rem;
}

.fnc-tag {
    display: inline-flex;
    align-items: center;
    padding: 0.15rem 0.55rem;
    border-radius: 9999px;
    font-family: var(--wp--preset--font-family--label);
    font-size: 0.75rem;
    font-weight: 600;
    letter-spacing: 0.01em;
    background: var(--wp--preset--color--surface-container-high);
    color: var(--wp--preset--color--on-surface-variant);
    white-space: nowrap;
}
.fnc-tag--good {
    background: rgba(159, 239, 213, 0.55);
    color: #0d4d2a;
}
.fnc-tag--warn {
    background: rgba(200, 168, 124, 0.28);
    color: #6b3f1c;
}
.fnc-tag--neutral {
    background: transparent;
    color: var(--wp--preset--color--outline);
    border: 1px dashed var(--wp--preset--color--outline-variant);
}
@media (max-width: 640px) {
    .fnc-eval-table { font-size: 0.8125rem; }
    .fnc-eval-table th, .fnc-eval-table td { padding: 0.5rem 0.625rem; }
    .fnc-tag { font-size: 0.6875rem; padding: 0.125rem 0.5rem; }
}

.fnc-quadrant {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.75rem;
}
.fnc-quadrant-cell {
    background: var(--wp--preset--color--surface-container-lowest);
    border: 1px solid var(--wp--preset--color--outline-variant);
    border-radius: 0.625rem;
    padding: 1rem 1.125rem;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}
.fnc-quadrant-cell--good {
    background: rgba(159, 239, 213, 0.35);
    border-color: rgba(13, 99, 27, 0.25);
}
.fnc-quadrant-cell--warn {
    background: rgba(200, 168, 124, 0.18);
    border-color: rgba(178, 58, 58, 0.25);
}
.fnc-quadrant-label {
    font-family: var(--wp--preset--font-family--label);
    font-size: 0.6875rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--wp--preset--color--on-surface-variant);
}
.fnc-quadrant-cell ul {
    list-style: disc !important;
    margin: 0 !important;
    padding-left: 1.125rem !important;
    font-size: 0.875rem;
    line-height: 1.55;
    color: var(--wp--preset--color--on-surface);
}
.fnc-quadrant-cell ul li {
    margin-bottom: 0.25rem !important;
}
@media (max-width: 640px) {
    .fnc-quadrant { grid-template-columns: 1fr; }
}

/* ═══════════════════════════════════════════════════════════
   정책 제안 페이지 — .pp-page (scoped)
   ═══════════════════════════════════════════════════════════ */
.pp-page {
  --pp-primary:    #006565;
  --pp-primary-dk: #004f4f;
  --pp-primary-md: #008080;
