/* Extracted from lib/college-creator/generic-renderer.js.
   Keep selectors scoped to .cnf-* / .cnf-shell so this global stylesheet stays safe in Pages Router. */

        .cnf-mqd {
          --mqd-serif: "Iowan Old Style", "Palatino Linotype", Palatino, "Book Antiqua", Georgia, serif;
          --mqd-mono: ui-monospace, "SF Mono", SFMono-Regular, Menlo, Consolas, "Liberation Mono", monospace;
        }
        .cnf-mqd-wrap {
          max-width: 880px;
          margin: 0 auto;
          padding: 26px 18px 96px;
        }
        .cnf-mqd .cnf-crumbs { margin: 0 0 16px; }
        .cnf-mqd .cnf-crumbs a {
          color: inherit;
          text-decoration: none;
          min-height: 44px;
          display: inline-flex;
          align-items: center;
        }
        .cnf-mqd .cnf-crumbs span[aria-hidden] { opacity: 0.5; }
        .cnf-mqd .cnf-crumbs [aria-current] { color: var(--cnf-ink-mid); }

        /* - dossier head sheet - */
        .cnf-mqd-sheet {
          position: relative;
          background: var(--cnf-card);
          border: 1px solid var(--cnf-rule-strong);
          border-top: 3px double var(--cnf-primary);
          border-radius: 14px;
          box-shadow: var(--cnf-shadow);
          padding: 0 22px 22px;
          margin-bottom: 22px;
          overflow: hidden;
        }
        .cnf-mqd-ref {
          display: flex;
          justify-content: space-between;
          gap: 12px;
          margin: 0 -22px 18px;
          padding: 9px 22px;
          font-family: var(--mqd-mono);
          font-size: 10.5px;
          letter-spacing: 0.14em;
          text-transform: uppercase;
          color: var(--cnf-ink-soft);
          border-bottom: 1px solid var(--cnf-rule);
          background:
            repeating-linear-gradient(0deg, transparent 0 3px, rgba(22, 20, 14, 0.015) 3px 4px),
            var(--cnf-bg);
        }
        .cnf-mqd-sheet h1 {
          margin: 0 0 10px;
          font-family: var(--mqd-serif);
          font-weight: 600;
          font-size: clamp(32px, 5.6vw, 52px);
          line-height: 1.02;
          letter-spacing: -0.01em;
          color: var(--cnf-ink);
          text-wrap: balance;
        }
        .cnf-mqd-dateline {
          display: flex;
          flex-wrap: wrap;
          gap: 6px 0;
          margin: 0 0 14px;
          font-family: var(--mqd-mono);
          font-size: 11px;
          letter-spacing: 0.08em;
          text-transform: uppercase;
          color: var(--cnf-ink-soft);
        }
        .cnf-mqd-dateline span + span::before { content: "·"; margin: 0 8px; opacity: 0.5; }
        .cnf-mqd-lead {
          margin: 0;
          max-width: 720px;
          color: var(--cnf-ink-mid);
          font-size: 16px;
          line-height: 1.65;
        }
        .cnf-mqd-answer {
          display: flex;
          align-items: center;
          justify-content: space-between;
          gap: 18px;
          margin: 18px 0 4px;
          padding: 16px 18px;
          border: 1px solid var(--cnf-rule);
          border-left: 3px solid var(--cnf-primary);
          border-radius: 10px;
          background: var(--cnf-primary-soft);
        }
        .cnf-mqd-figure-num {
          display: block;
          font-family: var(--mqd-serif);
          font-variant-numeric: tabular-nums lining-nums;
          font-weight: 700;
          font-size: clamp(30px, 6vw, 44px);
          line-height: 1;
          color: var(--cnf-primary-deep);
        }
        .cnf-mqd-figure-unit {
          display: block;
          margin-top: 6px;
          font-size: 12.5px;
          font-weight: 700;
          color: var(--cnf-ink-mid);
        }
        .cnf-mqd-stamp {
          flex: none;
          padding: 9px 14px;
          border: 1.5px solid var(--cnf-gold);
          border-radius: 6px;
          transform: rotate(-2deg);
          font-family: var(--mqd-mono);
          font-size: 10.5px;
          font-weight: 700;
          letter-spacing: 0.16em;
          line-height: 1.5;
          text-align: center;
          text-transform: uppercase;
          color: var(--cnf-gold-text);
          background: var(--cnf-gold-soft);
        }
        .cnf-mqd-meta {
          display: flex;
          flex-wrap: wrap;
          gap: 8px;
          margin-top: 16px;
        }
        .cnf-mqd-meta a {
          min-height: 36px;
          display: inline-flex;
          align-items: center;
          gap: 6px;
          padding: 7px 12px;
          border-radius: 999px;
          border: 1px solid var(--cnf-rule);
          background: #fff;
          color: var(--cnf-primary);
          font-size: 12px;
          font-weight: 700;
          text-decoration: none;
        }
        .cnf-mqd-meta .cnf-mqd-wa {
          background: var(--cnf-primary);
          border-color: var(--cnf-primary);
          color: #fff;
        }
        .cnf-mqd-toc {
          list-style: none;
          display: flex;
          flex-wrap: wrap;
          gap: 6px;
          margin: 18px -22px -22px;
          padding: 12px 22px 14px;
          border-top: 1px solid var(--cnf-rule);
          background: var(--cnf-bg);
        }
        @media (max-width: 640px) {
          .cnf-mqd-toc { flex-wrap: nowrap; overflow-x: auto; }
        }
        .cnf-mqd-toc a {
          white-space: nowrap;
          display: inline-flex;
          align-items: center;
          gap: 7px;
          min-height: 36px;
          padding: 6px 12px;
          border-radius: 8px;
          border: 1px solid var(--cnf-rule);
          background: #fff;
          color: var(--cnf-ink-mid);
          font-size: 12.5px;
          font-weight: 700;
          text-decoration: none;
        }
        .cnf-mqd-toc a span {
          font-family: var(--mqd-mono);
          font-size: 10px;
          color: var(--cnf-gold-text);
        }

        /* - numbered document headings - */
        .cnf-mqd-head { margin-bottom: 14px; }
        .cnf-mqd-head-num {
          display: block;
          font-family: var(--mqd-mono);
          font-size: 11px;
          letter-spacing: 0.18em;
          text-transform: uppercase;
          color: var(--cnf-gold-text);
          margin-bottom: 6px;
        }
        .cnf-mqd-head-title {
          margin: 0;
          font-family: var(--mqd-serif);
          font-weight: 600;
          font-size: clamp(21px, 3.4vw, 27px);
          line-height: 1.15;
          color: var(--cnf-ink);
          padding-bottom: 10px;
          border-bottom: 1px solid var(--cnf-rule-strong);
        }
        .cnf-mqd-head-sub {
          margin: 10px 0 0;
          font-size: 13.5px;
          line-height: 1.6;
          color: var(--cnf-ink-soft);
          max-width: 660px;
        }
        .cnf-mqd-card { margin-bottom: 18px; }

        /* - ledger tables - */
        .cnf-mqd-tablewrap { overflow-x: auto; }
        .cnf-mqd-table {
          width: 100%;
          border-collapse: collapse;
          font-size: 14px;
        }
        .cnf-mqd-table th, .cnf-mqd-table td {
          text-align: left;
          padding: 9px 10px 9px 0;
          border-bottom: 1px solid var(--cnf-rule);
          vertical-align: top;
        }
        .cnf-mqd-table thead th {
          font-family: var(--mqd-mono);
          font-size: 10.5px;
          font-weight: 700;
          letter-spacing: 0.1em;
          text-transform: uppercase;
          color: var(--cnf-ink-soft);
        }
        .cnf-mqd-table tbody th { font-weight: 600; color: var(--cnf-ink); }
        .cnf-mqd-num {
          text-align: right !important;
          font-family: var(--mqd-mono);
          font-variant-numeric: tabular-nums;
          color: var(--cnf-ink-mid);
        }
        .cnf-mqd-rownote {
          display: block;
          font-size: 11.5px;
          font-weight: 500;
          color: var(--cnf-ink-soft);
          margin-top: 2px;
        }
        .cnf-mqd-srcline {
          margin: 12px 0 0;
          font-size: 12.5px;
          color: var(--cnf-ink-soft);
        }

        /* - process steps - */
        .cnf-mqd-steps {
          list-style: none;
          margin: 0;
          padding: 0;
        }
        .cnf-mqd-steps li {
          display: flex;
          gap: 14px;
          padding: 12px 0;
          border-bottom: 1px solid var(--cnf-rule);
        }
        .cnf-mqd-steps li:last-child { border-bottom: 0; }
        .cnf-mqd-step-num {
          flex: none;
          font-family: var(--mqd-mono);
          font-size: 12px;
          font-weight: 700;
          color: var(--cnf-primary);
          padding-top: 2px;
        }
        .cnf-mqd-steps strong { font-size: 15px; color: var(--cnf-ink); }
        .cnf-mqd-steps p {
          margin: 4px 0 0;
          font-size: 14px;
          line-height: 1.6;
          color: var(--cnf-ink-mid);
        }
        .cnf-mqd-contact { margin: 14px 0 0; font-size: 14px; color: var(--cnf-ink-mid); }
        .cnf-mqd-caution {
          margin-top: 16px;
          padding: 14px 16px;
          border-left: 3px solid var(--cnf-warn);
          border-radius: 8px;
          background: var(--cnf-warn-soft);
          font-size: 13.5px;
        }
        .cnf-mqd-caution strong {
          display: block;
          font-family: var(--mqd-mono);
          font-size: 11px;
          letter-spacing: 0.12em;
          text-transform: uppercase;
          color: var(--cnf-warn);
          margin-bottom: 6px;
        }
        .cnf-mqd-caution ul { margin: 0; padding-left: 18px; }
        .cnf-mqd-caution li { margin: 3px 0; line-height: 1.55; }
        .cnf-mqd-docs { margin-top: 16px; font-size: 13.5px; }
        .cnf-mqd-docs strong {
          display: block;
          font-family: var(--mqd-mono);
          font-size: 11px;
          letter-spacing: 0.12em;
          text-transform: uppercase;
          color: var(--cnf-ink-soft);
          margin-bottom: 8px;
        }
        .cnf-mqd-docs ul {
          list-style: none;
          margin: 0;
          padding: 0;
          display: flex;
          flex-wrap: wrap;
          gap: 6px;
        }
        .cnf-mqd-docs li {
          padding: 5px 11px;
          border: 1px solid var(--cnf-rule);
          border-radius: 999px;
          background: var(--cnf-bg);
          font-size: 12.5px;
          font-weight: 600;
          color: var(--cnf-ink-mid);
        }

        /* - auditor's note (reconciliation) - */
        .cnf-mqd-recon-note {
          padding: 16px 18px;
          border-left: 3px solid var(--cnf-copper);
          border-radius: 8px;
          background: var(--cnf-gold-soft);
        }
        .cnf-mqd-recon-note p {
          margin: 0 0 12px;
          font-size: 14.5px;
          line-height: 1.7;
          color: var(--cnf-ink-mid);
        }
        .cnf-mqd-recon-note p:last-child { margin-bottom: 0; }
        .cnf-mqd-recon-note p:first-child {
          font-family: var(--mqd-serif);
          font-style: italic;
          font-size: 16.5px;
          color: var(--cnf-ink);
        }

        /* - FAQs - */
        .cnf-mqd-faqs details { border-bottom: 1px solid var(--cnf-rule); }
        .cnf-mqd-faqs summary {
          cursor: pointer;
          list-style: none;
          display: flex;
          justify-content: space-between;
          align-items: center;
          gap: 14px;
          min-height: 44px;
          padding: 12px 0;
          font-family: var(--mqd-serif);
          font-weight: 600;
          font-size: 16px;
          color: var(--cnf-ink);
        }
        .cnf-mqd-faqs summary::-webkit-details-marker { display: none; }
        .cnf-mqd-faqs summary::after {
          content: "+";
          flex: none;
          font-family: var(--mqd-mono);
          font-size: 16px;
          color: var(--cnf-gold-text);
          transition: transform 0.18s ease;
        }
        .cnf-mqd-faqs details[open] summary::after { transform: rotate(45deg); }
        .cnf-mqd-faqs details p {
          margin: 0 0 14px;
          font-size: 14px;
          line-height: 1.65;
          color: var(--cnf-ink-mid);
          max-width: 700px;
        }

        /* - evidence list - */
        .cnf-mqd-evidence {
          list-style: none;
          margin: 0;
          padding: 0;
        }
        .cnf-mqd-evidence li {
          display: flex;
          gap: 12px;
          padding: 11px 0;
          border-bottom: 1px solid var(--cnf-rule);
          align-items: baseline;
        }
        .cnf-mqd-evidence li:last-child { border-bottom: 0; }
        .cnf-mqd-filetag {
          flex: none;
          font-family: var(--mqd-mono);
          font-size: 10px;
          font-weight: 700;
          letter-spacing: 0.1em;
          padding: 3px 7px;
          border: 1px solid var(--cnf-rule-strong);
          border-radius: 4px;
          color: var(--cnf-ink-soft);
          background: var(--cnf-bg);
        }
        .cnf-mqd-evidence a {
          font-weight: 700;
          font-size: 14px;
          color: var(--cnf-primary);
          text-decoration: none;
        }
        .cnf-mqd-evidence a:hover { text-decoration: underline; }
        .cnf-mqd-evidence-meta {
          display: block;
          font-size: 12px;
          color: var(--cnf-ink-soft);
          margin-top: 2px;
        }

        .cnf-mqd .cnf-src, .cnf-mqd .cnf-review { margin-top: 18px; }

        /* - load reveal, motion-safe only - */
        @media (prefers-reduced-motion: no-preference) {
          .cnf-mqd-sheet h1,
          .cnf-mqd-dateline,
          .cnf-mqd-lead,
          .cnf-mqd-answer,
          .cnf-mqd-meta,
          .cnf-mqd-toc {
            animation: cnfMqdRise 0.5s cubic-bezier(0.2, 0.7, 0.3, 1) both;
          }
          .cnf-mqd-dateline { animation-delay: 0.05s; }
          .cnf-mqd-lead { animation-delay: 0.1s; }
          .cnf-mqd-answer { animation-delay: 0.16s; }
          .cnf-mqd-meta { animation-delay: 0.22s; }
          .cnf-mqd-toc { animation-delay: 0.28s; }
          @keyframes cnfMqdRise {
            from { opacity: 0; transform: translateY(10px); }
            to { opacity: 1; transform: none; }
          }
        }
        @media (max-width: 640px) {
          .cnf-mqd-wrap { padding-inline: 12px; }
          .cnf-mqd-sheet { padding: 0 16px 16px; border-radius: 12px; }
          .cnf-mqd-ref { margin: 0 -16px 14px; padding: 8px 16px; }
          .cnf-mqd-toc { margin: 16px -16px -16px; padding: 10px 16px 12px; }
          .cnf-mqd-answer { flex-direction: column; align-items: flex-start; gap: 12px; }
          .cnf-mqd-stamp { transform: rotate(-1.2deg); }
        }
        @media print {
          .cnf-mqd-meta .cnf-mqd-wa, .cnf-mqd-toc { display: none; }
        }


        .cnf-defunct-wrap { max-width: 760px; margin: 0 auto; padding: 56px 24px 120px; }
        .cnf-defunct-alt { display: inline-block; font-weight: 600; color: var(--cnf-primary); }
        .cnf-defunct-alternatives { margin: 22px 0 0; padding: 18px 0 2px; border-top: 1px solid rgba(14, 92, 61, 0.18); }
        .cnf-defunct-alternatives h2 { margin: 0 0 12px; font-size: 18px; line-height: 1.25; color: var(--cnf-ink); }
        .cnf-defunct-alternatives ul { display: grid; gap: 10px; margin: 0; padding: 0; list-style: none; }
        .cnf-defunct-alternatives li { display: flex; align-items: center; justify-content: space-between; gap: 14px; padding: 12px 0; border-bottom: 1px solid rgba(22, 20, 14, 0.08); }
        .cnf-defunct-alternatives a { min-height: 44px; display: inline-flex; align-items: center; color: var(--cnf-primary); font-weight: 700; text-decoration: none; }
        .cnf-defunct-alternatives a:hover { text-decoration: underline; }
        .cnf-defunct-alternatives span { flex: 0 0 auto; color: var(--cnf-ink-soft); font-size: 13px; }
        @media (max-width: 560px) {
          .cnf-defunct-alternatives li { align-items: flex-start; flex-direction: column; gap: 2px; }
        }


      .cnf-shell {
        /* Keep the current Supabase-backed renderer and layout, but inherit the
           PR #103 Manrope typography and the current cream-green-gold palette. */
        --cnf-sans: var(--font-manrope, 'Manrope'), system-ui, -apple-system, sans-serif;
        --cnf-serif: var(--font-manrope, 'Manrope'), system-ui, -apple-system, sans-serif;
        --cnf-mono: var(--font-manrope, 'Manrope'), system-ui, -apple-system, sans-serif;
        --cnf-bg: #F4F1EC;
        --cnf-bg-soft: #EBE7DD;
        --cnf-bg-deep: #E0DAC9;
        --cnf-card: #fff;
        --cnf-ink: #16140E;
        --cnf-ink-soft: #5E574A;
        --cnf-ink-mid: #3B3528;
        --cnf-primary: #0E5C3D;
        --cnf-primary-soft: #D9EBE0;
        --cnf-primary-deep: #062F1F;
        --cnf-primary-glow: #3FBE85;
        --cnf-warn: #C5421A;
        --cnf-warn-soft: #FDE5DA;
        --cnf-gold: #B8843A;
        --cnf-gold-soft: #F9EAD2;
        --cnf-gold-text: #8A5A1C;
        --cnf-copper: #7D3A1A;
        --cnf-rule: rgba(22,20,14,0.08);
        --cnf-rule-strong: rgba(22,20,14,0.16);
        --cnf-shadow: 0 1px 3px rgba(22,20,14,0.06), 0 8px 28px -8px rgba(22,20,14,0.08);
        /* Real rendered height of the section-nav topbar (title row + pill
           nav + paddings + border). Was an inflated 108px; trimmed to the
           measured desktop height. Mobile overrides this below. Used by
           scroll-margin-top, sticky rail top, and rail max-height. */
        --cnf-topbar-h: 94px;
        /* Site header sits above the creator topbar in the sticky stack:
           utility row (~24px) + .header-inner (68px) + borders on desktop;
           drops to 60px on mobile (utility row hidden, see media query). */
        --cnf-site-header-h: 99px;
        background: var(--cnf-bg);
        color: var(--cnf-ink);
        font-family: var(--cnf-sans);
        font-size: 16px;
        line-height: 1.55;
        -webkit-font-smoothing: antialiased;
        min-height: 100vh;
        padding-bottom: 96px;
      }
      .cnf-shell * { box-sizing: border-box; }
      .cnf-shell a { color: inherit; text-decoration: none; }
      /* Headings stay bold under the restored navy/gold system. This selector
         beats the per-class weight:500 rules (0,1,0). */
      .cnf-shell h1, .cnf-shell h2, .cnf-shell h3, .cnf-shell h4 { font-weight: 800; letter-spacing: -0.02em; }
      /* The brand CTAs need white ink on their green fill; scope to .cnf-shell a
         so this beats the reset (0,2,1 > 0,1,1) WITHOUT inflating the reset's
         own specificity (which would otherwise override the .cnf-pill.is-cta /
         .cnf-rail-link.is-cta gold-text rules at 0,2,0). */
      .cnf-shell a.cnf-cta-wa, .cnf-shell a.cnf-mq-cta-btn, .cnf-shell a.cnf-mq-answer-cta { color: #fff; }
      /* Source-citation links must read in brand green, not the dark-ink reset.
         Scope to .cnf-shell a.cnf-cite (0,2,1) so this beats the .cnf-shell a
         reset (0,1,1) - the bare .cnf-cite rule (0,1,0) is otherwise overridden. */
      .cnf-shell a.cnf-cite { color: var(--cnf-primary); }
      .cnf-shell h1, .cnf-shell h2, .cnf-shell h3, .cnf-shell h4 { margin: 0; }
      .cnf-shell ul, .cnf-shell ol { margin: 0; padding: 0; list-style: none; }
      .cnf-shell code { font-family: var(--cnf-mono); font-size: 0.92em; }
      /* Anchor landing offset budgets for the full revealed stack (site header
         + section-nav topbar). The topbar auto-hides on scroll-down but is
         force-revealed on nav click (see useScrollSpy onNavClick), so a clicked
         or deep-linked section always lands under a present topbar. */
      .cnf-shell section[data-cnf-section] { scroll-margin-top: calc(var(--cnf-site-header-h) + var(--cnf-topbar-h) + 8px); }

      /* Topbar (mobile + cross-desktop pill nav).
         Stacked below the site header so the two don't collide at top:0. */
      .cnf-topbar {
        position: sticky;
        top: var(--cnf-site-header-h);
        z-index: 30;
        background: rgba(244,241,236,0.9);
        backdrop-filter: blur(16px) saturate(180%);
        -webkit-backdrop-filter: blur(16px) saturate(180%);
        border-bottom: 1px solid var(--cnf-rule);
        padding: 10px 24px 0;
        /* Auto-hide on scroll-down (class toggled in useScrollSpy). Slides up
           under the still-sticky site header; will-change keeps it smooth on
           low-end Android. */
        transition: transform 0.26s ease, opacity 0.2s ease;
        will-change: transform;
      }
      .cnf-topbar--hidden {
        transform: translateY(-130%);
        opacity: 0;
        pointer-events: none;
      }
      /* Keyboard a11y: if a section-nav pill is focused while the bar is
         auto-hidden, reveal it so focus is never on an off-screen control.
         :focus-within (0,2,0) beats .cnf-topbar--hidden (0,1,0). */
      .cnf-topbar:focus-within {
        transform: none; opacity: 1; pointer-events: auto;
      }
      .cnf-topbar-row {
        display: flex; justify-content: space-between; align-items: baseline;
        gap: 16px; margin-bottom: 8px; min-height: 26px;
      }
      .cnf-topbar-title { display: flex; align-items: baseline; gap: 10px; min-width: 0; }
      .cnf-topbar-short {
        font-family: var(--cnf-serif); font-weight: 500; font-size: 18px;
        font-variation-settings: "opsz" 24; color: var(--cnf-ink);
        white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
      }
      .cnf-topbar-meta {
        font-family: var(--cnf-mono); font-size: 11px; color: var(--cnf-ink-soft);
        letter-spacing: 0.04em; white-space: nowrap;
      }
      .cnf-topbar-meta-right {
        font-family: var(--cnf-mono); font-size: 10.5px; color: var(--cnf-ink-soft);
        letter-spacing: 0.06em; text-transform: uppercase; white-space: nowrap;
      }
      .cnf-topbar-verified { color: var(--cnf-primary); font-weight: 600; }
      .cnf-pillnav {
        display: flex; gap: 6px; padding: 0 0 10px;
        overflow-x: auto; scrollbar-width: none;
        margin: 0 -24px; padding-left: 24px; padding-right: 24px;
      }
      .cnf-pillnav::-webkit-scrollbar { display: none; }
      .cnf-pill {
        padding: 7px 13px;
        background: var(--cnf-card); border-radius: 999px;
        font-size: 12.5px; font-weight: 600; color: var(--cnf-ink-mid);
        white-space: nowrap; flex-shrink: 0;
        box-shadow: 0 1px 2px rgba(0,0,0,0.16);
        border: 1px solid var(--cnf-rule);
        transition: all 0.15s;
      }
      .cnf-pill.is-active { background: var(--cnf-primary); color: var(--cnf-bg); border-color: var(--cnf-primary); }
      .cnf-pill.is-cta { background: var(--cnf-gold-soft); color: var(--cnf-gold-text); border-color: var(--cnf-gold-soft); }
      .cnf-pill.is-cta.is-active { background: var(--cnf-gold-text); color: var(--cnf-bg); border-color: var(--cnf-gold-text); }

      /* Layout grid - scales with viewport up to 2200px; rails and gap grow at wider viewports */
      .cnf-layout {
        max-width: min(2200px, calc(100vw - 64px));
        margin: 0 auto;
        padding: 24px 0 80px;
        display: grid;
        grid-template-columns: 260px minmax(0, 1fr) 360px;
        gap: 40px;
        align-items: flex-start;
      }
      .cnf-main { display: flex; flex-direction: column; gap: 22px; min-width: 0; }
      .cnf-crumbs {
        margin: 4px 0 12px;
        font-size: 12.5px;
        color: var(--cnf-ink-soft);
        display: flex;
        flex-wrap: wrap;
        align-items: center;
        gap: 7px;
      }
      /* Topbar lives inside .cnf-shell, NOT .cnf-layout. Keep its container
         centered to the same max-width so pill nav aligns with content. */
      .cnf-topbar > * {
        max-width: min(2200px, calc(100vw - 64px));
        margin-left: auto; margin-right: auto;
      }

      /* Left rail - sits below site header + topbar. */
      .cnf-leftrail {
        position: sticky;
        top: calc(var(--cnf-site-header-h) + var(--cnf-topbar-h) - 4px);
        max-height: calc(100vh - var(--cnf-site-header-h) - var(--cnf-topbar-h) - 24px);
        overflow-y: auto; padding-bottom: 24px;
        scrollbar-width: thin;
        min-width: 0;
      }
      .cnf-leftrail::-webkit-scrollbar { width: 4px; }
      .cnf-leftrail::-webkit-scrollbar-thumb { background: var(--cnf-rule); border-radius: 2px; }
      .cnf-leftrail-label {
        font-family: var(--cnf-mono); font-size: 10px; letter-spacing: 0.14em;
        text-transform: uppercase; color: var(--cnf-ink-soft); font-weight: 700;
        margin: 6px 0 10px;
      }
      .cnf-leftrail nav { display: flex; flex-direction: column; gap: 1px; margin-bottom: 24px; }
      .cnf-rail-link {
        padding: 9px 14px; font-size: 13.5px; color: var(--cnf-ink-mid);
        border-radius: 8px; transition: all 0.12s;
        display: flex; justify-content: space-between; align-items: center;
        font-weight: 500;
      }
      .cnf-rail-link:hover { background: var(--cnf-bg-soft); color: var(--cnf-ink); }
      .cnf-rail-link.is-active { background: var(--cnf-ink); color: var(--cnf-bg); font-weight: 600; }
      .cnf-rail-link.is-cta { background: var(--cnf-gold-soft); color: var(--cnf-gold-text); font-weight: 700; }
      .cnf-rail-link.is-cta:hover { background: var(--cnf-gold-text); color: var(--cnf-bg); }
      .cnf-rail-pip { font-family: var(--cnf-mono); font-size: 10px; opacity: 1; color: var(--cnf-ink-soft); }
      .cnf-rail-link.is-active .cnf-rail-pip { color: var(--cnf-bg); opacity: 0.85; }
      .cnf-leftrail-meta {
        padding: 16px 14px; background: var(--cnf-card);
        border-radius: 14px; border: 1px solid var(--cnf-rule);
      }
      .cnf-leftrail-meta-h {
        font-family: var(--cnf-mono); font-size: 10px; letter-spacing: 0.12em;
        text-transform: uppercase; color: var(--cnf-primary); font-weight: 700;
        margin-bottom: 8px;
      }
      .cnf-leftrail-meta-v {
        font-family: var(--cnf-serif); font-size: 14px; line-height: 1.4; color: var(--cnf-ink-mid);
      }

      /* Right rail - sits below site header + topbar. */
      .cnf-rightrail {
        position: sticky;
        top: calc(var(--cnf-site-header-h) + var(--cnf-topbar-h) - 4px);
        max-height: calc(100vh - var(--cnf-site-header-h) - var(--cnf-topbar-h) - 24px);
        overflow-y: auto; padding-bottom: 24px;
      }
      .cnf-cta-card {
        background: var(--cnf-card); border-radius: 18px; padding: 22px;
        box-shadow: var(--cnf-shadow); border: 1px solid var(--cnf-rule);
      }
      .cnf-cta-title {
        font-family: var(--cnf-serif); font-size: 18px; font-weight: 500;
        line-height: 1.2; color: var(--cnf-ink); margin-bottom: 8px;
        font-variation-settings: "opsz" 24;
      }
      .cnf-cta-title em { font-style: italic; color: var(--cnf-primary); }
      .cnf-cta-card p { font-size: 13px; color: var(--cnf-ink-soft); line-height: 1.5; margin: 0 0 16px; }
      .cnf-cta-wa, .cnf-cta-save {
        display: flex; align-items: center; justify-content: center; gap: 8px;
        width: 100%; padding: 13px;
        border-radius: 12px; font-size: 14px; font-weight: 600; margin-bottom: 8px;
        transition: all 0.12s;
      }
      .cnf-cta-wa {
        background: #0E7A3B; color: #fff; padding: 15px; font-weight: 700;
        box-shadow: 0 4px 14px -4px rgba(14,122,59,0.4);
      }
      .cnf-cta-wa:hover { background: #075F30; }
      .cnf-cta-wa:focus-visible,
      .cnf-actbar a:focus-visible,
      .cnf-mq-cta-btn:focus-visible,
      .cnf-mq-answer-cta:focus-visible,
      .cnf-mq-na-cta-btn:focus-visible {
        outline: 3px solid var(--cnf-primary);
        outline-offset: 3px;
      }
      .cnf-cta-save {
        background: transparent; border: 1px solid var(--cnf-rule-strong);
        color: var(--cnf-ink-mid); padding: 11px; font-size: 13px;
      }
      .cnf-cta-save:hover { border-color: var(--cnf-ink); color: var(--cnf-ink); }
      .cnf-cta-meta {
        padding: 16px 22px; background: var(--cnf-bg-soft);
        border-radius: 14px; margin-top: 14px;
      }
      .cnf-cta-meta-h {
        font-family: var(--cnf-mono); font-size: 10px; letter-spacing: 0.12em;
        text-transform: uppercase; color: var(--cnf-primary); font-weight: 700;
        margin-bottom: 6px;
      }
      .cnf-cta-meta-row {
        display: flex; gap: 10px; align-items: center;
        padding: 6px 0; font-size: 12.5px; color: var(--cnf-ink-mid); line-height: 1.4;
      }
      .cnf-cta-meta-row-divider { border-top: 1px solid var(--cnf-rule); padding-top: 10px; margin-top: 8px; }
      .cnf-cta-meta-dot {
        width: 8px; height: 8px; border-radius: 50%;
        background: var(--cnf-primary-glow);
        box-shadow: 0 0 6px var(--cnf-primary-glow); flex-shrink: 0;
      }
      .cnf-cta-meta a { color: var(--cnf-primary); font-family: var(--cnf-mono); font-size: 11.5px; }

      /* Bottom action bar (mobile only) */
      .cnf-actbar {
        display: none;
        position: fixed; left: 0; right: 0; bottom: 0;
        padding: 10px 12px calc(10px + env(safe-area-inset-bottom));
        background: rgba(244,241,236,0.96);
        backdrop-filter: blur(12px) saturate(160%);
        -webkit-backdrop-filter: blur(12px) saturate(160%);
        border-top: 1px solid var(--cnf-rule-strong);
        box-shadow: 0 -8px 28px -14px rgba(0,0,0,0.55);
        z-index: 40; gap: 10px;
      }
      .cnf-actbar a {
        display: flex; align-items: center; justify-content: center; gap: 9px;
        border-radius: 13px; font-size: 16px; font-weight: 800; min-height: 52px;
        white-space: nowrap;
      }
      .cnf-actbar-wa {
        flex: 1; background: #0E7A3B; color: #fff;
        box-shadow: 0 6px 16px -5px rgba(14,122,59,0.5);
      }
      .cnf-actbar-wa:active { background: #075F30; transform: translateY(1px); }

      /* Hero */
      .cnf-hero {
        background: var(--cnf-card); border-radius: 24px; overflow: hidden;
        box-shadow: var(--cnf-shadow); border: 1px solid var(--cnf-rule);
        display: grid; grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
      }
      .cnf-hero:not(:has(.cnf-hero-media)) { grid-template-columns: minmax(0, 1fr); }
      .cnf-hero-media {
        position: relative; min-height: 420px; background: var(--cnf-bg-soft);
      }
      .cnf-hero-media img { width: 100%; height: 100%; object-fit: cover; display: block; }
      .cnf-hero-media-empty { width: 100%; height: 100%; background: linear-gradient(135deg, var(--cnf-bg-soft), var(--cnf-bg-deep)); }
      .cnf-hero-chip {
        position: absolute; top: 16px; left: 16px; z-index: 2;
        padding: 6px 12px; background: rgba(244,241,236,0.86); border: 1px solid var(--cnf-rule-strong); border-radius: 999px;
        font-family: var(--cnf-sans); font-size: 11px; font-weight: 700;
        letter-spacing: 0.04em; color: var(--cnf-primary);
      }
      .cnf-hero-chip::before {
        content: ""; display: inline-block;
        width: 6px; height: 6px; background: var(--cnf-primary); border-radius: 50%;
        margin-right: 5px; vertical-align: middle;
      }
      /* Subtle bottom gradient keeps the overlaid caption legible on weak photos
         without darkening the whole image (prototype .hero-img::after). */
      .cnf-hero-media::after {
        content: ""; position: absolute; inset: 0; z-index: 1; pointer-events: none;
        background: linear-gradient(180deg, rgba(0,0,0,0) 46%, rgba(8,20,14,0.58) 100%);
      }
      .cnf-hero-cap {
        position: absolute; left: 13px; bottom: 11px; z-index: 2;
        display: inline-flex; align-items: center; gap: 7px;
        color: #fff; font-family: var(--cnf-sans); font-size: 13px; font-weight: 700;
        letter-spacing: -0.01em; text-shadow: 0 1px 3px rgba(0,0,0,0.45);
      }
      .cnf-hero-cap svg { flex: 0 0 auto; }
      .cnf-hero-body {
        padding: 36px 32px; display: flex; flex-direction: column; justify-content: center;
        min-width: 0;
      }
      .cnf-hero-meta {
        font-family: var(--cnf-mono); font-size: 11px; letter-spacing: 0.08em;
        text-transform: uppercase; color: var(--cnf-ink-soft); font-weight: 700;
        margin-bottom: 14px; display: flex; gap: 14px; flex-wrap: wrap;
      }
      .cnf-hero-title {
        font-family: var(--cnf-sans); font-weight: 800;
        font-size: clamp(24px, 3.4vw, 40px);
        line-height: 1.12; letter-spacing: -0.03em;
        color: var(--cnf-ink);
        margin-bottom: 12px;
        word-wrap: break-word; overflow-wrap: anywhere;
      }
      .cnf-hero-tagline {
        font-size: 15px; color: var(--cnf-ink-soft); line-height: 1.5;
        margin: 0 0 18px; max-width: 480px;
      }
      .cnf-hero-badges {
        display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 20px;
      }
      .cnf-badge {
        display: inline-flex; align-items: center; gap: 6px; height: 30px;
        padding: 0 11px; font-family: var(--cnf-sans); font-size: 13px; font-weight: 600;
        background: var(--cnf-card); border: 1px solid var(--cnf-rule);
        border-radius: 9px; color: var(--cnf-ink); letter-spacing: -0.005em;
        box-shadow: 0 1px 2px rgba(0,0,0,0.16);
      }
      .cnf-badge-k { color: var(--cnf-ink-soft); font-weight: 600; margin-right: 0; }
      /* Hero answer box (above-the-fold dominant intent) - prototype .answer */
      .cnf-hero-answer {
        background: var(--cnf-card); border: 1px solid var(--cnf-rule); border-radius: 14px;
        box-shadow: var(--cnf-shadow); overflow: hidden; margin: 4px 0 18px;
      }
      .cnf-hero-answer-top { padding: 14px 16px 12px; }
      .cnf-hero-answer-lab {
        font-family: var(--cnf-sans); font-size: 12.5px; font-weight: 700;
        letter-spacing: 0.02em; text-transform: uppercase; color: var(--cnf-ink-soft);
      }
      .cnf-hero-answer-big {
        font-family: var(--cnf-sans); font-weight: 800; font-size: 33px;
        letter-spacing: -0.03em; line-height: 1.04; margin-top: 3px; color: var(--cnf-ink);
      }
      .cnf-hero-answer-big small {
        font-size: 15px; font-weight: 600; color: var(--cnf-ink-soft);
        margin-left: 4px; letter-spacing: 0;
      }
      .cnf-hero-answer-sub {
        font-size: 13.5px; color: var(--cnf-ink-soft); margin-top: 6px; line-height: 1.45;
      }
      .cnf-hero-answer-sub b { color: var(--cnf-ink); font-weight: 700; }
      .cnf-answer-evidence {
        display: block; margin-top: 6px; font-size: 12px; line-height: 1.4;
        color: var(--cnf-ink-soft); font-weight: 600;
      }
      .cnf-answer-evidence .cnf-cite { margin-top: 0; }
      .cnf-answer-evidence-sep { color: var(--cnf-ink-soft); }
      .cnf-hero-answer-foot {
        display: flex; align-items: center; gap: 8px; padding: 10px 16px;
        background: var(--cnf-warn-soft); border-top: 1px solid rgba(249,115,22,0.28);
        font-size: 12.5px; color: #7C2D12; font-weight: 600; line-height: 1.35;
      }
      .cnf-hero-answer-foot svg { flex: 0 0 auto; }
      /* ---------- Accordion (secondary sections) - matches public/_proto/college.html .acc ---------- */
      /* A section that IS an accordion: zero the card's own padding so the
         <details> fills it edge-to-edge (one border + shadow, not two). The
         .cnf-shell prefix wins over both .cnf-card and the mobile .cnf-card
         padding override by specificity. */
      .cnf-shell .cnf-acc-card { padding: 0; overflow: hidden; }
      .cnf-acc { background: transparent; }
      .cnf-acc-sum {
        list-style: none; display: flex; align-items: center; gap: 13px;
        padding: 16px 18px; cursor: pointer; -webkit-tap-highlight-color: transparent;
      }
      .cnf-acc-sum::-webkit-details-marker { display: none; }
      .cnf-acc-sum:focus-visible { outline: 2px solid var(--cnf-primary); outline-offset: -2px; border-radius: 14px; }
      .cnf-acc-ico {
        width: 36px; height: 36px; flex: 0 0 auto; border-radius: 10px;
        background: var(--cnf-bg-soft); display: grid; place-items: center;
        color: var(--cnf-primary);
      }
      .cnf-acc-lab { flex: 1; min-width: 0; }
      .cnf-acc-sum .cnf-acc-title {
        font-family: var(--cnf-sans); font-size: 16px; line-height: 1.2;
        letter-spacing: -0.02em; color: var(--cnf-ink); margin: 0; font-weight: 700;
      }
      .cnf-acc-title em { font-style: normal; color: var(--cnf-primary); }
      .cnf-acc-hint {
        display: block; font-size: 12.5px; line-height: 1.35; color: var(--cnf-ink-soft);
        margin-top: 2px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
        font-weight: 500;
      }
      .cnf-acc-chev {
        width: 22px; height: 22px; flex: 0 0 auto; display: grid; place-items: center;
        color: var(--cnf-ink-soft); transition: transform 0.2s ease;
      }
      .cnf-acc[open] .cnf-acc-chev { transform: rotate(180deg); }
      .cnf-acc-body {
        padding: 4px 18px 22px;
        border-top: 1px solid var(--cnf-rule);
        margin-top: 2px;
      }
      .cnf-acc-body > :first-child { margin-top: 14px; }
      @media (prefers-reduced-motion: reduce) {
        .cnf-acc-chev { transition: none; }
      }

      @media (max-width: 840px) {
        .cnf-hero-answer-big { font-size: 30px; }
        .cnf-hero-answer { margin: 4px 0 14px; }
      }
      .cnf-badge.is-gold {
        background: var(--cnf-gold-soft); border-color: rgba(184,132,58,0.3); color: var(--cnf-gold-text);
      }
      .cnf-badge.is-gold .cnf-badge-k { color: var(--cnf-gold-text); }
      .cnf-hero-stats {
        display: grid; grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
        gap: 14px; padding-top: 20px; border-top: 1px solid var(--cnf-rule);
      }
      .cnf-hero-stat { min-width: 0; }
      .cnf-hero-stat-v {
        font-family: var(--cnf-serif); font-weight: 500; font-size: 22px;
        line-height: 1; font-variation-settings: "opsz" 48;
        color: var(--cnf-ink);
      }
      .cnf-hero-stat-l {
        font-family: var(--cnf-mono); font-size: 10px;
        color: var(--cnf-ink-soft); letter-spacing: 0.05em;
        text-transform: uppercase; margin-top: 5px; font-weight: 600;
      }

      /* Section card primitive */
      .cnf-card {
        background: var(--cnf-card); border-radius: 18px;
        padding: 28px; border: 1px solid var(--cnf-rule);
        box-shadow: var(--cnf-shadow); position: relative;
      }
      .cnf-card-head { margin-bottom: 20px; }
      .cnf-card-eyebrow {
        display: block;
        font-family: var(--cnf-mono); font-size: 10.5px; letter-spacing: 0.12em;
        text-transform: uppercase; color: var(--cnf-primary); font-weight: 700;
        margin-bottom: 6px;
      }
      .cnf-card-title {
        font-family: var(--cnf-serif); font-weight: 500; font-size: 26px;
        line-height: 1.1; letter-spacing: -0.02em; color: var(--cnf-ink);
        font-variation-settings: "opsz" 48;
      }
      .cnf-card-title em { font-style: normal; color: var(--cnf-primary); }
      .cnf-fact-summary { padding-top: 24px; padding-bottom: 24px; }
      .cnf-fact-grid {
        margin: 0; display: grid; grid-template-columns: repeat(2, minmax(0, 1fr));
        border: 1px solid var(--cnf-rule); border-radius: 14px; overflow: hidden;
      }
      .cnf-fact-item {
        padding: 12px 14px; border-right: 1px solid var(--cnf-rule); border-bottom: 1px solid var(--cnf-rule);
        min-width: 0; background: rgba(255,255,255,0.03);
      }
      .cnf-fact-item:nth-child(2n) { border-right: 0; }
      .cnf-fact-item:nth-last-child(-n+2) { border-bottom: 0; }
      .cnf-fact-item dt {
        font-family: var(--cnf-mono); font-size: 10.5px; text-transform: uppercase;
        letter-spacing: 0.07em; font-weight: 800; color: var(--cnf-ink-soft); margin-bottom: 4px;
      }
      .cnf-fact-item dd {
        margin: 0; color: var(--cnf-ink); font-size: 13px; line-height: 1.45;
        font-weight: 650; overflow-wrap: anywhere;
      }
      .cnf-review {
        display: flex; gap: 16px; align-items: flex-start;
        background: linear-gradient(180deg, var(--cnf-card), var(--cnf-bg-soft));
      }
      .cnf-review-mark {
        width: 52px; height: 52px; border-radius: 50%;
        display: inline-flex; align-items: center; justify-content: center;
        background: var(--cnf-ink); color: #fff;
        font-family: var(--cnf-mono); font-weight: 800; letter-spacing: 0.04em;
        flex: 0 0 auto;
      }
      .cnf-review-body { min-width: 0; }
      .cnf-review-body p {
        margin: 8px 0 12px; color: var(--cnf-ink-soft);
        font-size: 13.5px; line-height: 1.65;
      }
      .cnf-review-links {
        display: flex; flex-wrap: wrap; gap: 8px; align-items: center;
        font-size: 12px; font-family: var(--cnf-mono);
      }
      .cnf-review-links a {
        color: var(--cnf-primary); text-decoration: none;
        border-bottom: 1px solid rgba(168,107,42,0.3);
      }
      .cnf-review-links span { color: var(--cnf-ink-soft); }

      /* Pair grid */
      .cnf-pair {
        display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); gap: 20px;
      }
      .cnf-pair > .cnf-card { margin: 0; min-width: 0; }

      /* Fees */
      .cnf-fee-banner {
        background: linear-gradient(135deg, var(--cnf-primary), var(--cnf-primary-deep));
        color: var(--cnf-bg); border-radius: 14px; padding: 24px;
        margin-bottom: 16px; position: relative; overflow: hidden; min-width: 0;
      }
      .cnf-fee-banner::before {
        content: ""; position: absolute; top: -40px; right: -40px;
        width: 140px; height: 140px;
        background: radial-gradient(circle, rgba(255,255,255,0.12), transparent 70%);
      }
      .cnf-fee-banner-l {
        font-family: var(--cnf-mono); font-size: 11px; letter-spacing: 0.08em;
        text-transform: uppercase; opacity: 0.8; font-weight: 600;
        margin-bottom: 6px; min-width: 0; overflow-wrap: anywhere;
      }
      .cnf-fee-banner-v {
        font-family: var(--cnf-serif); display: flex; align-items: baseline;
        gap: 4px; font-variation-settings: "opsz" 96; min-width: 0; flex-wrap: wrap;
      }
      .cnf-fee-banner-cur { font-size: 24px; font-weight: 500; opacity: 0.85; }
      .cnf-fee-banner-amt { font-size: 52px; font-weight: 500; line-height: 1; letter-spacing: -0.03em; }
      .cnf-fee-banner-note {
        font-size: 12px; opacity: 0.8; margin-top: 8px; min-width: 0; overflow-wrap: anywhere;
      }
      .cnf-intent-answer {
        margin: 0 0 16px; padding: 14px 16px;
        border: 1px solid rgba(184,132,58,0.22); border-left: 4px solid var(--cnf-primary);
        border-radius: 12px; background: rgba(184,132,58,0.07);
        color: var(--cnf-ink-mid); font-size: 14px; line-height: 1.65;
        overflow-wrap: anywhere;
      }
      .cnf-fee-rows { display: flex; flex-direction: column; }
      table.cnf-fee-rows {
        display: table; width: 100%; border-collapse: collapse;
      }
      .cnf-fee-branches { margin-top: 18px; }
      .cnf-mq-branches { margin-top: 6px; }
      .cnf-mq-foot a { color: var(--cnf-primary); font-weight: 700; text-decoration: none; }
      .cnf-mq-answer {
        margin: -4px 0 18px; padding: 15px 16px;
        border: 1px solid rgba(184,132,58,0.28); border-left: 4px solid var(--cnf-primary);
        border-radius: 12px; background: rgba(184,132,58,0.08);
      }
      .cnf-mq-answer h3 {
        font-family: var(--cnf-serif); font-size: 20px; line-height: 1.2;
        color: var(--cnf-ink); margin: 0 0 8px;
      }
      .cnf-mq-answer p {
        margin: 0; color: var(--cnf-ink-mid); font-size: 13.5px;
        line-height: 1.65; overflow-wrap: anywhere;
      }
      .cnf-mq-answer strong { color: var(--cnf-ink); font-weight: 750; }
      .cnf-faq-list { display: flex; flex-direction: column; }
      .cnf-faq-item { border-bottom: 1px solid var(--cnf-rule); }
      .cnf-faq-item:last-child { border-bottom: none; }
      .cnf-faq-q {
        cursor: pointer; font-weight: 600; font-size: 15px; color: var(--cnf-ink);
        padding: 14px 0; list-style: none; display: flex; justify-content: space-between;
        gap: 12px; align-items: baseline;
      }
      .cnf-faq-q::-webkit-details-marker { display: none; }
      .cnf-faq-q::after { content: "+"; color: var(--cnf-primary); font-weight: 700; flex-shrink: 0; font-size: 18px; }
      .cnf-faq-item[open] > .cnf-faq-q::after { content: "\\2212"; }
      .cnf-faq-a { color: var(--cnf-ink-soft); font-size: 14px; line-height: 1.7; padding: 0 0 14px; }
      /* One caption for the whole table replaces the per-row repeated label. */
      .cnf-fee-caption {
        font-size: 13px; color: var(--cnf-ink-soft); line-height: 1.45;
        margin: 2px 0 10px;
      }
      .cnf-fee-row {
        display: grid; grid-template-columns: 1fr auto;
        padding: 14px 0; border-bottom: 1px solid var(--cnf-rule);
        align-items: baseline; gap: 16px;
      }
      table.cnf-fee-rows .cnf-fee-row { display: table-row; }
      .cnf-fee-row:last-child { border-bottom: none; }
      .cnf-fee-row-k { font-weight: 600; font-size: 14px; line-height: 1.3; color: var(--cnf-ink); }
      .cnf-fee-row-name { font-weight: 700; }
      /* Compact non-default tag (Year 1 payable / Official circular). */
      .cnf-fee-row-tag {
        display: inline-block; margin-left: 8px; padding: 1px 7px;
        font-size: 10.5px; font-weight: 700; letter-spacing: 0.02em;
        color: var(--cnf-gold-text); background: var(--cnf-gold-soft);
        border-radius: 999px; vertical-align: 2px; white-space: nowrap;
      }
      .cnf-fee-row-v {
        font-size: 16px; font-weight: 800; color: var(--cnf-ink);
        white-space: nowrap; line-height: 1.15;
      }
      .cnf-fee-row-amt { letter-spacing: -0.01em; }
      .cnf-fee-row-per { font-size: 11px; font-weight: 600; color: var(--cnf-ink-soft); margin-left: 1px; }
      .cnf-fee-row-tot { display: block; font-size: 11px; font-weight: 600; color: var(--cnf-ink-soft); margin-top: 1px; }
      /* Restored: other FeesSection renderers (general fee list, per-quota and
         annual-fee-by-branch tables) still emit .cnf-fee-row-sub for their small
         muted secondary line. All-sans version of the original rule. */
      .cnf-fee-row-sub { font-size: 11px; line-height: 1.35; font-weight: 400; color: var(--cnf-ink-soft); margin-top: 2px; }
      table.cnf-fee-rows .cnf-fee-row-k,
      table.cnf-fee-rows .cnf-fee-row-v {
        padding: 9px 0; border-bottom: 1px solid var(--cnf-rule);
        vertical-align: top;
      }
      table.cnf-fee-rows .cnf-fee-row-k {
        text-align: left; padding-right: 16px;
      }
      table.cnf-fee-rows .cnf-fee-row-v { text-align: right; }
      table.cnf-fee-rows .cnf-fee-row:last-child .cnf-fee-row-k,
      table.cnf-fee-rows .cnf-fee-row:last-child .cnf-fee-row-v { border-bottom: none; }
      .cnf-fee-row.is-primary .cnf-fee-row-v { color: var(--cnf-primary); }
      .cnf-fee-row.is-muted .cnf-fee-row-v { color: var(--cnf-ink-soft); font-size: 14px; font-weight: 700; }
      .cnf-fee-absences {
        margin-top: 16px; padding: 14px 16px;
        background: var(--cnf-bg); border-radius: 10px;
      }
      .cnf-fee-absences-l {
        font-family: var(--cnf-mono); font-size: 11px;
        letter-spacing: 0.05em; text-transform: uppercase;
        color: var(--cnf-ink-soft); font-weight: 600; margin-bottom: 8px;
      }

      /* Management Quota */
      .cnf-mq-banner {
        background: linear-gradient(135deg, var(--cnf-copper), var(--cnf-gold));
        color: #fff; border-radius: 14px; padding: 22px; margin-bottom: 18px;
        position: relative; overflow: hidden; min-width: 0;
      }
      .cnf-mq-banner::before {
        content: ""; position: absolute; top: -50px; right: -50px;
        width: 160px; height: 160px;
        background: radial-gradient(circle, rgba(255,255,255,0.18), transparent 70%);
      }
      .cnf-mq-banner-eyebrow {
        font-family: var(--cnf-mono); font-size: 10.5px; letter-spacing: 0.1em;
        text-transform: uppercase; opacity: 0.85; font-weight: 600;
        margin-bottom: 6px; min-width: 0; overflow-wrap: anywhere;
      }
      .cnf-mq-banner-title {
        font-family: var(--cnf-serif); font-weight: 500; font-size: 30px;
        line-height: 1.05; letter-spacing: -0.02em; margin-bottom: 8px;
        font-variation-settings: "opsz" 72; min-width: 0; overflow-wrap: anywhere;
      }
      .cnf-mq-banner-title em { font-style: italic; }
      .cnf-mq-banner-sub {
        font-size: 13.5px; opacity: 0.92; line-height: 1.5; max-width: 54ch;
        min-width: 0; overflow-wrap: anywhere;
      }
      .cnf-mq-banner-sub a {
        color: #fff; font-weight: 700; text-underline-offset: 3px;
      }
      .cnf-mq-tiers { display: flex; flex-direction: column; gap: 12px; margin-bottom: 20px; }
      .cnf-mq-tier {
        display: grid; grid-template-columns: 1fr auto; gap: 18px;
        padding: 16px; background: var(--cnf-bg); border-radius: 12px;
        border: 1px solid var(--cnf-rule); align-items: center;
      }
      .cnf-mq-tier-l { display: flex; gap: 12px; align-items: flex-start; }
      .cnf-mq-tier-badge {
        flex-shrink: 0; padding: 6px 11px; border-radius: 7px;
        font-family: var(--cnf-mono); font-size: 11px; font-weight: 700;
        color: #fff; letter-spacing: 0.05em;
      }
      .cnf-mq-tier-badge.is-t1 { background: linear-gradient(135deg, #0E5C3D, #1A8B5F); }
      .cnf-mq-tier-badge.is-t2 { background: linear-gradient(135deg, var(--cnf-copper), var(--cnf-gold)); }
      .cnf-mq-tier-badge.is-t3 { background: linear-gradient(135deg, #4A4A4A, #6B6B6B); }
      .cnf-mq-tier-name { font-weight: 700; font-size: 14px; color: var(--cnf-ink); }
      .cnf-mq-tier-note {
        font-family: var(--cnf-mono); font-size: 11px; color: var(--cnf-ink-soft);
        margin-top: 3px; letter-spacing: 0.02em;
      }
      .cnf-mq-tier-r { text-align: right; }
      .cnf-mq-tier-yr {
        font-family: var(--cnf-serif); font-size: 22px; font-weight: 500;
        color: var(--cnf-ink); line-height: 1;
        font-variation-settings: "opsz" 48;
      }
      .cnf-mq-tier-yr span { font-family: var(--cnf-mono); font-size: 11px; opacity: 0.55; font-weight: 400; }
      .cnf-mq-tier-tot {
        font-family: var(--cnf-mono); font-size: 11px; color: var(--cnf-ink-soft);
        margin-top: 4px; letter-spacing: 0.02em;
      }
      .cnf-mq-empty {
        background: var(--cnf-warn-soft); border: 1px solid rgba(197,66,26,0.18);
        border-radius: 12px; padding: 18px; margin-bottom: 18px;
        color: var(--cnf-ink); font-size: 13.5px; line-height: 1.55;
      }
      .cnf-mq-empty strong { color: var(--cnf-warn); }
      .cnf-mq-route-compare { margin-bottom: 18px; }
      .cnf-mq-route-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 10px; }
      .cnf-mq-route-card {
        background: var(--cnf-bg); border: 1px solid var(--cnf-rule);
        border-radius: 10px; padding: 12px 13px;
      }
      .cnf-mq-route-card strong {
        display: block; font-size: 13px; color: var(--cnf-ink);
        margin-bottom: 5px;
      }
      .cnf-mq-route-card span {
        display: block; font-size: 12.5px; color: var(--cnf-ink-soft);
        line-height: 1.5;
      }
      .cnf-mq-process { margin-bottom: 18px; }
      .cnf-mq-process h3 {
        font-family: var(--cnf-mono); font-size: 11px; letter-spacing: 0.08em;
        text-transform: uppercase; color: var(--cnf-primary); font-weight: 700;
        margin-bottom: 12px;
      }
      .cnf-mq-process-list {
        display: flex; flex-direction: column; gap: 12px;
        padding: 0; margin: 0; list-style: none;
      }
      .cnf-mq-process-list [role="listitem"] {
        display: grid; grid-template-columns: 28px 1fr; gap: 12px;
        align-items: flex-start; font-size: 13.5px; line-height: 1.55;
        color: var(--cnf-ink-mid);
      }
      .cnf-mq-step {
        width: 28px; height: 28px; border-radius: 50%;
        background: var(--cnf-bg-soft); color: var(--cnf-ink);
        display: flex; align-items: center; justify-content: center;
        font-family: var(--cnf-mono); font-size: 12px; font-weight: 700;
      }
      .cnf-mq-donation {
        background: var(--cnf-bg); border-left: 3px solid var(--cnf-gold);
        padding: 14px 16px; border-radius: 8px; font-size: 13px;
        line-height: 1.55; color: var(--cnf-ink-mid); margin-bottom: 14px;
      }
      .cnf-mq-cta {
        display: flex; justify-content: space-between; align-items: center;
        gap: 14px; padding: 16px; background: var(--cnf-primary-soft);
        border-radius: 12px; margin-bottom: 12px;
      }
      .cnf-mq-cta-text { font-size: 13.5px; color: var(--cnf-primary-deep); font-weight: 600; display: grid; gap: 4px; }
      .cnf-mq-cta-text span { font-family: var(--cnf-mono); font-size: 11px; color: var(--cnf-ink-mid); }
      .cnf-mq-cta-btn {
        display: flex; align-items: center; justify-content: center; gap: 7px;
        min-height: 44px;
        padding: 10px 16px; background: #0E7A3B; color: #fff;
        border-radius: 10px; font-size: 13px; font-weight: 700;
        flex-shrink: 0;
      }
      .cnf-mq-cta-btn:hover { background: #075F30; }

      /* ===== Management quota answer block (opt-in lead element of #management-quota) =====
         Snippet-style direct answer + compact highlighted mini-table + prominent
         WhatsApp lead CTA. Mobile-first; sits inside the existing .cnf-card
         and reuses --cnf-primary-soft so it reads as a sibling of the .cnf-mq-cta
         band, not a foreign panel. */
      .cnf-mq-answer {
        margin: 0 0 18px; padding: 16px;
        background: var(--cnf-primary-soft);
        border: 1px solid var(--cnf-rule); border-radius: 12px;
      }
      .cnf-mq-answer-eyebrow {
        font-family: var(--cnf-mono); font-size: 10.5px; font-weight: 700;
        letter-spacing: 0.12em; text-transform: uppercase;
        color: var(--cnf-primary); margin-bottom: 8px;
      }
      .cnf-mq-answer-lead {
        margin: 0 0 14px; font-size: 15px; line-height: 1.55;
        color: var(--cnf-primary-deep); font-weight: 600;
      }
      .cnf-mq-answer-lead strong { color: var(--cnf-ink); }
      .cnf-mq-answer-table {
        margin: 0; background: var(--cnf-card);
        border: 1px solid var(--cnf-rule-strong); border-radius: 12px;
        padding: 12px 14px;
      }
      .cnf-mq-answer-table .cnf-pl-branches-head { margin-bottom: 8px; }
      /* "indicative" tag for unsourced rows (gold caution accent) - used in the
         answer block AND the full per-branch table so an unsourced rupee figure
         never reads as a source-verified one. */
      .cnf-fee-indic {
        display: inline-block; margin-left: 8px; padding: 1px 7px;
        border-radius: 999px; background: var(--cnf-gold-soft); color: var(--cnf-gold-text);
        font-family: var(--cnf-mono); font-size: 10px; font-weight: 700;
        letter-spacing: 0.04em; text-transform: uppercase; vertical-align: middle;
        white-space: nowrap;
      }
      .cnf-mq-answer-cta {
        display: flex; align-items: center; justify-content: center; gap: 8px;
        width: 100%; min-height: 44px; margin-top: 14px; padding: 13px 16px;
        background: #0E7A3B; color: #fff; border-radius: 12px;
        font-size: 14px; font-weight: 700; letter-spacing: 0.01em;
        box-shadow: 0 4px 14px -4px rgba(14,122,59,0.4);
        transition: background 0.12s ease, transform 0.12s ease;
      }
      .cnf-mq-answer-cta:hover { background: #075F30; }
      .cnf-mq-answer-cta:active { background: #075F30; transform: translateY(1px); }
      .cnf-mq-answer-note { margin-top: 12px; }
      .cnf-mq-handoff {
        font-size: 13px; color: var(--cnf-ink-soft); line-height: 1.55;
        margin: 16px 0 0; padding-top: 12px; border-top: 1px solid var(--cnf-rule);
      }
      .cnf-mq-handoff a { color: var(--cnf-primary); font-weight: 700; text-decoration: none; }
      .cnf-mq-handoff a:hover { text-decoration: underline; }
      @media (max-width: 840px) {
        .cnf-mq-answer { padding: 14px; }
        .cnf-mq-answer-table { padding: 10px 12px; }
        .cnf-mq-answer-lead { font-size: 14.5px; }
      }
      @media (max-width: 480px) {
        .cnf-mq-answer-cta { font-size: 13.5px; padding: 12px; }
        .cnf-fee-indic { margin-left: 6px; }
      }
      @media (prefers-reduced-motion: reduce) {
        .cnf-mq-answer-cta { transition: none; }
        .cnf-mq-answer-cta:active { transform: none; }
      }

      .cnf-mq-foot {
        display: flex; gap: 8px; align-items: flex-start;
        font-family: var(--cnf-mono); font-size: 11px; color: var(--cnf-ink-soft);
        letter-spacing: 0.02em; line-height: 1.5;
      }
      .cnf-mq-contact-note {
        margin-top: 10px; font-size: 12px; color: var(--cnf-ink-mid);
        display: flex; gap: 6px; flex-wrap: wrap;
      }
      .cnf-mq-reconcile {
        margin-top: 12px; padding: 12px 14px;
        border: 1px solid rgba(168,107,42,0.25);
        border-radius: 10px; background: rgba(184,132,58,0.08);
        color: var(--cnf-ink-mid); font-size: 12.5px; line-height: 1.55;
      }

      /* Management Quota - "Not applicable" disclaimer panel.
         Editorial card, intentionally NOT styled as an error/404. Terracotta
         accent stripe at the top signals "notice" in the navy/gold theme. */
      .cnf-mq-na {
        position: relative;
        background: var(--cnf-card);
        padding-top: 36px;
        overflow: hidden;
      }
      .cnf-mq-na-stripe {
        position: absolute; top: 0; left: 0; right: 0; height: 4px;
        background: linear-gradient(90deg,
          var(--cnf-warn) 0%,
          var(--cnf-warn) 18%,
          var(--cnf-gold) 18%,
          var(--cnf-gold) 32%,
          var(--cnf-warn) 32%,
          var(--cnf-warn) 60%,
          var(--cnf-copper) 60%,
          var(--cnf-copper) 100%);
      }
      .cnf-mq-na-head {
        max-width: 640px;
        padding-bottom: 26px;
        border-bottom: 1px solid var(--cnf-rule);
        margin-bottom: 24px;
      }
      .cnf-mq-na-eyebrow {
        font-family: var(--cnf-mono);
        font-size: 11px;
        letter-spacing: 0.16em;
        text-transform: uppercase;
        color: var(--cnf-warn);
        margin-bottom: 14px;
      }
      .cnf-mq-na-eyebrow strong {
        color: var(--cnf-copper);
        font-weight: 700;
      }
      .cnf-mq-na-title {
        font-family: var(--cnf-serif);
        font-size: clamp(32px, 4.4vw, 46px);
        font-weight: 500;
        font-variation-settings: "opsz" 144;
        line-height: 1.05;
        letter-spacing: -0.025em;
        color: var(--cnf-ink);
        margin-bottom: 16px;
      }
      .cnf-mq-na-title em {
        font-style: italic;
        color: var(--cnf-warn);
        font-weight: 500;
      }
      .cnf-mq-na-lead {
        font-family: var(--cnf-sans);
        font-size: 15.5px;
        line-height: 1.65;
        color: var(--cnf-ink-mid);
        margin: 0;
      }
      .cnf-mq-na-routes {
        background: var(--cnf-bg-soft);
        border-radius: 14px;
        padding: 22px 24px;
        margin-bottom: 24px;
      }
      .cnf-mq-na-routes-h {
        font-family: var(--cnf-mono);
        font-size: 11px;
        letter-spacing: 0.14em;
        text-transform: uppercase;
        color: var(--cnf-primary-deep);
        font-weight: 700;
        margin-bottom: 14px;
      }
      .cnf-mq-na-routes-list {
        display: flex; flex-direction: column; gap: 10px;
      }
      .cnf-mq-na-routes-list li {
        display: flex; gap: 12px; align-items: flex-start;
        font-size: 14.5px; color: var(--cnf-ink); line-height: 1.5;
      }
      .cnf-mq-na-bullet {
        display: inline-flex; align-items: center; justify-content: center;
        width: 22px; height: 22px;
        border-radius: 50%;
        background: var(--cnf-primary-soft);
        color: var(--cnf-primary);
        font-weight: 700; font-size: 12px;
        flex-shrink: 0;
        margin-top: 1px;
      }
      .cnf-mq-na-fees {
        border: 1px solid var(--cnf-rule);
        border-radius: 14px;
        overflow: hidden;
        margin-bottom: 24px;
        background: var(--cnf-card);
      }
      .cnf-mq-na-fees h3 {
        font-family: var(--cnf-mono);
        font-size: 11px;
        letter-spacing: 0.12em;
        text-transform: uppercase;
        color: var(--cnf-primary-deep);
        font-weight: 700;
        padding: 16px 18px;
        border-bottom: 1px solid var(--cnf-rule);
      }
      .cnf-mq-na-fee-table-wrap { overflow-x: auto; }
      .cnf-mq-na-fee-table {
        width: 100%;
        min-width: 720px;
        border-collapse: collapse;
        font-size: 13px;
      }
      .cnf-mq-na-fee-table caption {
        text-align: left;
        padding: 12px 18px;
        color: var(--cnf-ink-soft);
        font-family: var(--cnf-mono);
        font-size: 11px;
        border-bottom: 1px solid var(--cnf-rule);
      }
      .cnf-mq-na-fee-table th,
      .cnf-mq-na-fee-table td {
        text-align: left;
        padding: 12px 14px;
        border-bottom: 1px solid var(--cnf-rule);
        vertical-align: top;
      }
      .cnf-mq-na-fee-table th {
        font-family: var(--cnf-mono);
        font-size: 10px;
        text-transform: uppercase;
        letter-spacing: 0.08em;
        color: var(--cnf-ink-soft);
        background: var(--cnf-bg-soft);
      }
      .cnf-mq-na-fee-table td {
        color: var(--cnf-ink-mid);
        font-weight: 600;
      }
      .cnf-mq-na-fee-table td:first-child {
        color: var(--cnf-ink);
        font-weight: 700;
      }
      .cnf-mq-na-cta {
        display: flex; gap: 16px; align-items: center; justify-content: space-between;
        flex-wrap: wrap;
        padding: 18px 22px;
        background: linear-gradient(135deg, var(--cnf-primary-deep), var(--cnf-primary));
        border-radius: 14px;
        color: var(--cnf-bg);
        margin-bottom: 22px;
      }
      .cnf-mq-na-cta-body { min-width: 0; flex: 1 1 240px; }
      .cnf-mq-na-cta-h {
        font-family: var(--cnf-serif);
        font-size: 18px;
        font-weight: 500;
        font-variation-settings: "opsz" 48;
        line-height: 1.25;
        margin-bottom: 4px;
      }
      .cnf-mq-na-cta-sub {
        font-size: 13px;
        opacity: 0.86;
        line-height: 1.5;
      }
      .cnf-mq-na-cta-btn {
        display: inline-flex; align-items: center; gap: 8px;
        padding: 12px 18px;
        background: var(--cnf-bg); color: var(--cnf-ink) !important;
        border: 1px solid rgba(255, 255, 255, 0.72);
        box-shadow: 0 10px 24px rgba(16, 24, 20, 0.22);
        border-radius: 10px;
        text-decoration: none;
        font-size: 13.5px; font-weight: 700;
        flex-shrink: 0;
        transition: transform 0.15s ease;
      }
      .cnf-mq-na-cta-btn svg { color: #128c7e; }
      .cnf-mq-na-cta-btn:hover { transform: translateY(-1px); }
      .cnf-mq-na-foot {
        display: flex; gap: 16px;
        justify-content: space-between; align-items: flex-start;
        flex-wrap: wrap;
        padding-top: 18px;
        border-top: 1px solid var(--cnf-rule);
        font-family: var(--cnf-mono);
        font-size: 11px;
        letter-spacing: 0.02em;
        line-height: 1.55;
        color: var(--cnf-ink-soft);
      }
      .cnf-mq-na-foot span { flex: 1 1 280px; max-width: 520px; }
      .cnf-mq-na-source {
        color: var(--cnf-primary);
        text-decoration: underline;
        text-decoration-color: var(--cnf-primary-glow);
        text-underline-offset: 3px;
        font-weight: 600;
        white-space: nowrap;
      }
      .cnf-mq-na-source:hover { color: var(--cnf-primary-deep); }
      @media (max-width: 640px) {
        .cnf-mq-na { padding-top: 32px; }
        .cnf-mq-na-cta { flex-direction: column; align-items: stretch; }
        .cnf-mq-na-cta-btn { justify-content: center; }
      }

      /* Placements */
      .cnf-pl-headline {
        display: grid; grid-template-columns: auto 1fr; gap: 24px;
        align-items: center; padding-bottom: 18px;
        border-bottom: 1px solid var(--cnf-rule); margin-bottom: 18px;
      }
      .cnf-pl-pct span {
        font-family: var(--cnf-serif); font-size: 84px; font-weight: 500;
        color: var(--cnf-primary); line-height: 0.9;
        letter-spacing: -0.04em; font-variation-settings: "opsz" 144;
        display: inline-block;
      }
      .cnf-pl-pct small {
        font-family: var(--cnf-serif); font-size: 30px; font-weight: 500;
        opacity: 0.7; margin-left: -4px;
      }
      .cnf-pl-pct-sub {
        font-family: var(--cnf-mono); font-size: 11px; color: var(--cnf-ink-soft);
        letter-spacing: 0.04em; margin-top: 8px;
      }
      .cnf-pl-side { display: flex; flex-direction: column; gap: 10px; }
      .cnf-pl-tile {
        display: flex; justify-content: space-between; align-items: baseline;
        gap: 14px; padding: 12px 14px; background: var(--cnf-bg);
        border-radius: 10px;
      }
      .cnf-pl-tile strong {
        font-family: var(--cnf-serif); font-size: 22px; font-weight: 500;
        color: var(--cnf-ink); font-variation-settings: "opsz" 48;
      }
      .cnf-pl-tile span {
        font-family: var(--cnf-mono); font-size: 11px; color: var(--cnf-ink-soft);
        letter-spacing: 0.04em;
      }
      .cnf-pl-summary {
        font-size: 13.5px; color: var(--cnf-ink-mid); line-height: 1.65;
        margin: 0 0 18px; overflow-wrap: anywhere;
      }
      .cnf-pl-trend { margin-bottom: 18px; }
      .cnf-pl-trend-head, .cnf-pl-branches-head {
        font-family: var(--cnf-mono); font-size: 11px; letter-spacing: 0.08em;
        text-transform: uppercase; color: var(--cnf-primary); font-weight: 700;
        margin-bottom: 12px;
      }
      .cnf-pl-trend-row {
        display: grid; grid-template-columns: 80px 1fr 60px;
        gap: 12px; align-items: center; padding: 6px 0;
        font-family: var(--cnf-mono); font-size: 12px;
      }
      .cnf-pl-trend-y { color: var(--cnf-ink-mid); letter-spacing: 0.04em; }
      .cnf-pl-trend-bar {
        height: 8px; background: var(--cnf-bg-soft); border-radius: 999px; overflow: hidden;
      }
      .cnf-pl-trend-bar span {
        display: block; height: 100%; background: var(--cnf-primary);
      }
      .cnf-pl-trend-row strong { color: var(--cnf-primary); text-align: right; }
      .cnf-pl-branches { margin-bottom: 18px; }
      .cnf-pl-branch-row {
        display: grid; grid-template-columns: minmax(0, 0.8fr) minmax(0, 1.2fr);
        gap: 12px; align-items: baseline; padding: 8px 0;
        font-size: 13px; color: var(--cnf-ink-mid);
        border-bottom: 1px solid var(--cnf-rule);
      }
      .cnf-pl-branch-name { color: var(--cnf-ink); font-weight: 650; min-width: 0; overflow-wrap: anywhere; }
      .cnf-pl-branch-metrics { min-width: 0; text-align: right; overflow-wrap: anywhere; }
      .cnf-pl-branch-metrics .cnf-cite { margin-top: 0; white-space: nowrap; }
      .cnf-pl-branch-row:last-child { border-bottom: none; }
      .cnf-pl-recruiters { margin-bottom: 6px; }
      .cnf-pl-recruiter-list, .cnf-chip-grid {
        display: flex; gap: 6px; flex-wrap: wrap;
      }

      /* Chip */
      .cnf-chip {
        padding: 5px 10px; background: var(--cnf-bg-soft);
        border-radius: 7px; font-family: var(--cnf-mono);
        font-size: 11px; color: var(--cnf-ink-mid);
        letter-spacing: 0.02em; font-weight: 500;
      }
      .cnf-chip.is-route { background: var(--cnf-primary-soft); color: var(--cnf-primary-deep); font-weight: 600; }
      .cnf-chip.is-muted { background: transparent; color: var(--cnf-ink-soft); border: 1px dashed var(--cnf-rule-strong); }

      /* Programmes */
      .cnf-prog-list {
        display: flex; flex-direction: column; gap: 8px;
        container-type: inline-size; container-name: cnf-programme-list;
      }
      .cnf-prog-row {
        display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: 14px;
        align-items: center; padding: 12px 13px;
        background: var(--cnf-bg); border-radius: 13px;
        border: 1px solid var(--cnf-rule);
      }
      .cnf-prog-row-l { min-width: 0; }
      .cnf-prog-row-name {
        font-family: var(--cnf-sans); font-weight: 700; font-size: 16px;
        line-height: 1.2; letter-spacing: -0.01em; color: var(--cnf-ink); margin-bottom: 3px;
        overflow-wrap: anywhere;
      }
      .cnf-prog-row-meta {
        display: flex; flex-wrap: wrap; gap: 8px;
        font-family: var(--cnf-mono); font-size: 11px;
        color: var(--cnf-ink-soft); letter-spacing: 0.02em;
      }
      .cnf-prog-row-meta .is-good { color: var(--cnf-primary); font-weight: 700; }
      .cnf-prog-row-r {
        display: flex; gap: 16px; flex-shrink: 0;
      }
      .cnf-prog-stat { text-align: right; }
      .cnf-prog-stat strong {
        display: block; font-family: var(--cnf-sans); font-size: 16px;
        font-weight: 800; color: var(--cnf-ink); line-height: 1; letter-spacing: -0.01em;
      }
      .cnf-prog-stat span {
        font-family: var(--cnf-mono); font-size: 10px;
        color: var(--cnf-ink-soft); letter-spacing: 0.04em;
        text-transform: uppercase;
      }
      .cnf-prog-row-foot {
        grid-column: 1 / -1; padding-top: 6px; border-top: 1px solid var(--cnf-rule);
        margin-top: 2px; font-family: var(--cnf-mono); font-size: 10.5px;
        color: var(--cnf-ink-soft); letter-spacing: 0.02em;
      }
      @container cnf-programme-list (max-width: 820px) {
        .cnf-prog-row { grid-template-columns: 1fr; align-items: flex-start; gap: 10px; }
        .cnf-prog-row-r {
          display: grid;
          grid-template-columns: repeat(auto-fit, minmax(78px, max-content));
          justify-content: flex-start;
          gap: 10px 18px;
          flex-shrink: 1;
        }
        .cnf-prog-stat { text-align: left; }
        .cnf-prog-stat span { display: block; line-height: 1.2; }
      }

      /* Cutoffs */
      .cnf-cut-grid { display: flex; flex-direction: column; }
      .cnf-cut-head {
        display: grid; grid-template-columns: minmax(0, 1.4fr) repeat(3, minmax(0, 1fr));
        gap: 12px; padding: 10px 14px;
        background: var(--cnf-bg); border-radius: 8px;
        font-family: var(--cnf-mono); font-size: 10.5px; letter-spacing: 0.08em;
        text-transform: uppercase; color: var(--cnf-ink-soft); font-weight: 700;
      }
      .cnf-cut-row {
        display: grid; grid-template-columns: minmax(0, 1.4fr) repeat(3, minmax(0, 1fr));
        gap: 12px; padding: 12px 14px;
        font-size: 13px; color: var(--cnf-ink-mid);
        border-bottom: 1px solid var(--cnf-rule);
        align-items: baseline;
      }
      .cnf-cut-row:last-child { border-bottom: none; }
      .cnf-cut-branch { font-weight: 600; color: var(--cnf-ink); }
      .cnf-cut-row .is-strong {
        font-family: var(--cnf-sans); font-size: 15px; font-weight: 800;
        letter-spacing: -0.01em; color: var(--cnf-primary);
      }
      .cnf-cut-foot {
        font-size: 12px; color: var(--cnf-ink-soft); line-height: 1.5;
        margin: 10px 0 0; padding-top: 10px; border-top: 1px solid var(--cnf-rule);
      }
      /* Multi-exam cutoffs: per-exam group + 5-column opening/closing table */
      .cnf-cut-exam { margin-bottom: 16px; }
      .cnf-cut-exam:last-child { margin-bottom: 0; }
      .cnf-cut-exam-head { display: flex; align-items: baseline; gap: 10px; margin: 0 0 6px; }
      .cnf-cut-exam-name { font-family: var(--cnf-sans); font-weight: 800; font-size: 16px; letter-spacing: -0.01em; color: var(--cnf-ink); }
      .cnf-cut-exam-yr { font-family: var(--cnf-mono); font-size: 11px; color: var(--cnf-gold-text); font-weight: 700; }
      .cnf-cut-head--full, .cnf-cut-row--full { grid-template-columns: minmax(0, 1.6fr) minmax(0, 0.8fr) minmax(0, 0.9fr) minmax(0, 0.9fr) minmax(0, 1fr); }
      /* fr tracks default to a content-based min, which let the header row size
         its columns differently from the data rows (misalignment) and overflow
         the card; minmax(0, ...) above makes tracks purely proportional. min-width:0
         keeps every cell to its track; only the header labels and branch names may
         wrap - rank VALUES never break mid-number (the column is sized to fit them). */
      .cnf-cut-head > span, .cnf-cut-row > span { min-width: 0; }
      .cnf-cut-head > span, .cnf-cut-branch { overflow-wrap: anywhere; }
      .cnf-cut-row--full .is-strong { color: var(--cnf-primary); }
      /* Horizontal-scroll viewport for the wide 5-col multi-exam table */
      .cnf-cut-scroll {
        position: relative; margin: 0 -2px;
        overflow-x: auto; -webkit-overflow-scrolling: touch;
        scrollbar-width: thin; scrollbar-color: var(--cnf-rule-strong) transparent;
      }
      .cnf-cut-scroll::-webkit-scrollbar { height: 6px; }
      .cnf-cut-scroll::-webkit-scrollbar-thumb { background: var(--cnf-rule-strong); border-radius: 99px; }
      /* Cutoffs wide-table scroll affordance: right-edge fade hinting more columns.
         Lives on the relative .cnf-cut-scroll viewport; pointer-events:none so it
         never blocks taps on the table or its SourceCite links. */
      .cnf-cut-scroll::after {
        content: ""; position: absolute; top: 0; right: 0; bottom: 0;
        width: 28px; pointer-events: none;
        background: linear-gradient(90deg, rgba(255,255,255,0), var(--cnf-card));
      }

      /* Admissions */
      .cnf-adm-routes {
        display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 12px;
      }
      .cnf-adm-grid {
        display: grid; grid-template-columns: 1.4fr 1fr;
        gap: 18px 24px; margin-bottom: 14px;
      }
      .cnf-adm-col h3, .cnf-adm-docs h3, .cnf-adm-contact h3, .cnf-adm-nri h3 {
        font-family: var(--cnf-mono); font-size: 11px; letter-spacing: 0.08em;
        text-transform: uppercase; color: var(--cnf-primary); font-weight: 700;
        margin-bottom: 8px;
      }
      .cnf-adm-steps {
        display: flex; flex-direction: column; gap: 8px;
        padding: 0; margin: 0; list-style: none;
      }
      .cnf-adm-steps [role="listitem"] {
        display: grid; grid-template-columns: 26px 1fr; gap: 10px;
        align-items: flex-start; font-size: 13.5px; line-height: 1.5;
        color: var(--cnf-ink-mid);
      }
      .cnf-adm-list {
        display: flex; flex-direction: column; gap: 7px;
        padding: 0; margin: 0; list-style: none;
      }
      .cnf-adm-list li {
        display: block; font-size: 13px; line-height: 1.55;
        color: var(--cnf-ink-mid);
        padding-left: 16px; position: relative;
        word-break: break-word; overflow-wrap: anywhere;
      }
      .cnf-adm-list li::before {
        content: ""; position: absolute; left: 0; top: 0.55em;
        width: 5px; height: 5px; background: var(--cnf-primary);
        border-radius: 50%;
      }
      .cnf-adm-list strong {
        color: var(--cnf-ink); font-weight: 600;
        margin-right: 6px;
      }
      .cnf-adm-docs { margin-bottom: 14px; }
      .cnf-adm-docs-list { display: flex; gap: 6px; flex-wrap: wrap; }
      .cnf-adm-contact {}
      .cnf-adm-contact-row {
        display: flex; flex-direction: column; gap: 8px;
        font-size: 13px; color: var(--cnf-ink-mid);
      }
      .cnf-adm-contact-row span { display: flex; align-items: center; gap: 8px; }
      .cnf-adm-nri {
        border: 1px solid var(--cnf-rule);
        border-radius: 14px;
        background: var(--cnf-bg-soft);
        padding: 14px;
        margin-bottom: 14px;
      }
      .cnf-adm-nri-head p {
        margin: -2px 0 12px;
        color: var(--cnf-ink-soft);
        font-size: 13px;
        line-height: 1.55;
      }
      .cnf-adm-nri-routes {
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
        gap: 10px;
        margin-bottom: 12px;
      }
      .cnf-adm-nri-card {
        background: var(--cnf-card);
        border: 1px solid var(--cnf-rule);
        border-radius: 12px;
        padding: 11px 12px;
      }
      .cnf-adm-nri-card h4,
      .cnf-adm-nri-docs h4 {
        margin: 0 0 6px;
        color: var(--cnf-ink);
        font-size: 13px;
        font-weight: 800;
      }
      .cnf-adm-nri-card p {
        margin: 0 0 7px;
        color: var(--cnf-ink-mid);
        font-size: 13px;
        line-height: 1.55;
      }
      .cnf-adm-nri-docs { margin-top: 2px; }
      .cnf-adm-nri-foot {
        display: flex;
        flex-wrap: wrap;
        gap: 8px;
        align-items: center;
        margin-top: 12px;
        color: var(--cnf-ink-soft);
        font-size: 12px;
        font-weight: 650;
      }
      .cnf-adm-nri-foot > span {
        border: 1px solid var(--cnf-rule);
        border-radius: 999px;
        background: var(--cnf-card);
        padding: 5px 9px;
      }

      /* Hostel */
      .cnf-hos-grid {
        display: grid; grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
        gap: 12px; margin-bottom: 16px;
      }
      .cnf-hos-stat {
        padding: 12px; background: var(--cnf-bg); border-radius: 10px;
        text-align: left;
      }
      .cnf-hos-stat strong {
        display: block; font-family: var(--cnf-serif); font-size: 24px;
        font-weight: 500; color: var(--cnf-ink); line-height: 1;
        font-variation-settings: "opsz" 48;
      }
      .cnf-hos-stat span {
        font-family: var(--cnf-mono); font-size: 10.5px;
        color: var(--cnf-ink-soft); letter-spacing: 0.05em;
        text-transform: uppercase; margin-top: 4px; display: block;
      }
      .cnf-hos-loc {
        font-size: 13px; color: var(--cnf-ink-mid); margin: 0 0 16px;
      }
      .cnf-hos-amenities { margin-bottom: 14px; }
      .cnf-hos-foot {
        font-size: 12px; color: var(--cnf-ink-soft); line-height: 1.5;
        margin: 8px 0 0;
      }
      .cnf-hostel-answer { margin-bottom: 16px; }

      /* Scholarships */
      .cnf-sch-headline {
        background: var(--cnf-primary-soft); padding: 14px 18px;
        border-radius: 10px; font-size: 14px; color: var(--cnf-primary-deep);
        margin-bottom: 16px; line-height: 1.5;
      }
      .cnf-sch-headline strong { color: var(--cnf-primary); }
      .cnf-sch-rows { display: flex; flex-direction: column; gap: 10px; }
      .cnf-sch-row {
        display: grid; grid-template-columns: 1fr auto; gap: 14px;
        padding: 12px 14px; background: var(--cnf-bg);
        border-radius: 10px; align-items: center;
      }
      .cnf-sch-row-name { font-weight: 600; font-size: 13.5px; color: var(--cnf-ink); }
      .cnf-sch-row-note {
        font-size: 12px; color: var(--cnf-ink-soft); line-height: 1.4;
        margin-top: 3px;
      }
      .cnf-sch-row-tag {
        font-family: var(--cnf-mono); font-size: 11px; font-weight: 700;
        padding: 4px 9px; background: var(--cnf-primary); color: var(--cnf-bg);
        border-radius: 6px; letter-spacing: 0.02em;
      }
      .cnf-sch-foot {
        font-size: 12px; color: var(--cnf-ink-soft); margin-top: 12px;
      }

      /* Infrastructure */
      .cnf-inf-grid {
        display: grid; grid-template-columns: repeat(3, 1fr);
        gap: 12px; margin-bottom: 18px;
      }
      .cnf-inf-cell {
        padding: 14px; background: var(--cnf-bg); border-radius: 10px;
      }
      .cnf-inf-v {
        font-family: var(--cnf-serif); font-size: 24px; font-weight: 500;
        color: var(--cnf-ink); line-height: 1;
        font-variation-settings: "opsz" 48;
      }
      .cnf-inf-l {
        font-family: var(--cnf-mono); font-size: 10.5px;
        color: var(--cnf-ink-soft); letter-spacing: 0.04em;
        text-transform: uppercase; margin-top: 6px; line-height: 1.35;
      }
      .cnf-inf-feature { margin-bottom: 16px; }
      .cnf-inf-feature:last-child { margin-bottom: 0; }

      /* Research */
      .cnf-res-stats {
        display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
        gap: 12px; margin-bottom: 18px;
      }
      .cnf-res-stat {
        padding: 14px; background: var(--cnf-bg); border-radius: 10px;
      }
      .cnf-res-stat strong {
        display: block; font-family: var(--cnf-serif); font-size: 24px;
        font-weight: 500; color: var(--cnf-ink); line-height: 1;
        font-variation-settings: "opsz" 48;
      }
      .cnf-res-stat span {
        font-family: var(--cnf-mono); font-size: 10.5px;
        color: var(--cnf-ink-soft); letter-spacing: 0.05em;
        text-transform: uppercase; margin-top: 5px; display: block;
      }
      .cnf-res-section { margin-bottom: 16px; }
      .cnf-res-centres, .cnf-res-patents, .cnf-res-grants {
        display: grid; gap: 10px;
      }
      .cnf-res-centre, .cnf-res-patent, .cnf-res-grant {
        padding: 12px 14px; background: var(--cnf-bg);
        border-radius: 10px; display: flex; flex-direction: column; gap: 4px;
      }
      .cnf-res-centre strong, .cnf-res-patent strong, .cnf-res-grant strong {
        font-weight: 700; font-size: 13.5px; color: var(--cnf-ink);
      }
      .cnf-res-centre span, .cnf-res-patent span, .cnf-res-grant span {
        font-size: 12.5px; color: var(--cnf-ink-soft); line-height: 1.4;
      }
      .cnf-muted { font-family: var(--cnf-mono); font-size: 11px !important; }

      /* Gallery - expanded mosaic. Featured (first) photo spans 2x2; the rest
         are square tiles flowing around it (grid-auto-flow: dense). Mobile-first
         result: a big near-square hero + a 2-col tile grid. */
      .cnf-gal-head {
        display: flex; align-items: flex-end; justify-content: space-between;
        gap: 12px; margin-bottom: 16px;
      }
      .cnf-gal-head-l { min-width: 0; }
      .cnf-gal-count {
        flex: 0 0 auto; display: inline-flex; align-items: center; gap: 6px;
        font-family: var(--cnf-mono); font-size: 11px; font-weight: 700;
        letter-spacing: 0.04em; text-transform: uppercase; color: var(--cnf-gold-text);
        background: var(--cnf-gold-soft); border: 1px solid rgba(184,132,58,0.24);
        padding: 5px 11px 5px 9px; border-radius: 999px; white-space: nowrap;
      }
      .cnf-gal-wrap { display: flex; flex-direction: column; gap: 10px; }
      .cnf-gal-grid {
        display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px;
      }
      .cnf-photo {
        aspect-ratio: 1 / 1; border-radius: 14px; overflow: hidden;
        background: var(--cnf-bg-soft); position: relative; display: block;
        padding: 0; border: 1px solid var(--cnf-rule); margin: 0;
        cursor: zoom-in; font-family: inherit; width: 100%;
        transition: transform 0.22s cubic-bezier(0.22,1,0.36,1), box-shadow 0.22s ease, border-color 0.22s ease;
        /* Staggered reveal on load. animation-fill-mode backwards hides each
           tile during its delay then reverts to base after, so hover transforms
           still work and there is no flash of content (also SSR/no-JS safe). */
        animation: cnf-gal-rise 0.55s cubic-bezier(0.22,1,0.36,1) backwards;
        animation-delay: calc(var(--i, 0) * 45ms);
      }
      .cnf-photo-feat { aspect-ratio: 16 / 10; border-radius: 18px; }
      .cnf-photo:hover {
        transform: translateY(-3px);
        box-shadow: var(--cnf-shadow); border-color: var(--cnf-rule-strong);
      }
      .cnf-photo:focus-visible { outline: 2px solid var(--cnf-primary); outline-offset: 2px; }
      .cnf-photo img {
        width: 100%; height: 100%; object-fit: cover; display: block;
        transition: transform 0.45s cubic-bezier(0.22,1,0.36,1);
      }
      .cnf-photo:hover img { transform: scale(1.06); }
      .cnf-photo-shade {
        position: absolute; inset: 0; pointer-events: none;
        background: linear-gradient(180deg, transparent 55%, rgba(22,20,14,0.45));
        opacity: 0.6; transition: opacity 0.22s ease;
      }
      .cnf-photo:hover .cnf-photo-shade { opacity: 0.85; }
      .cnf-photo-cap {
        position: absolute; bottom: 0; left: 0; right: 0; z-index: 1;
        padding: 18px 12px 9px;
        color: #fff; font-family: var(--cnf-mono); font-size: 10px;
        letter-spacing: 0.03em; text-transform: lowercase; text-align: left;
        line-height: 1.3; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
        text-shadow: 0 1px 3px rgba(0,0,0,0.5);
      }
      .cnf-photo-feat .cnf-photo-cap { font-size: 12px; padding: 22px 16px 13px; white-space: normal; }
      .cnf-photo-zoom {
        position: absolute; top: 9px; right: 9px; z-index: 1;
        width: 30px; height: 30px; border-radius: 50%;
        display: flex; align-items: center; justify-content: center;
        background: rgba(22,20,14,0.5); color: #fff;
        opacity: 0; transform: scale(0.8) rotate(-8deg);
        transition: opacity 0.22s ease, transform 0.22s cubic-bezier(0.22,1,0.36,1);
        backdrop-filter: blur(4px); -webkit-backdrop-filter: blur(4px);
      }
      .cnf-photo:hover .cnf-photo-zoom,
      .cnf-photo:focus-visible .cnf-photo-zoom { opacity: 1; transform: scale(1) rotate(0); }
      .cnf-sr-only {
        position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
        overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0;
      }
      .cnf-gal-foot {
        margin: 14px 0 0; text-align: center;
        font-family: var(--cnf-mono); font-size: 11px; letter-spacing: 0.04em;
        text-transform: uppercase; color: var(--cnf-ink-soft);
      }
      @keyframes cnf-gal-rise {
        from { opacity: 0; transform: translateY(16px) scale(0.985); }
        to { opacity: 1; transform: translateY(0) scale(1); }
      }

      /* Gallery lightbox */
      .cnf-lb {
        position: fixed; inset: 0; z-index: 1000;
        display: flex; align-items: center; justify-content: center;
        padding: 28px;
        background: rgba(20, 18, 12, 0.94);
        backdrop-filter: blur(10px) saturate(115%);
        -webkit-backdrop-filter: blur(10px) saturate(115%);
        animation: cnf-lb-fade 0.22s ease both;
      }
      @keyframes cnf-lb-fade { from { opacity: 0; } to { opacity: 1; } }
      .cnf-lb-fig {
        margin: 0; display: flex; flex-direction: column; gap: 16px;
        max-width: min(1080px, 92vw); align-items: center;
        animation: cnf-lb-rise 0.32s cubic-bezier(0.22, 0.85, 0.24, 1) both;
      }
      @keyframes cnf-lb-rise { from { opacity: 0; transform: scale(0.965) translateY(8px); } to { opacity: 1; transform: none; } }
      .cnf-lb-stage {
        border-radius: 14px; overflow: hidden;
        box-shadow: 0 40px 90px -24px rgba(0,0,0,0.7);
        background: var(--cnf-bg-deep); line-height: 0;
      }
      .cnf-lb-fig img {
        display: block; max-width: 100%; max-height: 78vh;
        object-fit: contain;
      }
      .cnf-lb-cap {
        display: flex; align-items: baseline; gap: 16px; flex-wrap: wrap;
        width: 100%; padding: 0 2px;
      }
      .cnf-lb-count {
        font-family: var(--cnf-mono); font-size: 12px; font-weight: 600;
        letter-spacing: 0.12em; color: var(--cnf-gold-text); flex-shrink: 0;
      }
      .cnf-lb-label {
        font-family: var(--cnf-serif); font-style: italic; font-size: 17px;
        line-height: 1.4; color: rgba(244,241,236,0.94);
      }
      .cnf-lb-src {
        margin-left: auto; flex-shrink: 0;
        font-family: var(--cnf-mono); font-size: 11px; letter-spacing: 0.04em;
        color: rgba(244,241,236,0.6);
        border-bottom: 1px dotted rgba(244,241,236,0.35);
      }
      .cnf-lb-src:hover { color: rgba(244,241,236,0.9); }
      .cnf-lb-close, .cnf-lb-nav {
        position: fixed; display: flex; align-items: center; justify-content: center;
        color: #F4F1EC; cursor: pointer;
        background: rgba(244,241,236,0.08);
        border: 1px solid rgba(244,241,236,0.18);
        border-radius: 50%; backdrop-filter: blur(4px);
        transition: background 0.15s ease, transform 0.15s ease, border-color 0.15s ease;
      }
      .cnf-lb-close:hover, .cnf-lb-nav:hover {
        background: rgba(244,241,236,0.2); border-color: rgba(244,241,236,0.4);
      }
      .cnf-lb-close:active, .cnf-lb-nav:active { transform: scale(0.92); }
      .cnf-lb-close { top: 20px; right: 24px; width: 44px; height: 44px; }
      .cnf-lb-nav { top: 50%; transform: translateY(-50%); width: 54px; height: 54px; }
      .cnf-lb-nav:hover { transform: translateY(-50%) scale(1.06); }
      .cnf-lb-nav:active { transform: translateY(-50%) scale(0.94); }
      .cnf-lb-prev { left: 24px; }
      .cnf-lb-next { right: 24px; }
      @media (prefers-reduced-motion: reduce) {
        .cnf-lb, .cnf-lb-fig { animation: none; }
      }

      /* Alumni */
      .cnf-alm-event {
        background: var(--cnf-gold-soft); padding: 12px 16px;
        border-radius: 10px; font-size: 13px; color: var(--cnf-ink);
        margin-bottom: 16px;
      }
      .cnf-alm-event strong { color: var(--cnf-gold-text); margin-right: 6px; }
      .cnf-alm-grid {
        display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
        gap: 10px; margin-bottom: 16px;
      }
      .cnf-alm-card {
        padding: 12px 14px; background: var(--cnf-bg);
        border-radius: 10px; border-left: 3px solid var(--cnf-primary-soft);
      }
      .cnf-alm-name { font-weight: 700; font-size: 13.5px; color: var(--cnf-ink); }
      .cnf-alm-meta {
        font-family: var(--cnf-mono); font-size: 10.5px;
        color: var(--cnf-ink-soft); letter-spacing: 0.04em; margin-top: 3px;
      }
      .cnf-alm-cur { font-size: 12px; color: var(--cnf-ink-mid); margin-top: 4px; line-height: 1.4; }
      .cnf-alm-rank { margin-bottom: 14px; }
      .cnf-alm-portal {
        display: inline-flex; align-items: center; gap: 6px;
        font-family: var(--cnf-mono); font-size: 12px; color: var(--cnf-primary);
        font-weight: 600; letter-spacing: 0.02em;
      }

      /* Leadership */
      .cnf-ldr-grid {
        display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px;
        margin-bottom: 18px;
      }
      .cnf-ldr-grid-sm { grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 10px; }
      .cnf-ldr-sep {
        font-family: var(--cnf-mono); font-size: 11px; letter-spacing: 0.08em;
        text-transform: uppercase; color: var(--cnf-primary); font-weight: 700;
        margin-bottom: 12px; padding-top: 6px;
      }
      .cnf-person {
        display: flex; flex-direction: column; background: var(--cnf-bg);
        border-radius: 10px; overflow: hidden; border: 1px solid var(--cnf-rule);
      }
      .cnf-person .creator-person-media {
        position: relative; aspect-ratio: 1 / 1;
        background: linear-gradient(135deg, var(--cnf-bg-soft), var(--cnf-bg-deep));
        overflow: hidden; flex: none;
      }
      .cnf-person .creator-person-media img {
        width: 100%; height: 100%; object-fit: cover; display: block;
      }
      .cnf-person .creator-person-media.is-fallback { display: none; }
      .cnf-person .creator-person-media.is-fallback img { display: none; }
      .cnf-person-body { padding: 12px; min-width: 0; overflow-wrap: anywhere; }
      .cnf-person-dept {
        font-family: var(--cnf-mono); font-size: 9.5px; letter-spacing: 0.08em;
        text-transform: uppercase; color: var(--cnf-primary); font-weight: 700;
        margin-bottom: 4px; line-height: 1.3;
      }
      .cnf-person-name {
        font-family: var(--cnf-serif); font-weight: 500; font-size: 15px;
        line-height: 1.25; color: var(--cnf-ink);
        font-variation-settings: "opsz" 24;
      }
      .cnf-person-role {
        font-size: 12px; color: var(--cnf-ink-mid); margin-top: 4px;
        line-height: 1.35;
      }
      .cnf-person-meta {
        font-family: var(--cnf-mono); font-size: 10.5px; color: var(--cnf-ink-soft);
        margin-top: 4px; line-height: 1.4; letter-spacing: 0.02em;
      }
      .cnf-person.is-compact .cnf-person-name { font-size: 13px; }
      .cnf-person.is-compact .cnf-person-role { font-size: 11px; }
      .cnf-person.is-compact .cnf-person-meta { font-size: 10px; }

      /* Summary fallback paragraph (used by adapter-fed sections without structured data) */
      .cnf-section-summary {
        font-size: 14px; color: var(--cnf-ink-mid); line-height: 1.65;
        margin: 0; padding: 14px 16px;
        background: var(--cnf-bg); border-radius: 10px;
        font-family: var(--cnf-sans);
      }

      /* Empty-state shown on section pages when the section data is missing */
      .cnf-empty .cnf-empty-body {
        font-size: 15px; color: var(--cnf-ink-mid); line-height: 1.7;
        margin: 0 0 18px; font-family: var(--cnf-sans);
      }
      .cnf-empty .cnf-empty-body strong { color: var(--cnf-ink); font-weight: 600; }
      .cnf-empty-cta { display: flex; gap: 10px; flex-wrap: wrap; }
      .cnf-empty-link {
        display: inline-flex; align-items: center;
        padding: 9px 14px; border-radius: 999px;
        font-family: var(--cnf-sans); font-size: 13px; font-weight: 600;
        color: var(--cnf-ink); background: var(--cnf-bg-soft);
        border: 1px solid var(--cnf-rule-strong);
      }
      .cnf-empty-link:hover { background: var(--cnf-bg-deep); }
      .cnf-empty-wa {
        display: inline-flex; align-items: center; gap: 6px;
        padding: 9px 14px; border-radius: 999px;
        font-family: var(--cnf-sans); font-size: 13px; font-weight: 600;
        color: #fff; background: #1FA259;
      }
      .cnf-empty-wa:hover { background: #168548; }

      /* Sources card */
      .cnf-src p { font-size: 13.5px; color: var(--cnf-ink-mid); line-height: 1.65; margin: 0 0 10px; }
      .cnf-src strong { color: var(--cnf-ink); }
      .cnf-src-meta { font-family: var(--cnf-mono); font-size: 11.5px !important; color: var(--cnf-ink-soft) !important; letter-spacing: 0.02em; }
      .cnf-src-list { margin: 4px 0 12px; padding-left: 18px; display: grid; gap: 6px; }
      .cnf-src-list li { font-size: 12.5px; color: var(--cnf-ink-mid); line-height: 1.5; }
      .cnf-src-list .cnf-cite { margin-top: 0; }
      .cnf-src-label { opacity: 0.88; }

      /* Source cite link */
      .cnf-cite {
        display: inline-block; margin-top: 12px;
        font-family: var(--cnf-mono); font-size: 11px; color: var(--cnf-primary);
        font-weight: 600; letter-spacing: 0.02em;
        border-bottom: 1px dotted rgba(184,132,58,0.45);
      }
      .cnf-cite::after { content: " ↗"; opacity: 0.7; }

      /* Pill nav fade affordance so user knows it scrolls */
      .cnf-pillnav {
        mask-image: linear-gradient(to right, transparent, #000 16px, #000 calc(100% - 24px), transparent);
        -webkit-mask-image: linear-gradient(to right, transparent, #000 16px, #000 calc(100% - 24px), transparent);
      }

      /* ===== Responsive ===== */
      @media (max-width: 1380px) {
        .cnf-layout {
          grid-template-columns: 220px minmax(0, 1fr) 320px;
          gap: 28px;
        }
      }
      @media (max-width: 1180px) {
        .cnf-layout {
          grid-template-columns: 200px minmax(0, 1fr);
          gap: 24px;
          padding: 20px 0 100px;
        }
        .cnf-rightrail { display: none; }
        .cnf-hero { grid-template-columns: minmax(0, 1fr); }
        /* On mobile/tablet the hero stacks vertically. aspect-ratio derives
           height from width (full grid column), so the media never exceeds
           the column. The earlier min-height + aspect-ratio combo inverted
           that and forced the column to 498px on a 292-wide hero. */
        .cnf-hero-media { aspect-ratio: 16/9; min-height: 0; }
        .cnf-pair { grid-template-columns: minmax(0, 1fr); }
        .cnf-hero-title { font-size: 38px; }
        .cnf-actbar { display: flex; }
        /* Action bar bottom-pinned at 1180px - leave breathing room above it
           so the left rail doesn't get covered. */
        .cnf-leftrail {
          max-height: calc(100vh - var(--cnf-site-header-h) - var(--cnf-topbar-h) - 96px);
        }
      }
      @media (max-width: 767px) {
        /* Mobile: site header is a two-row logo/menu + search layout.
           Topbar's real mobile height is
           ~86px (10px top pad + ~26px row + ~44px pill row + 10px pad + border).
           Keep both vars in sync with scroll-margin-top / rail offsets. */
        .cnf-shell { --cnf-site-header-h: 121px; --cnf-topbar-h: 60px; }
        /* Drop the redundant meta-right on narrow phones - Verified date
           is duplicated on the hero card / Sources section. Prevents the
           text from overlapping the headline label on the left. */
        .cnf-topbar { padding: 6px 12px 0; }
        .cnf-topbar-row { display: none; }
        .cnf-topbar-meta-right { display: none; }
        .cnf-topbar-meta { display: none; }
        .cnf-topbar-short { font-size: 15px; }
        /* Tap-target rule: pills reach 44px tall on touch viewports. */
        .cnf-pill { min-height: 44px; display: inline-flex; align-items: center; padding: 0 12px; }
        .cnf-pillnav { margin: 0 -12px; padding-left: 12px; padding-right: 12px; padding-bottom: 6px; }
      }
      @media (max-width: 1024px) and (min-width: 768px) {
        .cnf-topbar-meta { display: none; }
        .cnf-topbar-meta-right { font-size: 10px; }
      }
      @media (max-width: 840px) {
        .cnf-shell { padding-bottom: 96px; }
        .cnf-layout {
          grid-template-columns: 1fr;
          width: 100%; max-width: none;
          padding: 10px 12px 88px;
          gap: 12px;
        }
        .cnf-main { gap: 12px; }
        .cnf-crumbs { margin: 0; gap: 6px; }
        .cnf-leftrail { display: none; }
        .cnf-topbar { padding: 8px 12px 0; }
        .cnf-pillnav { margin: 0 -12px; padding-left: 12px; padding-right: 12px; padding-bottom: 7px; }
        .cnf-card { padding: 16px 13px; border-radius: 14px; }
        .cnf-card-head { margin-bottom: 14px; }
        .cnf-review { flex-direction: column; }
        .cnf-fact-grid { grid-template-columns: 1fr; }
        .cnf-fact-item, .cnf-fact-item:nth-child(2n), .cnf-fact-item:nth-last-child(-n+2) {
          border-right: 0; border-bottom: 1px solid var(--cnf-rule);
        }
        .cnf-fact-item:last-child { border-bottom: 0; }
        .cnf-hero { border-radius: 16px; }
        .cnf-hero-body { padding: 14px 12px 16px; }
        .cnf-hero-title { font-size: clamp(21px, 6vw, 26px); line-height: 1.18; letter-spacing: -0.03em; }
        .cnf-hero-tagline { font-size: 14px; margin-bottom: 12px; }
        .cnf-hero-badges { margin-bottom: 14px; }
        .cnf-hero-stats { grid-template-columns: repeat(auto-fit, minmax(120px, 1fr)); gap: 10px; padding-top: 14px; }
        .cnf-hero-answer-top { padding: 11px 12px 9px; }
        .cnf-hero-answer-foot { padding: 8px 12px; }
        .cnf-fee-banner-amt { font-size: 44px; }
        /* Mobile-first full-bleed: section cards that wrap colored panels and
           tables drop their horizontal frame, so each child owns ONE 14px
           gutter instead of stacking card padding + panel padding (was ~39px
           to text). No negative margins - the panels simply span the card. */
        .cnf-mq:not(.cnf-mq-na),
        .cnf-fees { padding-left: 0; padding-right: 0; }
        .cnf-mq:not(.cnf-mq-na) > *,
        .cnf-fees > * { padding-left: 14px; padding-right: 14px; }
        .cnf-fee-banner { padding-top: 18px; padding-bottom: 18px; }
        .cnf-mq-banner { padding-top: 18px; padding-bottom: 18px; }
        .cnf-mq-banner-title { font-size: 24px; }
        .cnf-mq-answer { padding-top: 14px; padding-bottom: 14px; }
        .cnf-mq-tier { grid-template-columns: 1fr; gap: 12px; }
        .cnf-mq-tier-r { text-align: left; padding-left: 44px; }
        .cnf-mq-route-grid { grid-template-columns: 1fr; }
        .cnf-mq-cta { flex-direction: column; align-items: flex-start; }
        .cnf-pl-headline { grid-template-columns: 1fr; gap: 16px; }
        .cnf-pl-pct span { font-size: 64px; }
        .cnf-pl-branch-row { grid-template-columns: 1fr; gap: 4px; }
        .cnf-pl-branch-metrics { text-align: left; }
        .cnf-prog-row { grid-template-columns: 1fr; gap: 10px; }
        .cnf-prog-row-r { justify-content: flex-start; gap: 18px; }
        .cnf-prog-stat { text-align: left; }
        .cnf-cut-head, .cnf-cut-row { grid-template-columns: minmax(0, 1.2fr) repeat(3, minmax(0, 0.9fr)); gap: 8px; font-size: 12px; padding: 9px 11px; }
        /* Wide 5-col multi-exam table: do NOT crush to 11px - give it a min-width
           inside .cnf-cut-scroll so columns keep ~13px and stay legible, with a
           sticky Branch column + sticky header for orientation while scrolling. */
        .cnf-cut-grid--scroll { min-width: 540px; }
        .cnf-cut-head--full, .cnf-cut-row--full { grid-template-columns: minmax(0, 1.7fr) minmax(0, 0.95fr) minmax(0, 1fr) minmax(0, 1fr) minmax(0, 1fr); gap: 10px; font-size: 12.5px; padding: 9px 11px; }
        .cnf-cut-grid--scroll .cnf-cut-head { position: sticky; top: 0; z-index: 2; }
        .cnf-cut-grid--scroll .cnf-cut-branch,
        .cnf-cut-grid--scroll .cnf-cut-head--full > span:first-child {
          position: sticky; left: 0; z-index: 1; background: var(--cnf-card);
          padding-right: 10px; box-shadow: 1px 0 0 var(--cnf-rule);
        }
        .cnf-cut-grid--scroll .cnf-cut-head--full > span:first-child { background: var(--cnf-bg); }
        .cnf-cut-row .is-strong { font-size: 14px; }
        .cnf-adm-grid { grid-template-columns: 1fr; gap: 14px; }
        .cnf-inf-grid { grid-template-columns: repeat(2, 1fr); }
        .cnf-gal-wrap { gap: 8px; }
        .cnf-gal-grid { grid-template-columns: repeat(3, 1fr); gap: 8px; }
        .cnf-photo-feat { aspect-ratio: 16 / 11; }
        .cnf-gal-head { margin-bottom: 14px; }
        .cnf-ldr-grid { grid-template-columns: repeat(2, 1fr); }
        /* Lightbox on phones: swipe to browse; arrows drop to bottom corners
           so they never sit on top of the image, and the image leaves room. */
        .cnf-lb { padding: 14px; }
        .cnf-lb-fig { gap: 12px; max-width: 100%; }
        .cnf-lb-fig img { max-height: 68vh; }
        .cnf-lb-cap { justify-content: center; text-align: center; gap: 10px; }
        .cnf-lb-label { font-size: 15px; }
        .cnf-lb-src { margin-left: 0; }
        .cnf-lb-close { top: 14px; right: 14px; width: 40px; height: 40px; }
        .cnf-lb-nav { top: auto; bottom: 18px; transform: none; width: 46px; height: 46px; }
        .cnf-lb-nav:hover { transform: none; }
        .cnf-lb-nav:active { transform: scale(0.94); }
        .cnf-lb-prev { left: 18px; }
        .cnf-lb-next { right: 18px; }
      }
      @media (max-width: 480px) {
        .cnf-inf-grid { grid-template-columns: 1fr; }
        .cnf-hos-grid { grid-template-columns: repeat(2, 1fr); }
      }
      @media (prefers-reduced-motion: reduce) {
        .cnf-photo { animation: none; }
        .cnf-photo:hover { transform: none; }
        .cnf-photo:hover img { transform: none; }
        .cnf-pillnav { scroll-behavior: auto; }
        /* Honour reduced-motion: the topbar still hides/reveals (JS toggles the
           class) but without the slide animation. */
        .cnf-topbar { transition: none; }
      }
