/* ============================================================
   regulatory-intelligence.css — Direction B ('Editorial Brief')
   Source of truth: design_handoff_regulatory_intelligence/ (committed bundle).
   Page-scoped styles for the Regulatory Intelligence tab: .ri-* (shared: tape,
   notice, head, tabs, filterbar) + .riB-* (Direction-B layout). Extracted from
   the handoff's regint.css — prototype shell (.mlro-*) and the unused A/C/D
   directions are NOT carried over.
   Tokens: colours come from main.css (:root) — same design system. The block
   below adds ONLY the tokens the handoff defines that main.css lacks (hero
   gradient, radii, shadows, font aliases, neutrals). Never redefine a token
   main.css already owns (collision-checked 4 Jun 2026).
   Fonts: IBM Plex Sans + Mono load via the Google Fonts link in index.html —
   the same pattern the SAR portal uses (self-hosted ttfs remain in the design
   bundle as a fallback reference).
   ============================================================ */

:root {
  /* RI Direction-B token additions (from the handoff tokens.css) */
  --hero-1: #020e0a;
  --hero-2: #011a14;
  --hero-3: #021007;
  --border-faint: #eef0f2;
  --font-display: 'IBM Plex Sans', system-ui, sans-serif;
  --font-body: 'IBM Plex Sans', system-ui, sans-serif;
  --font-mono: 'IBM Plex Mono', ui-monospace, monospace;
  --r-xs: 4px;
  --r-sm: 6px;
  --r-md: 8px;
  --r-lg: 10px;
  --shadow-card: 0 2px 8px rgba(0,0,0,0.06);
  --ring-focus: 0 0 0 3px rgba(1,82,47,0.12);
  --ri-tape-dur: 60s;
}

/* Respect reduced-motion: freeze the tape + blinking dots (README requirement;
   the prototype lacked this). */
@media (prefers-reduced-motion: reduce) {
  .ri-tape-track { animation: none !important; }
  .ri-blink, .ri-live-dot { animation: none !important; }
}

@keyframes blink { 50% { opacity: 0; } }

/* ── LIVE TAPE (refined ticker) ── */
.ri-tape {
  display: flex; align-items: stretch;
  background: linear-gradient(90deg, var(--hero-1), var(--hero-2) 60%, var(--hero-3));
  border-bottom: 1px solid rgba(0,196,113,0.16);
  height: 34px; overflow: hidden;
  position: sticky; top: 0; z-index: 9;
}

.ri-tape-label {
  display: flex; align-items: center; gap: 7px;
  flex-shrink: 0;
  padding: 0 16px;
  font-family: var(--font-mono);
  font-size: 9.5px; font-weight: 700;
  letter-spacing: 0.16em;
  color: var(--live);
  background: rgba(0,196,113,0.06);
  border-right: 1px solid rgba(0,196,113,0.18);
}

.ri-tape-livedot {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--live);
  box-shadow: 0 0 8px var(--live);
  animation: lv3-pulse 2s ease-in-out infinite;
}

.ri-tape-track { flex: 1; overflow: hidden; position: relative; display: flex; align-items: center; }

.ri-tape-track::after {
  content: ''; position: absolute; right: 0; top: 0; bottom: 0; width: 80px;
  background: linear-gradient(90deg, transparent, var(--hero-3));
  pointer-events: none;
}

.ri-tape-scroll {
  display: flex; align-items: center;
  white-space: nowrap;
  animation: ri-tape-scroll var(--ri-tape-dur, 60s) linear infinite;
}

.ri-tape:hover .ri-tape-scroll { animation-play-state: paused; }

@keyframes ri-tape-scroll { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* Tape items render as <button> for keyboard access (the prototype used divs)
   — strip the UA button chrome or each item shows as a grey outset pill. */
.ri-tape-item {
  display: inline-flex; align-items: center; gap: 9px; padding: 0 4px;
  background: none; border: 0; color: inherit; font: inherit; cursor: pointer;
}

.ri-tape-src {
  font-family: var(--font-mono); font-size: 9px; font-weight: 700;
  letter-spacing: 0.08em; color: rgba(255,255,255,0.5);
}

.ri-tape-tag {
  font-family: var(--font-mono); font-size: 8.5px; font-weight: 700;
  letter-spacing: 0.1em;
  padding: 2px 6px; border-radius: 3px;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.10);
}

.ri-tape-tag.tone-red    { color: #f87171; border-color: rgba(248,113,113,0.3); }

.ri-tape-tag.tone-amber  { color: #f5b97e; border-color: rgba(245,185,126,0.3); }

.ri-tape-tag.tone-forest { color: var(--live); border-color: rgba(0,196,113,0.3); }

.ri-tape-tag.tone-slate  { color: rgba(255,255,255,0.7); }

.ri-tape-text { font-family: var(--font-body); font-size: 11.5px; color: rgba(255,255,255,0.9); }

.ri-tape-time {
  font-family: var(--font-mono); font-size: 9.5px;
  color: var(--live); letter-spacing: 0.04em;
}

.ri-tape-div { width: 1px; height: 14px; background: rgba(255,255,255,0.12); margin: 0 10px; }

/* ── AI summaries notice (subtle inline strip) ── */
.ri-notice {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 28px;
  background: var(--amber-pale);
  border-bottom: 1px solid rgba(217,119,6,0.16);
  font-size: 11px; color: var(--slate);
}

.ri-notice svg { color: var(--amber); flex-shrink: 0; }

.ri-notice b { color: var(--charcoal); font-weight: 700; }

.ri-notice .ri-notice-link {
  margin-left: auto; color: var(--amber); font-weight: 600;
  font-family: var(--font-mono); font-size: 9.5px; letter-spacing: 0.08em;
  text-transform: uppercase; cursor: pointer; white-space: nowrap;
}

.ri-head {
  display: flex; align-items: flex-end; justify-content: space-between;
  padding: 20px 28px 14px;
}

.ri-head-titles { display: flex; align-items: center; gap: 12px; }

.ri-head h1 {
  font-family: var(--font-display);
  font-size: 22px; font-weight: 700; letter-spacing: -0.025em;
  margin: 0; color: var(--charcoal);
}

.ri-count {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--font-mono); font-size: 10px; font-weight: 600;
  letter-spacing: 0.06em; color: var(--forest);
  background: var(--forest-pale); border: 1px solid var(--forest-pale2);
  padding: 4px 10px; border-radius: 100px;
}

.ri-count .ri-count-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--live); box-shadow: 0 0 6px var(--live); }

.ri-head-right { display: flex; align-items: center; gap: 14px; }

.ri-updated {
  font-family: var(--font-mono); font-size: 9.5px; letter-spacing: 0.06em;
  text-transform: uppercase; color: var(--mid);
  display: flex; align-items: center; gap: 6px;
}

.ri-updated .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--mid); }

.ri-tab {
  font-family: var(--font-body); font-size: 11.5px; font-weight: 600;
  padding: 7px 14px; border-radius: 100px;
  background: var(--card); border: 1px solid var(--border2);
  color: var(--mid); cursor: pointer;
  transition: background .15s, color .15s, border-color .15s;
  display: inline-flex; align-items: center; gap: 7px;
}

.ri-tab:hover { color: var(--forest); border-color: var(--forest); }

.ri-tab.is-active { background: var(--forest); border-color: var(--forest); color: #fff; }

.ri-tab .ri-tab-n {
  font-family: var(--font-mono); font-size: 9px; font-weight: 700;
  opacity: 0.7; font-variant-numeric: tabular-nums;
}

/* rectangular tab variant (Direction B) */
/* ── Filter / tab bar ── */
.ri-tabs { display: flex; gap: 7px; flex-wrap: wrap; }

.ri-tabs-rect .ri-tab { border-radius: var(--r-xs); }

.ri-filterbar {
  display: flex; align-items: flex-end; gap: 14px; flex-wrap: wrap;
  background: var(--card); border: 1px solid var(--border2);
  border-radius: var(--r-md);
  padding: 14px 16px;
  margin: 0 28px;
}

.ri-field { display: flex; flex-direction: column; gap: 5px; }

.ri-field > label {
  font-family: var(--font-mono); font-size: 8px; font-weight: 600;
  letter-spacing: 0.14em; text-transform: uppercase; color: var(--mid);
}

.ri-select, .ri-input, .ri-date {
  height: 34px; padding: 0 10px;
  border: 1px solid var(--border2); border-radius: var(--r-sm);
  background: var(--card); color: var(--charcoal);
  font-family: var(--font-body); font-size: 11.5px;
  outline: none; transition: border-color .15s, box-shadow .15s;
}

.ri-select { padding-right: 28px; cursor: pointer; appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%235a6b82' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 9px center;
}

.ri-input::placeholder { color: var(--mid); }

.ri-input { min-width: 200px; }

.ri-select:focus, .ri-input:focus, .ri-date:focus { border-color: var(--forest); box-shadow: var(--ring-focus); }

.ri-date { font-family: var(--font-mono); font-size: 11px; color: var(--mid); }

.ri-clear {
  height: 34px; padding: 0 4px; margin-left: auto;
  background: none; border: none; cursor: pointer;
  font-family: var(--font-mono); font-size: 9.5px; font-weight: 600;
  letter-spacing: 0.1em; text-transform: uppercase; color: var(--mid);
  display: inline-flex; align-items: center; gap: 6px;
}

.ri-clear:hover { color: var(--red); }

.ri-attn-toggle {
  height: 34px; padding: 0 12px; cursor: pointer;
  display: inline-flex; align-items: center; gap: 8px;
  border-radius: var(--r-sm); border: 1px solid var(--border2);
  background: var(--card); color: var(--slate);
  font-family: var(--font-body); font-size: 11px; font-weight: 600;
  transition: all .15s;
}

.ri-attn-toggle .ri-sw {
  width: 26px; height: 15px; border-radius: 100px;
  background: var(--border2); position: relative; transition: background .15s;
}

.ri-attn-toggle .ri-sw::after {
  content: ''; position: absolute; top: 2px; left: 2px;
  width: 11px; height: 11px; border-radius: 50%; background: #fff;
  transition: transform .15s; box-shadow: 0 1px 2px rgba(0,0,0,0.2);
}

.ri-attn-toggle.is-on { border-color: var(--forest); color: var(--forest); background: var(--forest-pale); }

.ri-attn-toggle.is-on .ri-sw { background: var(--forest); }

.ri-attn-toggle.is-on .ri-sw::after { transform: translateX(11px); }

.riA-breaking-flag .ri-blink { width: 7px; height: 7px; border-radius: 50%; background: var(--red); animation: blink 1.2s step-end infinite; }

/* ── Lead story ── */
.riB-lead {
  display: grid; grid-template-columns: 1.55fr 1fr; gap: 0;
  border: 1px solid var(--border2); border-radius: var(--r-lg); overflow: hidden;
  background: var(--card);
}

.riB-lead-main { padding: 28px 30px; display: flex; flex-direction: column; }

.riB-lead-cat { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }

.riB-cat-tag {
  font-family: var(--font-mono); font-size: 9px; font-weight: 700;
  letter-spacing: 0.14em; text-transform: uppercase; color: var(--red);
  display: inline-flex; align-items: center; gap: 7px;
}

.riB-cat-tag .ri-blink { width: 7px; height: 7px; border-radius: 50%; background: var(--red); animation: blink 1.2s step-end infinite; }

.riB-lead-main h2 {
  font-family: var(--font-display); font-size: 27px; font-weight: 700;
  letter-spacing: -0.03em; line-height: 1.12; margin: 0 0 14px; color: var(--charcoal);
  text-wrap: balance;
}

.riB-lead-main p { font-size: 13px; line-height: 1.6; color: var(--slate); margin: 0; max-width: 560px; }

.riB-lead-foot { display: flex; align-items: center; gap: 16px; margin-top: auto; padding-top: 22px; }

.riB-lead-side {
  background: linear-gradient(160deg, var(--hero-1), var(--hero-2) 70%, var(--hero-3));
  color: #fff; padding: 26px 26px; display: flex; flex-direction: column; gap: 14px;
}

.riB-lead-side-h {
  font-family: var(--font-mono); font-size: 9px; font-weight: 700;
  letter-spacing: 0.16em; text-transform: uppercase; color: var(--live);
}

.riB-lead-detail { display: flex; flex-direction: column; gap: 3px; }

.riB-lead-detail .k { font-family: var(--font-mono); font-size: 8.5px; letter-spacing: 0.1em; text-transform: uppercase; color: rgba(255,255,255,0.45); }

.riB-lead-detail .v { font-size: 12.5px; font-weight: 600; color: #fff; }

.riB-lead-detail .v.amber { color: #f5b97e; }

.riB-lead-side .ri-spacer { flex: 1; }

.riB-lead-cta {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  background: rgba(0,196,113,0.14); border: 1px solid rgba(0,196,113,0.3); color: var(--live);
  padding: 10px 14px; border-radius: var(--r-sm); cursor: pointer;
  font-family: var(--font-body); font-size: 11.5px; font-weight: 600;
}

.riB-lead-cta:hover { background: rgba(0,196,113,0.2); }

/* ── Day section head ── */
.riB-section-head { display: flex; align-items: center; gap: 12px; margin-bottom: 2px; }

.riB-section-head .lbl {
  font-family: var(--font-mono); font-size: 10px; font-weight: 700;
  letter-spacing: 0.14em; text-transform: uppercase; color: var(--slate);
}

.riB-section-head .rule { flex: 1; height: 1px; background: var(--border2); }

.riB-section-head .n { font-family: var(--font-mono); font-size: 9.5px; color: var(--mid); }

.riB-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-top: 12px; }

.riB-card {
  display: flex; flex-direction: column;
  background: var(--card); border: 1px solid var(--border2); border-radius: var(--r-md);
  padding: 0; overflow: hidden; cursor: pointer; transition: box-shadow .15s, border-color .15s, transform .15s;
}

.riB-card:hover { box-shadow: var(--shadow-card); border-color: #d6dde7; }

.riB-card-rail { height: 3px; width: 100%; }

.riB-card-rail.tone-red { background: var(--red); }

.riB-card-rail.tone-amber { background: var(--amber); }

.riB-card-rail.tone-forest { background: var(--forest); }

.riB-card-rail.tone-slate { background: var(--slate); }

.riB-card-inner { padding: 16px 18px 14px; display: flex; flex-direction: column; gap: 10px; flex: 1; }

.riB-card-top { display: flex; align-items: center; justify-content: space-between; gap: 8px; }

.riB-card-srcs { display: flex; align-items: center; gap: 7px; }

.riB-src-chip {
  font-family: var(--font-mono); font-size: 9px; font-weight: 700;
  letter-spacing: 0.06em; color: var(--charcoal);
  background: var(--bg); border: 1px solid var(--border2);
  padding: 3px 8px; border-radius: 4px;
}

.riB-out {
  font-family: var(--font-mono); font-size: 8.5px; font-weight: 700;
  letter-spacing: 0.06em; padding: 3px 7px; border-radius: 4px; white-space: nowrap;
}

.riB-out.tone-red { color: var(--red); background: var(--red-pale); }

.riB-out.tone-amber { color: var(--amber); background: var(--amber-pale); }

.riB-out.tone-forest { color: var(--forest); background: var(--forest-pale); }

.riB-out.tone-slate { color: var(--slate); background: rgba(45,63,88,0.07); }

/* Flag action renders as <button> (prototype used a span) — strip UA chrome. */
.riB-card-bm { color: var(--mid); cursor: pointer; display: flex; background: none; border: 0; padding: 0; }

.riB-card-bm:hover { color: var(--forest); }

.riB-card h3 {
  font-family: var(--font-display); font-size: 15px; font-weight: 700;
  letter-spacing: -0.018em; line-height: 1.25; margin: 0; color: var(--charcoal);
  text-wrap: pretty;
}

.riB-card .desc {
  font-size: 11.5px; line-height: 1.5; color: var(--mid); margin: 0;
  display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden;
}

.riB-card-foot {
  display: flex; align-items: center; gap: 10px; margin-top: auto;
  padding: 11px 18px; border-top: 1px solid var(--border-faint); background: var(--bg);
}

.riB-card-date { font-family: var(--font-mono); font-size: 9.5px; color: var(--mid); letter-spacing: 0.04em; }

.riB-card-affects {
  margin-left: auto; font-family: var(--font-mono); font-size: 9px; font-weight: 700;
  letter-spacing: 0.04em; color: var(--amber); display: inline-flex; align-items: center; gap: 5px;
}

.riB-card-affects .d { width: 5px; height: 5px; border-radius: 50%; background: var(--amber); }

.riB-card-ref { font-family: var(--font-mono); font-size: 9px; color: var(--mid); letter-spacing: 0.04em; }

.riB-empty { padding: 60px 20px; text-align: center; color: var(--mid); font-size: 13px; }

.riB-viewall { text-align: center; padding: 6px 0; }

.riB-viewall button {
  font-family: var(--font-body); font-size: 12px; font-weight: 600; color: var(--forest);
  background: none; border: none; cursor: pointer; display: inline-flex; align-items: center; gap: 8px;
}

.riB-viewall button:hover { color: var(--forest-2); }

/* ── Tweak: compact density (root class toggled by Tweaks panel) ── */
.ri-density-compact .ri-filterbar { padding: 10px 14px; }

.ri-density-compact .riA-row,
.ri-density-compact .riA-feed-head { padding-top: 9px; padding-bottom: 9px; }

.ri-density-compact .riA-breaking-inner { padding: 12px 16px; }

.ri-density-compact .riB-grid { gap: 12px; }

.ri-density-compact .riB-card-inner { padding: 12px 14px 10px; }

.ri-density-compact .riB-card-foot { padding: 9px 14px; }

.ri-density-compact .riC-card { padding: 11px 14px; }

.ri-density-compact .riC-item .riC-time { padding-top: 13px; }

.ri-density-compact .riD-li-body { padding: 9px 12px; }

.ri-density-compact .riD-reader-scroll { padding: 18px 24px 16px; }

.ri-density-compact .ri-head { padding: 14px 28px 10px; }

/* ── Tweak: element visibility toggles ── */
.ri-hide-tape .ri-tape { display: none; }

.ri-hide-notice .ri-notice { display: none; }




/* ── Direction-B structural shims (4 Jun 2026) — app-integration rules the
      handoff CSS left to prototype-inline styles. Kept with the .ri-/.riB-
      block; remove alongside it if the design is ever replaced. ─────────── */
.ri-page { padding-bottom: 40px; }
.ri-tabs-wrap { padding: 0 28px 12px; }
.riB-body { padding: 0 28px; }
.ri-field--grow { flex: 1 1 200px; }
a.riB-lead-cta { text-decoration: none; display: inline-flex; align-items: center; justify-content: center; gap: 6px; }
.riB-card { cursor: pointer; }
.riB-card.reg-intel__card--under-review { cursor: default; opacity: .78; }
.riB-card--open .desc { -webkit-line-clamp: unset; max-height: none; }
.riB-card .reg-intel__expanded { margin-top: 12px; border-top: 1px solid var(--border-faint); padding-top: 12px; }
.ri-notice-icon { display: inline-flex; flex-shrink: 0; }

/* ── UX polish (4 Jun 2026): active-filter row, card actions, highlight ── */

/* "Showing N of M" + one removable chip per active facet. */
.ri-active-row { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; padding: 12px 28px 0; }
.ri-active-count {
  font-family: var(--font-mono); font-size: 9.5px; font-weight: 700;
  letter-spacing: 0.12em; text-transform: uppercase; color: var(--mid);
  margin-right: 2px; white-space: nowrap;
}
.ri-active-chip {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 3px 10px;
  background: var(--card); border: 1px solid var(--border2); border-radius: 100px;
  font-family: var(--font-body); font-size: 11px; font-weight: 600; color: var(--slate);
  cursor: pointer; transition: border-color .15s, color .15s;
}
.ri-active-chip:hover { border-color: var(--red); color: var(--red); }
.ri-active-chip .x { font-size: 13px; line-height: 1; color: var(--mid); }
.ri-active-chip:hover .x { color: var(--red); }

/* Card top-right action cluster: flag + open-original. */
.riB-card-acts { display: flex; align-items: center; gap: 10px; flex-shrink: 0; }
a.riB-card-open { color: var(--mid); display: flex; }
a.riB-card-open:hover { color: var(--forest); }

/* Search-term highlight in card/lead titles + summaries. */
mark.ri-hl { background: var(--amber-pale); color: inherit; padding: 0 1px; border-radius: 2px; }

/* ── Daily Round-Up (4 Jun 2026): head button + bulletin modal ── */
.ri-roundup-btn {
  display: inline-flex; align-items: center; gap: 8px;
  height: 34px; padding: 0 14px;
  background: var(--forest); color: #fff;
  border: 1px solid var(--forest); border-radius: var(--r-sm);
  font-family: var(--font-body); font-size: 12px; font-weight: 600;
  cursor: pointer; transition: background .15s;
}
.ri-roundup-btn:hover { background: var(--forest-2); }

.ri-digest-backdrop {
  position: fixed; inset: 0; z-index: 60;
  background: rgba(2, 14, 10, 0.55);
  display: flex; align-items: center; justify-content: center;
  padding: 28px;
}
.ri-digest-modal {
  width: min(860px, 100%); height: min(92vh, 1000px);
  background: var(--card); border-radius: var(--r-lg);
  display: flex; flex-direction: column; overflow: hidden;
  box-shadow: 0 18px 60px rgba(0, 0, 0, 0.35);
}
.ri-digest-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 20px;
  background: linear-gradient(90deg, var(--hero-1), var(--hero-2) 60%, var(--hero-3));
  border-bottom: 2px solid var(--forest);
}
.ri-digest-brand {
  display: block; font-family: var(--font-mono); font-size: 8.5px; font-weight: 700;
  letter-spacing: 0.2em; color: var(--live);
}
.ri-digest-head h2 {
  margin: 2px 0 0; font-family: var(--font-display); font-size: 17px;
  font-weight: 700; color: #fff;
}
.ri-digest-close {
  background: none; border: 0; color: rgba(255,255,255,0.7);
  font-size: 24px; line-height: 1; cursor: pointer; padding: 2px 6px;
}
.ri-digest-close:hover { color: #fff; }
.ri-digest-body { flex: 1; display: flex; flex-direction: column; min-height: 0; }
.ri-digest-frame { flex: 1; width: 100%; border: 0; }
.ri-digest-foot {
  display: flex; justify-content: flex-end; gap: 10px;
  padding: 12px 20px; border-top: 1px solid var(--border2);
}
.ri-digest-download {
  display: inline-flex; align-items: center;
  height: 34px; padding: 0 16px;
  background: var(--forest); color: #fff; text-decoration: none;
  border-radius: var(--r-sm); font-family: var(--font-body);
  font-size: 12px; font-weight: 600; transition: background .15s;
}
.ri-digest-download:hover { background: var(--forest-2); }
.ri-digest-loading {
  flex: 1; display: flex; flex-direction: column; align-items: center;
  justify-content: center; gap: 16px; padding: 40px; text-align: center;
}
.ri-digest-loading p { max-width: 420px; font-size: 12.5px; color: var(--mid); line-height: 1.6; }
.ri-digest-spinner {
  width: 26px; height: 26px; border-radius: 50%;
  border: 3px solid var(--border2); border-top-color: var(--forest);
  animation: ri-digest-spin 0.9s linear infinite;
}
@keyframes ri-digest-spin { to { transform: rotate(360deg); } }
@media (prefers-reduced-motion: reduce) {
  .ri-digest-spinner { animation: none; }
}
.ri-digest-error {
  flex: 1; display: flex; flex-direction: column; align-items: center;
  justify-content: center; gap: 10px; padding: 40px; text-align: center;
}
.ri-digest-error-h { font-weight: 700; color: var(--charcoal); font-size: 14px; }
.ri-digest-error p { max-width: 460px; font-size: 12.5px; color: var(--slate); line-height: 1.6; }
.ri-digest-retry {
  margin-top: 6px; height: 32px; padding: 0 16px;
  background: var(--card); border: 1px solid var(--border2); border-radius: var(--r-sm);
  font-family: var(--font-body); font-size: 12px; font-weight: 600; color: var(--slate);
  cursor: pointer;
}
.ri-digest-retry:hover { border-color: var(--forest); color: var(--forest); }

/* Focus-flash applied to a grid card when the user clicks a tape item.
   Ring pulses outward in the brand red so the user's eye is led directly
   from tape click → card landing point. Ported from the retired
   regulatory-feed-banner.css (module removed in slice R4). */
.reg-intel__card--focus-flash {
  animation: reg-intel-focus-flash 1500ms ease-out;
  position: relative; z-index: 2;
}
@keyframes reg-intel-focus-flash {
  0%   { box-shadow: 0 0 0 0 rgba(255,45,79,0.55), 0 1px 2px rgba(15,23,42,0.04), 0 1px 3px rgba(15,23,42,0.06); }
  35%  { box-shadow: 0 0 0 6px rgba(255,45,79,0.20), 0 4px 16px rgba(15,23,42,0.08), 0 1px 4px rgba(15,23,42,0.06); }
  100% { box-shadow: 0 0 0 0 rgba(255,45,79,0), 0 1px 2px rgba(15,23,42,0.04), 0 1px 3px rgba(15,23,42,0.06); }
}
@media (prefers-reduced-motion: reduce) {
  .reg-intel__card--focus-flash { animation: none !important; outline: 2px solid #FF2D4F; outline-offset: 2px; }
}

/* ================= Legacy detail / modal / toast styles still consumed by the
   Direction B page (expanded card detail, flag modal, toasts, skeleton,
   banner, badges). Pre-Direction-B layout styles were removed in slice R4. */

/* Every rule below corresponds to a reg-intel__* class still emitted by
   frontend/components/regulatory-intelligence.js. Brand tokens are inlined
   as raw hex per the original spec — no CSS vars in this block. */

.reg-intel__container{width:100%;background:#F4F6F8;padding:24px;font-family:'IBM Plex Sans',sans-serif;color:#111827;box-sizing:border-box;}

/* Hidden utility — must win over any element's own display rule (e.g.
   the flag-modal backdrop's display:flex, declared later in this file).
   Without !important, equal-specificity source order let the backdrop
   stay visible, so adding this class on close did nothing. */
.reg-intel__hidden{display:none !important;}

/* ── New-items banner ───────────────────────────────────────────────────── */
/* Sticks just below the disclaimer when both are pinned. Lower z-index
   so the disclaimer always reads as the top-most chrome. */
.reg-intel__banner{position:sticky;top:62px;z-index:5;background:#015441;color:#FFFFFF;padding:10px 16px;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:12px;font-size:13px;font-weight:500;margin-bottom:16px;box-shadow:0 1px 3px rgba(0,0,0,0.08);transition:background .15s ease;}

.reg-intel__banner:hover{background:#0F3D24;}

.reg-intel__banner--hidden{display:none;}

/* ── Skeleton loading ───────────────────────────────────────────────────── */
/* Margin-bottom dropped — the grid `gap` now handles vertical spacing.
   Matches the resting tile chrome so the swap-in is visually quiet. */
.reg-intel__skeleton-card{background:#FFFFFF;border:1px solid #94A3B8;border-radius:10px;padding:16px 18px;box-shadow:0 1px 2px rgba(15,23,42,0.04), 0 1px 3px rgba(15,23,42,0.06);}

.reg-intel__skeleton-line{height:12px;border-radius:4px;margin-bottom:8px;background:#e5e7eb;background-image:linear-gradient(90deg,#e5e7eb 0%,#f3f4f6 50%,#e5e7eb 100%);background-size:200% 100%;animation:reg-intel__shimmer 1.5s infinite linear;}

.reg-intel__skeleton-line--short{width:40%;}

@keyframes reg-intel__shimmer{0%{background-position:-200% 0;}100%{background-position:200% 0;}}

/* Expanded card — applied alongside .riB-card--open on click. Spans the full
   grid row (grid-column) so the detail reads without losing the surrounding
   day-bucket context; forest border marks the open state. */
.reg-intel__card--expanded{cursor:default;border-color:#015441;padding:22px 26px;grid-column:1 / -1;box-shadow:0 4px 16px rgba(15,23,42,0.08), 0 1px 4px rgba(15,23,42,0.06);}

.reg-intel__new-badge{color:#015441;background:#dcfce7;font-size:11px;font-weight:700;text-transform:uppercase;padding:3px 8px;border-radius:4px;white-space:nowrap;}

.reg-intel__collapse-btn{font-family:'IBM Plex Sans',sans-serif;font-size:12px;font-weight:500;color:#6B7280;background:none;border:1px solid #e5e7eb;border-radius:6px;padding:6px 12px;margin-top:12px;cursor:pointer;transition:all .15s ease;}

.reg-intel__collapse-btn:hover{color:#111827;border-color:#9ca3af;}

/* ── Expanded panel ─────────────────────────────────────────────────────── */
.reg-intel__expanded{margin-top:14px;padding-top:14px;border-top:1px solid #f3f4f6;}

/* Facts: two-column grid (label / value) */
.reg-intel__facts{display:grid;grid-template-columns:120px 1fr;gap:6px 16px;margin-bottom:16px;font-size:13px;}

.reg-intel__fact{display:contents;}

.reg-intel__fact-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:0.04em;color:#374151;align-self:center;}

.reg-intel__fact-value{color:#111827;line-height:1.5;}

/* Sections — AI Summary (neutral) and Recommendations (green) */
.reg-intel__section{margin-bottom:14px;padding:12px 14px;background:#f9fafb;border:1px solid #f3f4f6;border-radius:6px;}

.reg-intel__section--recommendations{background:#f0fdf4;border-color:#bbf7d0;}

.reg-intel__section-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:0.05em;color:#6B7280;margin:0 0 8px 0;}

.reg-intel__section--recommendations .reg-intel__section-title{color:#015441;}

.reg-intel__bullets{list-style:none;padding:0;margin:0;}

.reg-intel__bullet{font-size:13px;color:#1F2937;line-height:1.6;margin-bottom:8px;padding-left:14px;position:relative;}

.reg-intel__bullet:last-child{margin-bottom:0;}

.reg-intel__bullet:before{content:'\2022';position:absolute;left:0;top:0;color:#9ca3af;}

.reg-intel__bullet strong{color:#111827;font-weight:600;}

.reg-intel__section--recommendations .reg-intel__bullet:before{color:#015441;}

.reg-intel__section--recommendations .reg-intel__bullet strong{color:#015441;}

/* Designations — email-ingested sanctions update "Name → Unique ID" rows.
   The ID is a gov.uk-linked monospace token when safe (green), or muted
   plain text when no safe gov.uk link was resolved. */
.reg-intel__desig-list{list-style:none;padding:0;margin:0;}

.reg-intel__desig-row{display:flex;justify-content:space-between;align-items:baseline;gap:12px;font-size:13px;line-height:1.6;padding:5px 0;border-bottom:1px solid #f3f4f6;}

.reg-intel__desig-row:last-child{border-bottom:none;}

.reg-intel__desig-name{color:#111827;}

.reg-intel__desig-id{font-family:'IBM Plex Mono','JetBrains Mono',monospace;font-size:12px;font-weight:600;color:#015441;text-decoration:none;white-space:nowrap;flex:none;}

.reg-intel__desig-id:hover{text-decoration:underline;}

.reg-intel__desig-id--plain{color:#6B7280;font-weight:500;}

/* Link + attribution (inside expanded panel) */
.reg-intel__link{display:inline-block;font-size:13px;color:#015441;font-weight:500;text-decoration:none;margin-top:4px;}

.reg-intel__link:hover{text-decoration:underline;}

.reg-intel__attribution{font-size:11px;color:#1F2937;margin-top:12px;padding-top:10px;border-top:1px solid #f3f4f6;}

.reg-intel__attribution-link{color:#1F2937;text-decoration:underline;}

.reg-intel__error{background:#FFFFFF;border:1px solid #fee2e2;border-radius:8px;padding:40px;text-align:center;grid-column:1 / -1;}

.reg-intel__error-msg{font-size:14px;color:#dc2626;margin-bottom:12px;}

.reg-intel__retry-btn{font-family:'IBM Plex Sans',sans-serif;font-size:13px;color:#FFFFFF;background:#015441;border:none;border-radius:6px;padding:8px 16px;cursor:pointer;transition:background .15s ease;}

.reg-intel__retry-btn:hover{background:#0F3D24;}

@media (max-width:768px) {
  .reg-intel__container{padding:16px;}
  .reg-intel__card--expanded{padding:16px 18px;}
  .reg-intel__facts{grid-template-columns:90px 1fr;gap:4px 12px;}
}

@media (max-width:360px) {
  .reg-intel__container{padding:12px;}
  .reg-intel__facts{grid-template-columns:1fr;gap:2px 0;}
  .reg-intel__facts .reg-intel__fact-label{margin-top:6px;}
}

/* UNDER REVIEW badge — amber "in progress". Shown on any card with an
   open flag. Replaced the former FLAGGED badge (24 May 2026): once
   reported, the tile is locked under review rather than left openly
   readable. Tooltip carries the long-form explanation. */
.reg-intel__review-badge{display:inline-flex;align-items:center;font-size:10.5px;font-weight:700;letter-spacing:0.05em;text-transform:uppercase;background:#FEF3C7;color:#92400E;border:1px solid #F59E0B;border-radius:4px;padding:3px 8px;cursor:help;}

/* Flag modal — backdrop + dialog. Backdrop covers the whole viewport;
   click outside the dialog closes (handler in JS reads e.target ===
   backdrop). z-index is above the sticky disclaimer (8) and banner (5). */
.reg-intel__flag-modal-backdrop{position:fixed;inset:0;background:rgba(15,23,42,0.45);z-index:50;display:flex;align-items:center;justify-content:center;padding:20px;}

.reg-intel__flag-modal{background:#FFFFFF;border-radius:10px;box-shadow:0 10px 30px rgba(0,0,0,0.18);max-width:520px;width:100%;padding:24px;font-family:'IBM Plex Sans',sans-serif;color:#111827;}

.reg-intel__flag-modal-heading{margin:0 0 8px;font-size:16px;font-weight:600;color:#015441;}

.reg-intel__flag-modal-blurb{margin:0 0 18px;font-size:13px;color:#4B5563;line-height:1.5;}

.reg-intel__flag-modal-label{display:block;font-size:11.5px;font-weight:600;text-transform:uppercase;letter-spacing:0.05em;color:#374151;margin:0 0 6px;}

.reg-intel__flag-modal-select,.reg-intel__flag-modal-textarea{font-family:'IBM Plex Sans',sans-serif;font-size:13px;color:#111827;background:#FFFFFF;border:1px solid #D1D5DB;border-radius:6px;padding:8px 10px;width:100%;box-sizing:border-box;margin-bottom:14px;outline:none;transition:border-color .15s ease;}

.reg-intel__flag-modal-select:focus,.reg-intel__flag-modal-textarea:focus{border-color:#015441;}

.reg-intel__flag-modal-textarea{resize:vertical;min-height:80px;font-family:inherit;}

.reg-intel__flag-modal-error{background:#FEE2E2;color:#991B1B;border:1px solid #FCA5A5;border-radius:6px;padding:10px 12px;font-size:12.5px;margin-bottom:14px;}

.reg-intel__flag-modal-actions{display:flex;gap:10px;justify-content:flex-end;}

.reg-intel__flag-modal-cancel,.reg-intel__flag-modal-submit{font-family:'IBM Plex Sans',sans-serif;font-size:13px;font-weight:500;border-radius:6px;padding:8px 16px;cursor:pointer;transition:all .15s ease;}

.reg-intel__flag-modal-cancel{background:#FFFFFF;color:#374151;border:1px solid #D1D5DB;}

.reg-intel__flag-modal-cancel:hover{background:#F9FAFB;}

.reg-intel__flag-modal-submit{background:#015441;color:#FFFFFF;border:1px solid #015441;}

.reg-intel__flag-modal-submit:hover:not(:disabled){background:#0F3D24;border-color:#0F3D24;}

.reg-intel__flag-modal-submit:disabled{opacity:0.6;cursor:not-allowed;}

/* Success (thank-you) view — shown after a flag is submitted, replacing
   the form. Centred green tick + message. */
.reg-intel__flag-modal-success{text-align:center;padding:6px 4px 10px;}

.reg-intel__flag-modal-success-icon{width:44px;height:44px;margin:0 auto 12px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:#DCFCE7;color:#15803D;font-size:22px;font-weight:700;line-height:1;}

.reg-intel__flag-modal-success-title{margin:0 0 6px;font-size:15px;font-weight:700;color:#0F172A;}

.reg-intel__flag-modal-success-body{margin:0;font-size:12.5px;color:#475569;line-height:1.5;}

/* Toast — single column top-right, stacks on top of one another. CSS
   transition handles the fade; JS removes the node after the timeout. */
.reg-intel__toast-host{position:fixed;top:20px;right:20px;z-index:60;display:flex;flex-direction:column;gap:8px;pointer-events:none;}

.reg-intel__toast{background:#FFFFFF;border-radius:8px;box-shadow:0 4px 12px rgba(0,0,0,0.12);padding:12px 16px;font-family:'IBM Plex Sans',sans-serif;font-size:13px;color:#111827;min-width:240px;max-width:380px;border-left:4px solid #015441;animation:reg-intel-toast-in .25s ease;pointer-events:auto;}

.reg-intel__toast--success{border-left-color:#015441;}

.reg-intel__toast--error{border-left-color:#991B1B;color:#991B1B;}

.reg-intel__toast--leaving{opacity:0;transform:translateX(20px);transition:all .4s ease;}

@keyframes reg-intel-toast-in{from{opacity:0;transform:translateX(20px);}to{opacity:1;transform:translateX(0);}}
