/* ============================================================
   deslop.media · Citation feed — SCOPED styling.
   The live ClaimReview citation feed, namespaced under `.citefeed`
   so it can live inside Decomposition v3 (§04 Sources) without
   colliding with the page chrome or the side drawer. Tokens come
   from deslop-tokens.css / pyramid.css (already loaded by the host).
   Keyframes are renamed (cf-*) to avoid global clashes.
   ============================================================ */

.citefeed { --pos-si-hatch: rgba(138,143,152,0.20); margin-top: 30px; }

/* live strip */
.citefeed .live { display: flex; flex-wrap: wrap; align-items: center; gap: 10px 18px; font-family: var(--font-mono); font-size: 10.5px; letter-spacing: .07em; text-transform: uppercase; color: var(--color-text-tertiary); }
.citefeed .live__dot { width: 7px; height: 7px; border-radius: 50%; background: var(--color-volt); box-shadow: 0 0 0 0 rgba(206,255,0,.5); animation: cf-pulse 2.4s var(--ease) infinite; }
@keyframes cf-pulse { 0% { box-shadow: 0 0 0 0 rgba(206,255,0,.45); } 70% { box-shadow: 0 0 0 6px rgba(206,255,0,0); } 100% { box-shadow: 0 0 0 0 rgba(206,255,0,0); } }
.citefeed .live b { color: var(--color-text-secondary); font-weight: 500; }
.citefeed .live .vt { color: var(--color-volt); }
.citefeed .live .cr { color: var(--coral); }
.citefeed .live .sil { color: var(--color-text-secondary); position: relative; padding-left: 16px; }
.citefeed .live .sil::before { content: ""; position: absolute; left: 0; top: 50%; transform: translateY(-50%); width: 11px; height: 9px; background-image: repeating-linear-gradient(45deg, var(--pos-si-hatch) 0 1px, transparent 1px 4px); border: 1px solid var(--color-border); }

/* honesty banner */
.citefeed .honesty { margin-top: 20px; border: 1px solid var(--color-border); border-left: 2px solid var(--color-agent-gated); border-radius: var(--radius-md); padding: 12px 16px; font-size: 12.5px; line-height: 1.6; color: var(--color-text-secondary); max-width: 820px; }
.citefeed .honesty b { color: var(--color-text); font-weight: 500; }
.citefeed .honesty .pf { font-family: var(--font-mono); font-size: 9px; letter-spacing: .12em; text-transform: uppercase; color: var(--color-agent-gated); }

/* matrix-anchor strip */
.citefeed .anchor { margin-top: 26px; border: 1px solid var(--color-border); border-radius: var(--radius-lg); padding: 16px 18px; background: linear-gradient(180deg, rgba(26,34,48,.5), rgba(26,34,48,.15)); }
.citefeed .anchor__hd { display: flex; align-items: baseline; justify-content: space-between; gap: 12px; flex-wrap: wrap; }
.citefeed .anchor__lbl { font-family: var(--font-mono); font-size: 10px; font-weight: 600; letter-spacing: .12em; text-transform: uppercase; color: var(--color-text-secondary); }
.citefeed .anchor__note { font-size: 11.5px; color: var(--color-text-tertiary); line-height: 1.5; max-width: 60ch; }
.citefeed .anchor__cells { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 13px; }
.citefeed .lcell { display: inline-flex; align-items: center; gap: 8px; border: 1px solid var(--color-border); background: var(--color-surface); border-radius: var(--radius-sm); padding: 6px 9px 6px 7px; cursor: pointer; font-family: var(--font-mono); font-size: 10.5px; color: var(--color-text-secondary); transition: border-color var(--dur-fast) var(--ease), color var(--dur-fast) var(--ease); }
.citefeed .lcell:hover { border-color: var(--color-text-tertiary); color: var(--color-text); }
.citefeed .lcell .sw { width: 9px; height: 9px; border-radius: 1px; flex-shrink: 0; }
.citefeed .lcell .sw.h { background: var(--color-volt); }
.citefeed .lcell .sw.d { background: var(--coral); }
.citefeed .lcell .sw.s { background-image: repeating-linear-gradient(45deg, var(--pos-si-hatch) 0 1px, transparent 1px 4px); border: 1px solid var(--color-border); }
.citefeed .lcell .ref { color: var(--color-text-tertiary); }
.citefeed .lcell.is-silent { cursor: default; opacity: .72; }
.citefeed .lcell.is-silent:hover { border-color: var(--color-border); color: var(--color-text-secondary); }

/* controls bar (non-sticky inside the host page) */
.citefeed .controls { margin-top: 26px; padding: 13px 0; display: flex; flex-wrap: wrap; align-items: center; gap: 14px 22px; border-top: 1px solid var(--color-border-subtle); border-bottom: 1px solid var(--color-border-subtle); }
.citefeed .ctl { display: flex; align-items: center; gap: 9px; }
.citefeed .ctl__lbl { font-family: var(--font-mono); font-size: 9.5px; font-weight: 600; letter-spacing: .12em; text-transform: uppercase; color: var(--color-text-tertiary); }
.citefeed .seg { display: inline-flex; border: 1px solid var(--color-border); border-radius: var(--radius-sm); overflow: hidden; background: var(--color-surface); }
.citefeed .seg button { appearance: none; border: none; background: transparent; color: var(--color-text-secondary); font-family: var(--font-mono); font-size: 11px; letter-spacing: .02em; padding: 6px 12px; cursor: pointer; border-right: 1px solid var(--color-border); transition: background var(--dur-fast) var(--ease), color var(--dur-fast) var(--ease); white-space: nowrap; }
.citefeed .seg button:last-child { border-right: none; }
.citefeed .seg button:hover { color: var(--color-text); }
.citefeed .seg button[data-on="1"] { background: rgba(206,255,0,.10); color: var(--color-text); }
.citefeed .seg button[data-stance="hold"][data-on="1"] { box-shadow: inset 0 -2px 0 0 var(--color-volt); color: var(--color-volt); background: rgba(206,255,0,.08); }
.citefeed .seg button[data-stance="deny"][data-on="1"] { box-shadow: inset 0 -2px 0 0 var(--coral); color: var(--coral); background: rgba(217,100,110,.08); }
.citefeed .count { margin-left: auto; font-family: var(--font-mono); font-size: 10.5px; letter-spacing: .05em; color: var(--color-text-tertiary); }
.citefeed .count b { color: var(--color-text-secondary); font-weight: 500; }

/* feed groups */
.citefeed .feed { margin-top: 8px; }
.citefeed .grp { margin-top: 38px; }
.citefeed .grp:first-child { margin-top: 18px; }
.citefeed .grp__con { display: flex; align-items: center; gap: 12px; margin-bottom: 20px; }
.citefeed .grp__con-n { font-family: var(--font-mono); font-size: 11px; font-weight: 600; letter-spacing: .12em; color: var(--color-text); background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-sm); padding: 4px 9px; }
.citefeed .grp__con-nm { font-family: var(--font-editorial); font-size: 17px; font-weight: 600; letter-spacing: -.02em; color: var(--color-text); }
.citefeed .grp__con-rule { flex: 1; height: 1px; background: var(--color-border-subtle); }
.citefeed .grp__con-c { font-family: var(--font-mono); font-size: 9.5px; letter-spacing: .08em; text-transform: uppercase; color: var(--color-text-tertiary); }

.citefeed .qgrp { margin: 0 0 22px; }
.citefeed .qgrp__hd { display: flex; align-items: flex-start; gap: 11px; padding: 0 0 12px; }
.citefeed .qchip { flex-shrink: 0; font-family: var(--font-mono); font-size: 11px; font-weight: 600; letter-spacing: .04em; color: var(--color-bg); background: var(--color-text-secondary); border-radius: var(--radius-sm); padding: 3px 7px; line-height: 1.3; margin-top: 2px; }
.citefeed .qgrp__q { font-size: 13.5px; line-height: 1.5; color: var(--color-text-secondary); }
.citefeed .qgrp__q b { color: var(--color-text); font-weight: 500; }

.citefeed .cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(340px, 1fr)); gap: 16px; align-items: start; }

/* card — the ClaimReview atom */
.citefeed .card { position: relative; border: 1px solid var(--color-border); border-radius: var(--radius-lg); background: var(--color-surface); padding: 18px 18px 0; display: flex; flex-direction: column; scroll-margin-top: 96px; overflow: hidden; transition: border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease); }
.citefeed .card::before { content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 3px; }
.citefeed .card.is-hold::before { background: var(--color-volt); }
.citefeed .card.is-deny::before { background: var(--coral); }
.citefeed .card:hover { border-color: var(--color-text-tertiary); }
@keyframes cf-cardflash { 0% { box-shadow: 0 0 0 2px rgba(206,255,0,.55), 0 0 26px -4px rgba(206,255,0,.5); } 100% { box-shadow: 0 0 0 0 rgba(206,255,0,0), 0 0 0 0 rgba(206,255,0,0); } }
.citefeed .card.flash { animation: cf-cardflash 1.9s var(--ease); }

.citefeed .card__top { display: flex; align-items: center; gap: 11px; }
.citefeed .mono-tile { width: 38px; height: 38px; flex-shrink: 0; border-radius: var(--radius-sm); background: linear-gradient(150deg, #222d3d, #161e2a); border: 1px solid var(--color-border); display: flex; align-items: center; justify-content: center; font-family: var(--font-mono); font-size: 13px; font-weight: 600; letter-spacing: .02em; color: var(--color-text-secondary); }
.citefeed .card__who { min-width: 0; flex: 1; }
.citefeed .card__nm { font-family: var(--font-editorial); font-size: 15.5px; font-weight: 700; letter-spacing: -.02em; color: var(--color-text); line-height: 1.2; }
.citefeed .card__role { font-family: var(--font-mono); font-size: 10px; letter-spacing: .03em; color: var(--color-text-tertiary); margin-top: 2px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.citefeed .pill { flex-shrink: 0; align-self: flex-start; font-family: var(--font-mono); font-size: 9px; font-weight: 600; letter-spacing: .11em; text-transform: uppercase; border-radius: 999px; padding: 4px 9px; border: 1px solid; }
.citefeed .pill.h { color: var(--color-volt); border-color: rgba(206,255,0,.4); background: rgba(206,255,0,.08); }
.citefeed .pill.d { color: var(--coral); border-color: rgba(217,100,110,.45); background: rgba(217,100,110,.10); }

.citefeed .quote { font-family: var(--font-editorial); font-weight: 600; letter-spacing: -.02em; font-size: 19px; line-height: 1.32; color: var(--color-text); margin: 15px 0 0; text-wrap: pretty; }
.citefeed .quote .qm { color: var(--color-text-tertiary); font-weight: 700; }
.citefeed .flag { display: inline-block; margin-left: 6px; font-family: var(--font-mono); font-size: 9px; font-weight: 600; letter-spacing: .06em; color: var(--color-agent-gated); border: 1px solid rgba(167,139,250,.4); border-radius: 3px; padding: 1px 5px; vertical-align: middle; cursor: help; text-transform: uppercase; }

.citefeed .read { margin-top: 15px; font-size: 13px; line-height: 1.55; color: var(--color-text-secondary); }
.citefeed .read .org { color: var(--color-text); font-weight: 500; }
.citefeed .read .verb { font-weight: 600; }
.citefeed .read .verb.h { color: var(--color-volt); }
.citefeed .read .verb.d { color: var(--coral); }
.citefeed .read .qref { font-family: var(--font-mono); font-size: 11px; color: var(--color-text); background: rgba(138,143,152,.16); border-radius: 3px; padding: 1px 5px; }
.citefeed .read .pred { color: var(--color-text-secondary); }

.citefeed .clause { margin-top: 11px; display: flex; gap: 8px; align-items: flex-start; font-size: 11.5px; line-height: 1.5; color: var(--color-text-tertiary); border: 1px dashed var(--color-border); border-radius: var(--radius-sm); padding: 8px 10px; }
.citefeed .clause .ic { font-family: var(--font-mono); color: var(--color-agent-gated); font-size: 11px; flex-shrink: 0; }

.citefeed .resolve { margin-top: 13px; font-family: var(--font-mono); font-size: 10.5px; line-height: 1.55; color: var(--color-text-tertiary); }
.citefeed .resolve b { color: var(--color-text-secondary); font-weight: 500; letter-spacing: .04em; }

.citefeed .alsob { margin-top: 11px; font-family: var(--font-mono); font-size: 10px; letter-spacing: .02em; color: var(--color-text-tertiary); display: flex; flex-wrap: wrap; gap: 6px; align-items: center; }
.citefeed .alsob .ab { color: var(--color-text-secondary); background: rgba(138,143,152,.12); border-radius: 3px; padding: 1px 5px; cursor: pointer; }
.citefeed .alsob .ab:hover { color: var(--color-text); }

/* ClaimReview source bar */
.citefeed .crbar { margin: 15px -18px 0; padding: 11px 18px; border-top: 1px solid var(--color-border-subtle); background: rgba(16,24,32,.4); display: flex; flex-wrap: wrap; align-items: center; gap: 8px 10px; line-height: 1.5; font-family: var(--font-mono); font-size: 10px; letter-spacing: .02em; color: var(--color-text-tertiary); }
.citefeed .crbar > * { white-space: nowrap; }
.citefeed .crbar .v { color: var(--color-text-secondary); white-space: normal; }
.citefeed .crbar .dot { color: var(--color-border); }
.citefeed .crbar a { color: var(--color-text-secondary); border-bottom: 1px solid transparent; }
.citefeed .crbar a:hover { color: var(--color-volt); border-bottom-color: var(--color-volt); }
.citefeed .crbar .chk { display: inline-flex; align-items: center; gap: 5px; }
.citefeed .crbar .chk::before { content: ""; width: 5px; height: 5px; border-radius: 50%; background: var(--color-volt); opacity: .7; }
.citefeed .crbar .arc { color: var(--color-agent-gated); }
.citefeed .crbar .arc:hover { color: var(--color-agent-gated); border-bottom-color: var(--color-agent-gated); }

/* drawer toggle + body (card-local, NOT the side panel) */
.citefeed .card__more { margin-top: auto; }
.citefeed .more-btn { width: calc(100% + 36px); margin: 0 -18px; appearance: none; border: none; border-top: 1px solid var(--color-border-subtle); background: transparent; color: var(--color-text-tertiary); font-family: var(--font-mono); font-size: 10px; letter-spacing: .1em; text-transform: uppercase; padding: 10px 0; cursor: pointer; transition: color var(--dur-fast) var(--ease), background var(--dur-fast) var(--ease); }
.citefeed .more-btn:hover { color: var(--color-text-secondary); background: rgba(138,143,152,.05); }
.citefeed .more-btn .cv { display: inline-block; transition: transform var(--dur) var(--ease); }
.citefeed .card.open .more-btn .cv { transform: rotate(90deg); }
.citefeed .card .drawer { max-height: 0; overflow: hidden; transition: max-height .4s var(--ease); margin: 0 -18px; position: static; width: auto; background: none; border: none; box-shadow: none; transform: none; z-index: auto; }
.citefeed .card.open .drawer { max-height: 640px; }
.citefeed .drawer__in { padding: 4px 18px 16px; border-top: 1px solid var(--color-border-subtle); }
.citefeed .dsec { padding: 12px 0; border-bottom: 1px solid var(--color-border-subtle); }
.citefeed .dsec:last-child { border-bottom: none; }
.citefeed .dsec__l { font-family: var(--font-mono); font-size: 9px; font-weight: 600; letter-spacing: .12em; text-transform: uppercase; color: var(--color-text-tertiary); margin-bottom: 7px; }
.citefeed .dsec__p { font-size: 12px; line-height: 1.6; color: var(--color-text-secondary); }
.citefeed .dsec__p b { color: var(--color-text); font-weight: 500; }
.citefeed .excerpt { font-size: 12.5px; line-height: 1.66; color: var(--color-text-secondary); border-left: 2px solid var(--color-border); padding-left: 13px; }
.citefeed .excerpt .hl { color: var(--color-text); background: rgba(206,255,0,.08); box-shadow: inset 0 -1px 0 rgba(206,255,0,.3); }
.citefeed .prov-split { display: flex; gap: 18px; }
.citefeed .prov-split .pc { display: flex; flex-direction: column; gap: 2px; }
.citefeed .prov-split .pc b { font-family: var(--font-mono); font-size: 16px; font-weight: 500; color: var(--color-text); }
.citefeed .prov-split .pc.zero b { color: var(--color-text-tertiary); }
.citefeed .prov-split .pc span { font-family: var(--font-mono); font-size: 8.5px; letter-spacing: .08em; text-transform: uppercase; color: var(--color-text-tertiary); }

/* load more / end / empty */
.citefeed .loadmore { margin-top: 40px; display: flex; justify-content: center; }
.citefeed .loadmore button { appearance: none; border: 1px solid var(--color-border); background: var(--color-surface); color: var(--color-text-secondary); font-family: var(--font-mono); font-size: 11px; letter-spacing: .08em; text-transform: uppercase; padding: 12px 26px; border-radius: var(--radius-sm); cursor: pointer; transition: border-color var(--dur-fast) var(--ease), color var(--dur-fast) var(--ease); }
.citefeed .loadmore button:hover { border-color: var(--color-text-tertiary); color: var(--color-text); }
.citefeed .loadmore button .n { color: var(--color-text-tertiary); }
/* infinite-scroll sentinel (Twitter-style auto-load) + neutral spinner */
.citefeed .feed-sentinel { margin-top: 32px; min-height: 44px; display: flex; align-items: center; justify-content: center; gap: 10px; }
.citefeed .feed-spin { width: 13px; height: 13px; flex: 0 0 auto; border-radius: 50%; border: 2px solid var(--color-border); border-top-color: var(--color-text-secondary); animation: cf-spin .7s linear infinite; }
.citefeed .feed-loading { font-family: var(--font-mono); font-size: 10px; letter-spacing: .1em; text-transform: uppercase; color: var(--color-text-tertiary); }
.citefeed .feed-more-btn { appearance: none; border: 1px solid var(--color-border); background: var(--color-surface); color: var(--color-text-secondary); font-family: var(--font-mono); font-size: 11px; letter-spacing: .08em; text-transform: uppercase; padding: 12px 26px; border-radius: var(--radius-sm); cursor: pointer; transition: border-color var(--dur-fast) var(--ease), color var(--dur-fast) var(--ease); }
.citefeed .feed-more-btn:hover { border-color: var(--color-text-tertiary); color: var(--color-text); }
@keyframes cf-spin { to { transform: rotate(360deg); } }
@media (prefers-reduced-motion: reduce) { .citefeed .feed-spin { animation: none; border-top-color: var(--color-border); } }
.citefeed .feed-end { margin-top: 40px; text-align: center; font-family: var(--font-mono); font-size: 10px; letter-spacing: .1em; text-transform: uppercase; color: var(--color-text-tertiary); }
.citefeed .empty { margin-top: 40px; text-align: center; font-size: 13px; color: var(--color-text-tertiary); padding: 40px 0; }

/* toast for anchor jumps */
.citefeed .toast { position: fixed; left: 50%; bottom: 26px; transform: translateX(-50%) translateY(20px); z-index: 100; background: #131b26; border: 1px solid var(--color-border); border-left: 3px solid var(--color-volt); border-radius: var(--radius-md); padding: 10px 16px; font-family: var(--font-mono); font-size: 11px; color: var(--color-text-secondary); box-shadow: 0 18px 50px -20px rgba(0,0,0,.8); opacity: 0; pointer-events: none; transition: opacity var(--dur) var(--ease), transform var(--dur) var(--ease); }
.citefeed .toast.show { opacity: 1; transform: translateX(-50%) translateY(0); }
.citefeed .toast b { color: var(--color-text); font-weight: 500; }

@media (max-width: 640px) {
  .citefeed .cards { grid-template-columns: 1fr; }
  .citefeed .quote { font-size: 17px; }
  .citefeed .controls { gap: 10px 16px; }
}
@media (prefers-reduced-motion: reduce) {
  .citefeed .live__dot, .citefeed .card.flash { animation: none !important; }
  .citefeed .card .drawer, .citefeed .toast, .citefeed .more-btn .cv { transition: none !important; }
}
