/* =============================================================================
   MPRC Publications — archive + extras stylesheet (v2.1)

   Design source: design PDF (look & feel) — sage / terracotta / gold / cream,
   Ubuntu typography, rounded pill controls, 8px spacing rhythm.

   Functional source: Figma — view switchers, advanced filters, dashboard,
   per-card actions, export.

   Class prefix: .mprc-pub-* (no global selectors; safe to drop into any theme).
   ========================================================================== */

/* Phase 9f — page background. On any page that contains the Publications
 * archive or extras shortcode, paint the <body> cream so the gaps between
 * Elementor sections read as one continuous cream column instead of breaking
 * to white. The :has() selector scopes this automatically; the rule only
 * activates on Publications-related pages and is invisible elsewhere.
 *
 * Colour is #E1DDD3 (the cooler cream used by the stats banner and results
 * section on the live page) so every cream region matches. Phase 9e used
 * #F2EBDB which was warmer and created a visible mismatch against the
 * stats banner's #E1DDD3.
 *
 * Hex value direct (not var) because the CSS variables are scoped to the
 * .mprc-pub-archive / .mprc-pub-extras containers, not the body. */
body:has(.mprc-pub-archive),
body:has(.mprc-pub-extras) {
  background-color: #E1DDD3 !important;
}

/* ---------- Design tokens ---------- */
.mprc-pub-archive,
.mprc-pub-extras {
  --mprc-sage:        #728B75;
  --mprc-sage-dark:   #5C7060;
  --mprc-sage-light:  #8FA593;
  --mprc-terra:       #BC5C39;
  --mprc-terra-dark:  #9B4929;
  --mprc-gold:        #E3B23C;
  --mprc-gold-dark:   #C99A2C;
  --mprc-cream:       #E1DDD3;
  --mprc-cream-soft:  #FAF6EC;
  --mprc-charcoal:    #2A2A2A;
  --mprc-grey-700:    #555;
  --mprc-grey-500:    #888;
  --mprc-grey-300:    #D9D6CD;
  --mprc-white:       #FFFFFF;
  --mprc-shadow-card: 0 2px 8px rgba(42, 42, 42, .06);
  --mprc-shadow-soft: 0 1px 3px rgba(42, 42, 42, .04);
  --mprc-radius-sm:   8px;
  --mprc-radius:      14px;
  --mprc-radius-lg:   28px;
  --mprc-radius-pill: 999px;
  --mprc-space-1:     8px;
  --mprc-space-2:     16px;
  --mprc-space-3:     24px;
  --mprc-space-4:     32px;
  --mprc-space-5:     48px;

  font-family: 'Ubuntu', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  color: var(--mprc-charcoal);
  line-height: 1.5;
  box-sizing: border-box;
}
.mprc-pub-archive *,
.mprc-pub-archive *::before,
.mprc-pub-archive *::after,
.mprc-pub-extras *,
.mprc-pub-extras *::before,
.mprc-pub-extras *::after { box-sizing: border-box; }

/* ---------- Hero (only renders when show_hero='yes' attr set) ---------- */
.mprc-pub-hero {
  background: var(--mprc-sage-dark);
  padding: var(--mprc-space-5) var(--mprc-space-3);
  text-align: center;
}
.mprc-pub-hero h1 {
  color: var(--mprc-white);
  font-size: clamp(2.5rem, 6vw, 4.5rem);
  font-weight: 700;
  margin: 0;
  letter-spacing: -.02em;
}

/* ---------- Stats banner (cream section: heading + counters + filters) ---------- */
.mprc-pub-stats-banner {
  background: var(--mprc-cream);
  padding: var(--mprc-space-5) var(--mprc-space-3);
}
.mprc-pub-stats-inner {
  /* Phase 8n — centered column, same max-width as toolbar + card grid
   * below so the whole publications block reads as one aligned column
   * on wide viewports. */
  max-width: 1400px;
  margin: 0 auto;
  text-align: center;
}
.mprc-pub-stats-inner > h2 {
  font-size: clamp(1.75rem, 3.5vw, 2.5rem);
  font-weight: 700;
  color: var(--mprc-charcoal);
  margin: 0 0 var(--mprc-space-1);
}
.mprc-pub-stats-inner > p {
  color: var(--mprc-grey-700);
  font-size: 1rem;
  margin: 0 auto var(--mprc-space-4);
  max-width: 720px;
}
.mprc-pub-stats-inner > p strong { color: var(--mprc-charcoal); font-weight: 700; }

.mprc-pub-counters {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--mprc-space-3);
  margin-bottom: var(--mprc-space-4);
}
.mprc-pub-counter { text-align: center; }
.mprc-pub-counter-num {
  display: block;
  font-size: clamp(1.75rem, 3.5vw, 2.75rem);
  font-weight: 700;
  color: var(--mprc-terra);
  line-height: 1;
}
.mprc-pub-counter span {
  display: block;
  margin-top: var(--mprc-space-1);
  color: var(--mprc-grey-700);
  font-size: .9rem;
}

/* ---------- Filter row (pill inputs + terracotta toggle) ----------
 * Phase 8b — switched from flex to grid so the 5 filter controls always sit
 * in a single row at desktop width. Was wrapping vertically because <select>
 * elements have a browser-default min-width that the flex layout respected. */
.mprc-pub-filters {
  display: grid;
  /* Phase 8l — last column widened from 170px to 240px so both
   * "ADVANCED FILTERS" and "HIDE ADVANCED FILTERS" labels fit inside the pill. */
  grid-template-columns: 110px 110px 200px 1fr 240px;
  align-items: center;
  gap: 10px;
  background: transparent;
  margin-bottom: var(--mprc-space-2);
}
.mprc-pub-filters > * { min-width: 0; width: 100%; }
/* Phase 8h — !important on border-radius so Elementor's flat input styles don't override the pill shape. */
.mprc-pub-filters select,
.mprc-pub-filters input[type="search"],
.mprc-pub-filters input[type="number"] {
  appearance: none !important;
  -webkit-appearance: none !important;
  background-color: var(--mprc-white) !important;
  border: 1px solid var(--mprc-grey-300) !important;
  border-radius: var(--mprc-radius-pill) !important;
  padding: 12px 18px !important;
  font-family: inherit;
  font-size: .95rem !important;
  color: var(--mprc-charcoal) !important;
  height: 48px !important;
  outline: none;
  box-shadow: none !important;
}
/* Phase 8k — restore the chevron arrow on <select> dropdowns. Phase 8j's
 * shorthand `background:` was wiping the image. Now using longhand. */
.mprc-pub-filters select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 8'%3E%3Cpath fill='%23BC5C39' d='M6 8L0 0h12z'/%3E%3C/svg%3E") !important;
  background-repeat: no-repeat !important;
  background-position: right 16px center !important;
  background-size: 10px !important;
  padding-right: 36px !important;
}
.mprc-pub-filters input[type="search"] { flex: 2 1 240px; }
.mprc-pub-filters input:focus,
.mprc-pub-filters select:focus { border-color: var(--mprc-sage); box-shadow: 0 0 0 3px rgba(114, 139, 117, .15); }

/* Phase 8h — !important to beat Elementor's `.elementor button` cascade. */
.mprc-pub-advanced-toggle {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  gap: var(--mprc-space-1);
  background: var(--mprc-terra) !important;
  color: var(--mprc-white) !important;
  border: none !important;
  border-radius: var(--mprc-radius-pill) !important;
  padding: 12px 22px !important;
  font-family: inherit;
  font-size: .9rem !important;
  font-weight: 600;
  cursor: pointer;
  height: 48px;
  width: 100%;
  white-space: nowrap;
  transition: background .18s ease;
}
.mprc-pub-advanced-toggle:hover { background: var(--mprc-terra-dark) !important; }
.mprc-pub-advanced-toggle[aria-expanded="true"] .mprc-pub-adv-label::before { content: 'Hide '; }

/* ---------- Active filter chips + Clear All ---------- */
.mprc-pub-active-filters {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--mprc-space-1);
  margin: var(--mprc-space-2) 0 0;
}
.mprc-pub-active-filters[hidden] { display: none; }
.mprc-pub-clear-all {
  background: transparent;
  border: 1px solid var(--mprc-terra);
  color: var(--mprc-terra);
  border-radius: var(--mprc-radius-pill);
  padding: 6px 14px;
  font-family: inherit;
  font-size: .8rem;
  font-weight: 700;
  cursor: pointer;
  text-transform: uppercase;
  letter-spacing: .04em;
  transition: all .15s ease;
}
.mprc-pub-clear-all:hover { background: var(--mprc-terra); color: var(--mprc-white); }
.mprc-pub-chip-list {
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-wrap: wrap; gap: 6px;
}
.mprc-pub-chip {
  display: inline-flex; align-items: center; gap: 6px;
  background: var(--mprc-cream);
  border: 1px solid var(--mprc-grey-300);
  border-radius: var(--mprc-radius-pill);
  padding: 4px 12px;
  font-size: .8rem;
  color: var(--mprc-charcoal);
}
.mprc-pub-chip strong {
  color: var(--mprc-grey-700);
  font-weight: 600;
  text-transform: uppercase;
  font-size: .7rem;
  letter-spacing: .04em;
}
.mprc-pub-chip-x {
  background: transparent;
  border: none;
  color: var(--mprc-terra);
  font-size: 1rem;
  cursor: pointer;
  padding: 0 0 0 4px;
  line-height: 1;
}

/* Dashboard scope note */
.mprc-pub-dashboard-scope {
  text-align: center;
  margin: -8px auto var(--mprc-space-3);
  max-width: 600px;
  font-size: .85rem;
  color: var(--mprc-grey-700);
  font-style: italic;
}

/* Real-link CTA button (replaces dead form) */
.mprc-pub-cta-btn {
  display: inline-flex; align-items: center; justify-content: space-between;
  width: 100%;
  background: var(--mprc-cream);
  color: var(--mprc-charcoal);
  text-decoration: none;
  border-radius: var(--mprc-radius-pill);
  padding: 12px 22px;
  font-family: inherit; font-weight: 700;
  font-size: 1rem;
  transition: all .15s ease;
}
.mprc-pub-cta--apply .mprc-pub-cta-btn { background: var(--mprc-gold); color: var(--mprc-charcoal); }
.mprc-pub-cta-btn:hover { transform: translateX(4px); }

/* Citation cell in card body — visible in list/compact, hidden in grid/card via container rules */
.mprc-pub-card-cites-cell {
  margin: 0;
  font-size: .85rem;
  color: var(--mprc-terra);
  font-weight: 700;
}
.mprc-pub-cites-label { color: var(--mprc-grey-500); font-weight: 500; font-size: .75rem; }
.mprc-pub-grid--grid .mprc-pub-card-cites-cell,
.mprc-pub-grid--card .mprc-pub-card-cites-cell,
.mprc-pub-grid--photo .mprc-pub-card-cites-cell {
  /* Phase 8b — Grid + Card views show citations via the thumbnail badge
     (.mprc-pub-card-cites). Hide the in-body cites cell here so the number
     isn't shown twice. List + Compact keep the in-body cell visible. */
  display: none;
}

/* ---------- Advanced filters expander ---------- */
.mprc-pub-advanced-panel {
  margin-top: var(--mprc-space-2);
  padding: var(--mprc-space-3);
  background: var(--mprc-cream-soft);
  border: 1px solid var(--mprc-grey-300);
  border-radius: var(--mprc-radius);
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: var(--mprc-space-3);
  text-align: left;
}
.mprc-pub-advanced-panel[hidden] { display: none; }
.mprc-pub-adv-field { display: flex; flex-direction: column; gap: var(--mprc-space-1); font-size: .85rem; }
.mprc-pub-adv-field > span:first-child {
  display: inline-flex; align-items: center; gap: 6px;
  color: var(--mprc-grey-700); font-weight: 600;
  text-transform: uppercase; letter-spacing: .04em;
}
.mprc-pub-adv-field input[type="search"] {
  appearance: none;
  background: var(--mprc-white);
  border: 1px solid var(--mprc-grey-300);
  border-radius: var(--mprc-radius-pill);
  padding: 12px 18px;
  font-family: inherit;
  font-size: .95rem;
  height: 44px;
}
.mprc-pub-checkbox {
  display: inline-flex; align-items: center; gap: 10px;
  font-weight: 700; letter-spacing: .04em; color: var(--mprc-charcoal);
  font-size: .85rem; text-transform: uppercase;
  cursor: pointer; user-select: none;
}
.mprc-pub-checkbox input { accent-color: var(--mprc-terra); width: 18px; height: 18px; }

/* ---------- Statistics dashboard toggle + panel ---------- */
/* Phase 8f — moved to left-align below filter row, switched to rust pill per design. */
.mprc-pub-stats-link { margin-top: var(--mprc-space-3); text-align: left; }
.mprc-pub-dashboard-toggle {
  display: inline-flex !important; align-items: center; gap: var(--mprc-space-1);
  background: var(--mprc-terra) !important;
  color: var(--mprc-white) !important;
  border: 2px solid var(--mprc-terra) !important;
  border-radius: var(--mprc-radius-pill) !important;
  padding: 12px 22px !important;
  font-family: inherit;
  font-size: 1rem;
  font-weight: 700;
  cursor: pointer;
  transition: all .18s ease;
}
.mprc-pub-dashboard-toggle:hover { background: var(--mprc-terra-dark) !important; border-color: var(--mprc-terra-dark) !important; }
.mprc-pub-dashboard-toggle[aria-expanded="true"] .mprc-pub-dashboard-label::before { content: 'Hide '; }

.mprc-pub-dashboard {
  background: var(--mprc-cream-soft);
  padding: var(--mprc-space-4) var(--mprc-space-3);
}
.mprc-pub-dashboard[hidden] { display: none; }
.mprc-pub-dashboard > h3 {
  text-align: center;
  font-size: clamp(1.5rem, 2.5vw, 2rem);
  font-weight: 700;
  color: var(--mprc-charcoal);
  margin: 0 0 var(--mprc-space-3);
}
.mprc-pub-dashboard-grid {
  max-width: 1400px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--mprc-space-3);
}
.mprc-pub-dash-card {
  background: var(--mprc-white);
  border-radius: var(--mprc-radius);
  padding: var(--mprc-space-3);
  box-shadow: var(--mprc-shadow-soft);
}
.mprc-pub-dash-card h4 {
  margin: 0 0 var(--mprc-space-2);
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--mprc-charcoal);
  display: flex; align-items: center; gap: 8px;
}
/* Phase 8d — canvas sizing per chart-type.
 * Pie chart needs a square container so the circle is round, not an ellipse.
 * Bar + line charts can be rectangular (240px tall, full width). */
.mprc-pub-dash-card canvas { width: 100% !important; height: 240px !important; }
.mprc-pub-dash--themes canvas {
  width: auto !important;
  max-width: 320px !important;
  height: 320px !important;
  margin: 0 auto !important;
  display: block !important;
}
.mprc-pub-dash--themes { text-align: center; }

.mprc-pub-rank { list-style: none; counter-reset: rank-counter; padding: 0; margin: 0; }
.mprc-pub-rank li {
  counter-increment: rank-counter;
  display: flex; align-items: center;
  background: var(--mprc-cream-soft);
  border-radius: var(--mprc-radius-sm);
  padding: 12px 16px;
  margin-bottom: 6px;
  font-size: .95rem;
}
.mprc-pub-rank li::before {
  content: counter(rank-counter);
  flex: 0 0 32px;
  height: 32px;
  width: 32px;
  border-radius: 50%;
  background: var(--mprc-sage-dark);
  color: var(--mprc-white);
  display: inline-flex; align-items: center; justify-content: center;
  font-weight: 700;
  margin-right: 12px;
}
.mprc-pub-rank--journals li::before { background: var(--mprc-gold); }
.mprc-pub-rank li .mprc-pub-rank-name { flex: 1; color: var(--mprc-charcoal); }
.mprc-pub-rank li .mprc-pub-rank-count { color: var(--mprc-terra); font-weight: 700; }

.mprc-pub-cited-list { list-style: none; counter-reset: cited-counter; padding: 0; margin: 0; }
.mprc-pub-cited-list li {
  counter-increment: cited-counter;
  background: var(--mprc-cream-soft);
  border-radius: var(--mprc-radius-sm);
  padding: var(--mprc-space-2);
  margin-bottom: var(--mprc-space-1);
  display: grid;
  grid-template-columns: 32px 1fr;
  gap: var(--mprc-space-2);
}
.mprc-pub-cited-list li::before {
  content: counter(cited-counter);
  height: 32px; width: 32px; border-radius: 50%;
  background: var(--mprc-terra);
  color: var(--mprc-white);
  display: inline-flex; align-items: center; justify-content: center;
  font-weight: 700; font-size: .9rem;
}
.mprc-pub-cited-list .mprc-pub-cited-title { font-weight: 700; color: var(--mprc-charcoal); margin: 0 0 4px; }
.mprc-pub-cited-list .mprc-pub-cited-meta { color: var(--mprc-grey-700); font-size: .85rem; margin: 0 0 4px; }
.mprc-pub-cited-list .mprc-pub-cited-cites { color: var(--mprc-sage-dark); font-weight: 700; font-size: .85rem; }
.mprc-pub-cited-list .mprc-pub-cited-cites .oa { color: var(--mprc-sage); margin-left: 12px; font-weight: 600; }

/* ---------- Results header (summary + view switch + sort + per-page + export) ---------- */
.mprc-pub-results { background: var(--mprc-cream); padding: var(--mprc-space-4) var(--mprc-space-3); }
/* Phase 8n — toolbar locked to the same centered column as the card grid
 * + stats banner so the whole publications block reads as one aligned
 * unit on wide viewports. No more straying to viewport edges. */
.mprc-pub-results-header {
  width: 100%;
  max-width: 1400px;
  box-sizing: border-box;
  margin: 0 auto var(--mprc-space-3);
  padding: 0 var(--mprc-space-2);
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  justify-content: space-between;
  gap: var(--mprc-space-2);
}
.mprc-pub-results-summary {
  display: flex !important;
  flex-direction: column !important;
  gap: 2px;
  flex: 0 1 auto;
  min-width: 0;
}
.mprc-pub-showing {
  display: block !important;
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--mprc-charcoal);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.mprc-pub-summary-sub {
  display: block !important;
  font-size: .8rem;
  color: var(--mprc-grey-500);
}

.mprc-pub-results-controls {
  display: flex; align-items: center; gap: 8px;
  flex-wrap: nowrap;
  flex: 0 0 auto;
}
.mprc-pub-results-controls select { padding: 8px 30px 8px 10px !important; font-size: .85rem !important; }
@media (max-width: 1000px) {
  .mprc-pub-results-header { flex-wrap: wrap; }
  .mprc-pub-results-controls { flex-wrap: wrap; }
}

.mprc-pub-view-switch {
  display: inline-flex;
  background: var(--mprc-white);
  border: 1px solid var(--mprc-grey-300);
  border-radius: var(--mprc-radius-sm);
  padding: 4px;
  gap: 2px;
}
.mprc-pub-view-btn {
  background: transparent; border: none;
  width: 36px; height: 36px;
  border-radius: 6px;
  cursor: pointer;
  font-size: 1rem;
  color: var(--mprc-grey-500);
  display: inline-flex; align-items: center; justify-content: center;
  transition: all .15s ease;
}
.mprc-pub-view-btn:hover { color: var(--mprc-charcoal); background: var(--mprc-cream); }
.mprc-pub-view-btn.is-active { background: var(--mprc-charcoal); color: var(--mprc-white); }

.mprc-pub-results-controls select {
  appearance: none; -webkit-appearance: none;
  background: var(--mprc-white);
  border: 1px solid var(--mprc-grey-300);
  border-radius: var(--mprc-radius-sm);
  padding: 10px 36px 10px 14px;
  font-family: inherit;
  font-size: .9rem;
  height: 44px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 8'%3E%3Cpath fill='%23555' d='M6 8L0 0h12z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 14px center;
  background-size: 10px;
}
/* Export dropdown */
.mprc-pub-export-wrap { position: relative; }
.mprc-pub-export-btn {
  display: inline-flex; align-items: center; gap: 6px;
  background: var(--mprc-sage);
  color: var(--mprc-white);
  border: none;
  border-radius: var(--mprc-radius-sm);
  padding: 10px 18px;
  font-family: inherit; font-weight: 600;
  font-size: .9rem;
  cursor: pointer;
  height: 44px;
  transition: background .15s ease;
}
.mprc-pub-export-btn:hover { background: var(--mprc-sage-dark); }
.mprc-pub-export-btn:disabled { opacity: .5; cursor: not-allowed; }
.mprc-pub-export-caret { font-size: .75rem; margin-left: 4px; transition: transform .15s ease; }
.mprc-pub-export-btn[aria-expanded="true"] .mprc-pub-export-caret { transform: rotate(180deg); }
.mprc-pub-export-menu {
  position: absolute;
  top: calc(100% + 6px);
  right: 0;
  width: 320px;
  background: var(--mprc-white);
  border: 1px solid var(--mprc-grey-300);
  border-radius: var(--mprc-radius);
  box-shadow: 0 12px 32px rgba(42, 42, 42, .14);
  padding: 0;
  z-index: 50;
  overflow: hidden;
}
.mprc-pub-export-menu[hidden] { display: none; }
.mprc-pub-export-header {
  padding: 16px 20px 12px;
  border-bottom: 1px solid var(--mprc-grey-300);
  display: flex; flex-direction: column; gap: 2px;
}
.mprc-pub-export-header strong {
  font-size: .75rem;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--mprc-grey-500);
}
.mprc-pub-export-count {
  font-size: .95rem;
  color: var(--mprc-charcoal);
  font-weight: 500;
}
.mprc-pub-export-opt {
  display: flex; flex-direction: column; align-items: flex-start;
  width: 100%;
  background: transparent;
  border: none;
  padding: 14px 20px;
  font-family: inherit;
  cursor: pointer;
  text-align: left;
  border-bottom: 1px solid var(--mprc-grey-300);
  transition: background .12s ease;
}
.mprc-pub-export-opt:last-child { border-bottom: none; }
.mprc-pub-export-opt:hover,
.mprc-pub-export-opt:focus-visible { background: var(--mprc-cream-soft); outline: none; }
.mprc-pub-export-opt strong {
  display: block;
  color: var(--mprc-charcoal);
  font-size: 1rem;
  font-weight: 700;
  margin-bottom: 2px;
}
.mprc-pub-export-opt span {
  color: var(--mprc-grey-500);
  font-size: .8rem;
  font-weight: 600;
}

.mprc-pub-pager-mini { display: inline-flex; gap: 4px; }
.mprc-pub-pager-mini button {
  width: 36px; height: 36px;
  border-radius: 50%;
  border: 1px solid var(--mprc-grey-300);
  background: var(--mprc-white);
  color: var(--mprc-charcoal);
  cursor: pointer;
  font-size: 1.1rem;
  display: inline-flex; align-items: center; justify-content: center;
}
.mprc-pub-pager-mini button:disabled { opacity: .35; cursor: not-allowed; }
.mprc-pub-pager-mini button:not(:disabled):hover { background: var(--mprc-terra); color: var(--mprc-white); border-color: var(--mprc-terra); }
.mprc-pub-pager-mini button:last-child:not(:disabled) { background: var(--mprc-terra); color: var(--mprc-white); border-color: var(--mprc-terra); }

/* ---------- Results layout: grid + sidebar ---------- */
.mprc-pub-results-layout {
  /* Phase 8n — centered 1400px column to align with toolbar above. */
  max-width: 1400px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 280px;
  gap: var(--mprc-space-3);
  align-items: start;
}
.mprc-pub-results-layout:not(:has(.mprc-pub-sidebar)),
.mprc-pub-results-layout > .mprc-pub-grid:only-child { grid-template-columns: 1fr; }

/* In table-style views (list / compact), the sidebar is hidden so the table
   gets full width — matches design intent. CTAs reappear below the grid via
   the .mprc-pub-extras section or the separate sidebar shortcode. */
.mprc-pub-results-layout--list,
.mprc-pub-results-layout--compact {
  grid-template-columns: 1fr;
}
.mprc-pub-results-layout--list .mprc-pub-sidebar,
.mprc-pub-results-layout--compact .mprc-pub-sidebar {
  display: none;
}

/* ---------- Card grid — view modes ---------- */
.mprc-pub-grid { display: grid; gap: var(--mprc-space-2); }
.mprc-pub-grid--grid    { grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); }
.mprc-pub-grid--card,
.mprc-pub-grid--photo   { grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); }
.mprc-pub-grid--list    { grid-template-columns: 1fr; }
.mprc-pub-grid--compact { grid-template-columns: 1fr; }

/* ---------- Card — base style (matches design PDF) ---------- */
.mprc-pub-card {
  background: var(--mprc-white);
  border-radius: var(--mprc-radius);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  box-shadow: var(--mprc-shadow-card);
  transition: transform .18s ease, box-shadow .18s ease;
}
.mprc-pub-card:hover { transform: translateY(-2px); box-shadow: 0 6px 16px rgba(42, 42, 42, .1); }
.mprc-pub-card-thumb {
  /* Per design system §5.2.1 — Standard Card image is 16:9 full-bleed */
  position: relative;
  display: block;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  background: var(--mprc-cream);
}
.mprc-pub-card-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
/* Phase 8e — citation badge moved to bottom-LEFT to avoid collision with
 * the theme/method badge which sits in top-right of the thumbnail. */
.mprc-pub-card-cites {
  position: absolute;
  bottom: 10px; left: 10px;
  background: rgba(255,255,255,.95);
  color: var(--mprc-terra);
  font-weight: 700; font-size: .8rem;
  padding: 3px 10px;
  border-radius: var(--mprc-radius-pill);
  display: inline-flex; align-items: center; gap: 4px;
  box-shadow: 0 1px 4px rgba(0,0,0,0.15);
}
.mprc-pub-card-body { padding: var(--mprc-space-3) var(--mprc-space-3); display: flex; flex-direction: column; gap: 8px; flex: 1; }
.mprc-pub-card-title {
  /* Phase 8e — sized per design system §5.2.1 (Standard Card, image-led).
   * H4 token = clamp(1.125rem, 1.5vw + 0.8rem, 1.375rem) = 18-22px.
   * Slightly compressed for grid density: 16-18px range.
   * Source: /00. Planning/04_Visual Language & Asset Reference.md §3.4 + §5.2.1 */
  font-size: clamp(1rem, 0.9rem + 0.3vw, 1.125rem) !important;
  font-weight: 700;
  color: var(--mprc-sage-dark);
  margin: 0;
  line-height: 1.3;
  min-height: 2.6em; /* reserve 2 lines so card heights align */
}
.mprc-pub-card-title a {
  color: inherit; text-decoration: none;
  display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical;
  overflow: hidden;
  /* H4 line-height per design system §3.4 = 1.35 */
  line-height: 1.35 !important;
  font-size: inherit !important;
  font-weight: 700;
}
.mprc-pub-card-title a:hover { color: var(--mprc-terra); }
.mprc-pub-card-meta { margin: 0; color: var(--mprc-grey-500); font-size: .85rem; }
.mprc-pub-card-meta .mprc-pub-card-year { font-weight: 700; color: var(--mprc-charcoal); }
.mprc-pub-card-journal { margin: 0; color: var(--mprc-grey-700); font-size: .8rem; font-style: italic; }
.mprc-pub-card-snippet {
  margin: 4px 0 0;
  color: var(--mprc-grey-700);
  font-size: .85rem;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical;
  overflow: hidden;
}

/* Card actions row — Phase 9a layout, Phase 9d nowrap fix:
 * left cluster (View Paper + optional OA chip) | right side (Cite).
 * flex-wrap: nowrap so Grid view (narrower cards) keeps everything on
 * a single line instead of pushing Cite onto a second row. Items shrink
 * via min-width:0 so View Paper truncates rather than wraps. */
.mprc-pub-card-actions {
  display: flex; flex-wrap: nowrap; align-items: center;
  justify-content: space-between;
  gap: 6px;
  margin-top: auto;
  padding-top: var(--mprc-space-1);
  border-top: 1px solid var(--mprc-grey-300);
}
.mprc-pub-card-actions-left {
  display: inline-flex; align-items: center; gap: 6px;
  flex-wrap: nowrap;
  min-width: 0;
  flex: 0 1 auto;
}
.mprc-pub-card-actions > .mprc-pub-action-cite {
  flex: 0 0 auto;
}
.mprc-pub-card-action {
  display: inline-flex; align-items: center; gap: 4px;
  background: transparent;
  color: var(--mprc-terra);
  border: none;
  padding: 4px 8px;
  font-family: inherit;
  font-size: .8rem;
  font-weight: 600;
  cursor: pointer;
  text-decoration: none;
  border-radius: var(--mprc-radius-sm);
  transition: background .15s ease;
}
.mprc-pub-card-action:hover { background: var(--mprc-cream); }
/* Phase 9d — View Paper can shrink + truncate if the card is unusually
 * narrow. Cite + OA pill stay fixed-width via flex: 0 0 auto. */
.mprc-pub-action-view {
  min-width: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  flex: 0 1 auto;
}
/* Phase 9c — Cite button: charcoal pill with rounded edges + !important to
 * beat Elementor's `.elementor button` cascade. Was rendering as a flat
 * rectangle. Specific selector .mprc-pub-archive .mprc-pub-action-cite
 * gives specificity 0,3,0 which beats any Elementor rule. */
.mprc-pub-archive .mprc-pub-action-cite,
.mprc-pub-action-cite {
  background-color: var(--mprc-charcoal) !important;
  color: var(--mprc-white) !important;
  border: none !important;
  border-radius: var(--mprc-radius-pill) !important;
  padding: 6px 16px !important;
  font-weight: 600 !important;
  font-size: .8rem !important;
}
.mprc-pub-archive .mprc-pub-action-cite:hover,
.mprc-pub-action-cite:hover {
  background-color: var(--mprc-terra) !important;
  color: var(--mprc-white) !important;
}
/* Phase 9a — Save button retired; rules kept defensive in case existing
 * cached markup still renders it before the new template lands. */
.mprc-pub-action-save { display: none !important; }
/* Open Access chip — sage-tinted pill alongside View Paper. Shown only when
 * the paper is genuinely open access (OpenAlex is_oa = true). No badge for
 * closed or unclassified papers per Phase 9a design call. */
.mprc-pub-action-oa {
  color: var(--mprc-sage-dark);
  font-weight: 700;
  font-size: .7rem;
  letter-spacing: .04em;
  text-transform: uppercase;
  background: rgba(114, 139, 117, .14);
  border: 1px solid rgba(114, 139, 117, .35);
  border-radius: var(--mprc-radius-pill);
  padding: 2px 9px;
  cursor: default;
  white-space: nowrap;
  flex: 0 0 auto;
}

/* ---------- Card — variant per view ---------- */

/* Grid view (default — design PDF look): everything visible above */

/* Card view — bigger photo, slightly larger card */
.mprc-pub-grid--card .mprc-pub-card-thumb { aspect-ratio: 16 / 11; }
/* Card view (photo-tile) uses the H4 token as-is (slightly larger than Grid). */
.mprc-pub-grid--card .mprc-pub-card-title { font-size: clamp(1.0625rem, 1vw + 0.85rem, 1.25rem) !important; -webkit-line-clamp: 3; }
.mprc-pub-grid--card .mprc-pub-card-snippet { -webkit-line-clamp: 3; }

/* List view — true table rows: Title / Author / Journal / Year / Citations / Actions
   Six-column grid with explicit data cells. No CSS reshape of card markup —
   each cell maps to a real piece of the card data. */
.mprc-pub-grid--list .mprc-pub-card {
  flex-direction: row;
  align-items: stretch;
  border-radius: 0;
  background: var(--mprc-white);
  box-shadow: none;
  border-bottom: 1px solid var(--mprc-grey-300);
  padding: var(--mprc-space-2) 0;
}
.mprc-pub-grid--list .mprc-pub-card:hover { transform: none; box-shadow: none; background: var(--mprc-cream-soft); }
.mprc-pub-grid--list .mprc-pub-card-thumb { display: none; }
.mprc-pub-grid--list .mprc-pub-card-body {
  display: grid;
  grid-template-columns: minmax(0, 3fr) minmax(0, 1.2fr) minmax(0, 1.5fr) 80px 90px minmax(0, 1.4fr);
  gap: var(--mprc-space-2);
  align-items: center;
  padding: 0 var(--mprc-space-2);
}
.mprc-pub-grid--list .mprc-pub-card-title {
  font-size: .95rem;
  min-height: 0; /* override grid-view min-height */
  grid-column: 1;
}
.mprc-pub-grid--list .mprc-pub-card-title a { -webkit-line-clamp: 2; }
.mprc-pub-grid--list .mprc-pub-card-meta { font-size: .85rem; grid-column: 2; }
.mprc-pub-grid--list .mprc-pub-card-meta .mprc-pub-card-year { display: none; } /* year shown in its own column */
.mprc-pub-grid--list .mprc-pub-card-meta::before { content: ''; }
.mprc-pub-grid--list .mprc-pub-card-journal {
  font-style: normal;
  grid-column: 3;
  font-size: .85rem;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
/* Year cell — synthesized from the meta */
.mprc-pub-grid--list .mprc-pub-card-meta .mprc-pub-card-author { display: none; }
.mprc-pub-grid--list .mprc-pub-card-body::before {
  content: attr(data-year);
  grid-column: 4;
  font-size: .9rem;
  font-weight: 700;
  color: var(--mprc-charcoal);
}
.mprc-pub-grid--list .mprc-pub-card-cites-cell {
  grid-column: 5;
  font-size: .9rem;
  font-variant-numeric: tabular-nums;
}
.mprc-pub-grid--list .mprc-pub-card-cites-cell.is-empty { color: var(--mprc-grey-500); font-style: italic; }
/* Hide the small "cites" label in List view (header row already says "Citations") */
.mprc-pub-grid--list .mprc-pub-cites-label { display: none; }
.mprc-pub-grid--list .mprc-pub-card-snippet { display: none; }
.mprc-pub-grid--list .mprc-pub-card-actions {
  border-top: none; padding-top: 0;
  grid-column: 6;
  justify-content: flex-end;
  flex-wrap: nowrap;
}
.mprc-pub-grid--list .mprc-pub-card-actions .mprc-pub-card-action span:not([aria-hidden]) { display: none; }
.mprc-pub-grid--list .mprc-pub-card-action { padding: 4px 6px; font-size: .9rem; }

/* List + Compact header row (Compact has its own column count via modifier class) */
.mprc-pub-list-header {
  display: grid;
  gap: var(--mprc-space-2);
  padding: 12px var(--mprc-space-2);
  font-weight: 700; font-size: .75rem;
  color: var(--mprc-grey-700);
  text-transform: uppercase; letter-spacing: .05em;
  border-bottom: 2px solid var(--mprc-grey-300);
  background: var(--mprc-cream-soft);
}
.mprc-pub-list-header--list {
  grid-template-columns: minmax(0, 3fr) minmax(0, 1.2fr) minmax(0, 1.5fr) 80px 90px minmax(0, 1.4fr);
}
.mprc-pub-list-header--compact {
  grid-template-columns: 56px minmax(120px, 1.2fr) minmax(0, 3.5fr) 64px;
  padding: 6px var(--mprc-space-2);
  font-size: .7rem;
}
/* Column 4 (cites) right-aligned to match data cells */
.mprc-pub-list-header--compact span:nth-child(4) { text-align: right; }

/* ---------- Compact view ----------
 * Visually distinct from List: ~32px row height (vs List's ~64px),
 * 4 columns instead of 6 (drop Journal + collapse actions to a single Cite icon),
 * 12.5px body font, 1-line title with ellipsis. Use for high-density scanning
 * across hundreds of results.
 * Edited 2026-05-13 Phase 5.
 */
.mprc-pub-grid--compact .mprc-pub-card {
  flex-direction: row;
  align-items: center;
  border-radius: 0;
  background: var(--mprc-white);
  box-shadow: none;
  border-bottom: 1px solid var(--mprc-grey-200);
  padding: 4px 0;             /* tighter than List's 16px+ */
  min-height: 32px;
}
.mprc-pub-grid--compact .mprc-pub-card:nth-child(even) { background: var(--mprc-cream-soft); }
.mprc-pub-grid--compact .mprc-pub-card:hover { background: var(--mprc-gold-soft, #fdf6e3); }
.mprc-pub-grid--compact .mprc-pub-card-thumb { display: none; }
.mprc-pub-grid--compact .mprc-pub-card-body {
  display: grid;
  /* 4 columns: Year | Author | Title (greedy) | Citations */
  grid-template-columns: 56px minmax(120px, 1.2fr) minmax(0, 3.5fr) 64px;
  gap: var(--mprc-space-2);
  align-items: center;
  padding: 0 var(--mprc-space-2);
  font-size: .8125rem;        /* 13px base — denser */
  line-height: 1.25;
}
.mprc-pub-grid--compact .mprc-pub-card-title {
  font-size: .8125rem;
  font-weight: 500;
  min-height: 0;
  grid-column: 3;
  margin: 0;
}
.mprc-pub-grid--compact .mprc-pub-card-title a {
  -webkit-line-clamp: 1;
  display: block;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  color: var(--mprc-charcoal);
}
.mprc-pub-grid--compact .mprc-pub-card-title a:hover { color: var(--mprc-terra); }
.mprc-pub-grid--compact .mprc-pub-card-meta {
  font-size: .75rem;
  grid-column: 2;
  color: var(--mprc-grey-700);
  margin: 0;
}
.mprc-pub-grid--compact .mprc-pub-card-meta .mprc-pub-card-year { display: none; }    /* year is column 1 */
.mprc-pub-grid--compact .mprc-pub-card-meta::before { content: '' !important; }       /* kill " · " separator */
.mprc-pub-grid--compact .mprc-pub-card-journal { display: none; }                     /* no journal in compact */
.mprc-pub-grid--compact .mprc-pub-card-body::before {
  content: attr(data-year);
  grid-column: 1;
  font-size: .8rem;
  font-weight: 700;
  color: var(--mprc-terra);
  font-variant-numeric: tabular-nums;
}
.mprc-pub-grid--compact .mprc-pub-card-cites-cell {
  grid-column: 4;
  font-size: .75rem;
  text-align: right;
  font-variant-numeric: tabular-nums;
  color: var(--mprc-grey-700);
}
.mprc-pub-grid--compact .mprc-pub-card-cites-cell.is-empty { color: var(--mprc-grey-500); }
.mprc-pub-grid--compact .mprc-pub-cites-label { display: none; }                      /* hide "cites" word, number only */
.mprc-pub-grid--compact .mprc-pub-card-snippet { display: none; }
.mprc-pub-grid--compact .mprc-pub-card-actions { display: none; }                     /* no action bar in Compact */

/* ---------- Right sidebar CTAs (Never miss / Research awaits) ---------- */
.mprc-pub-sidebar { display: flex; flex-direction: column; gap: var(--mprc-space-2); position: sticky; top: var(--mprc-space-3); }
.mprc-pub-cta {
  border-radius: var(--mprc-radius);
  padding: var(--mprc-space-3) var(--mprc-space-2);
  color: var(--mprc-white);
}
.mprc-pub-cta--subscribe { background: var(--mprc-terra); }
.mprc-pub-cta--apply     { background: var(--mprc-sage); }
.mprc-pub-cta h3 {
  margin: 0 0 var(--mprc-space-1);
  font-size: 1.4rem; font-weight: 700; line-height: 1.15;
  color: var(--mprc-white);
}
.mprc-pub-cta p { margin: 0 0 var(--mprc-space-2); font-size: .9rem; opacity: .9; }
.mprc-pub-cta-form {
  display: flex; align-items: center;
  background: var(--mprc-cream);
  border-radius: var(--mprc-radius-pill);
  padding: 4px;
  overflow: hidden;
}
.mprc-pub-cta-form input {
  flex: 1; min-width: 0;
  border: none; background: transparent;
  padding: 8px 14px;
  font-family: inherit; font-size: .9rem;
  color: var(--mprc-charcoal);
  outline: none;
}
.mprc-pub-cta-form button {
  flex: 0 0 36px; height: 36px;
  border-radius: 50%;
  border: none;
  background: var(--mprc-charcoal);
  color: var(--mprc-gold);
  font-weight: 700; cursor: pointer;
  font-size: 1.1rem;
  display: inline-flex; align-items: center; justify-content: center;
}
.mprc-pub-cta--apply .mprc-pub-cta-form button { background: var(--mprc-gold); color: var(--mprc-white); }

/* ---------- Bottom pagination ---------- */
.mprc-pub-pagination {
  /* Phase 8n — centered 1400px column to match. */
  max-width: 1400px;
  margin: var(--mprc-space-3) auto 0;
  display: flex; align-items: center; justify-content: center; gap: var(--mprc-space-2);
}
.mprc-pub-pagination button {
  background: var(--mprc-white);
  border: 1px solid var(--mprc-grey-300);
  border-radius: var(--mprc-radius-pill);
  padding: 10px 18px;
  font-family: inherit; font-weight: 600;
  cursor: pointer;
  color: var(--mprc-charcoal);
}
.mprc-pub-pagination button:hover:not(:disabled) { background: var(--mprc-terra); color: var(--mprc-white); border-color: var(--mprc-terra); }
.mprc-pub-pagination button:disabled { opacity: .4; cursor: not-allowed; }
.mprc-pub-page-info { color: var(--mprc-grey-700); font-size: .9rem; }
.mprc-pub-page-info strong { color: var(--mprc-charcoal); }

/* ---------- Empty state ---------- */
.mprc-pub-empty {
  grid-column: 1 / -1;
  text-align: center;
  padding: var(--mprc-space-5) var(--mprc-space-3);
  background: var(--mprc-cream-soft);
  border: 1px dashed var(--mprc-grey-300);
  border-radius: var(--mprc-radius);
}
.mprc-pub-empty p {
  margin: 0 0 var(--mprc-space-2);
  font-size: 1.1rem;
  color: var(--mprc-grey-700);
}

/* ---------- Toast ---------- */
.mprc-pub-toast {
  position: fixed; bottom: 24px; left: 50%;
  transform: translateX(-50%) translateY(20px);
  background: var(--mprc-charcoal);
  color: var(--mprc-white);
  padding: 12px 22px;
  border-radius: var(--mprc-radius-pill);
  font-size: .9rem;
  opacity: 0;
  pointer-events: none;
  transition: opacity .25s ease, transform .25s ease;
  z-index: 9999;
}
.mprc-pub-toast.is-visible { opacity: 1; transform: translateX(-50%) translateY(0); }

/* ===========================================================================
   Extras shortcode — Annual Reports + Highlight Collections
   =========================================================================== */
.mprc-pub-extras { padding: var(--mprc-space-4) var(--mprc-space-3); background: var(--mprc-cream); }
.mprc-pub-extras-grid {
  max-width: 1400px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--mprc-space-3);
}
.mprc-pub-extra {
  border-radius: var(--mprc-radius);
  padding: var(--mprc-space-3);
  color: var(--mprc-white);
}
.mprc-pub-extra--reports    { background: var(--mprc-sage); }
.mprc-pub-extra--highlights { background: var(--mprc-gold); color: var(--mprc-charcoal); }
.mprc-pub-extra header { margin-bottom: var(--mprc-space-3); }
.mprc-pub-extra h3 { margin: 0 0 6px; font-size: 1.4rem; font-weight: 700; color: inherit; }
.mprc-pub-extra header p { margin: 0; font-size: .9rem; opacity: .92; }

.mprc-pub-reports-list,
.mprc-pub-highlights-list { list-style: none; padding: 0; margin: 0; }
.mprc-pub-reports-list li,
.mprc-pub-highlights-list li { border-top: 1px solid rgba(255,255,255,.4); }
.mprc-pub-extra--highlights .mprc-pub-highlights-list li { border-top-color: rgba(42,42,42,.18); }
.mprc-pub-reports-list li:last-child,
.mprc-pub-highlights-list li:last-child { border-bottom: 1px solid rgba(255,255,255,.4); }
.mprc-pub-extra--highlights .mprc-pub-highlights-list li:last-child { border-bottom-color: rgba(42,42,42,.18); }

.mprc-pub-reports-list a,
.mprc-pub-highlights-list a {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 4px;
  text-decoration: none;
  color: inherit;
  font-weight: 600;
  font-size: .95rem;
  transition: opacity .15s ease;
}
.mprc-pub-reports-list a:hover,
.mprc-pub-highlights-list a:hover { opacity: .8; }
.mprc-pub-report-icon {
  width: 28px; height: 28px;
  border-radius: 50%;
  background: rgba(255,255,255,.25);
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 1rem;
}
.mprc-pub-highlight-count {
  background: var(--mprc-charcoal);
  color: var(--mprc-gold);
  border-radius: var(--mprc-radius-pill);
  padding: 4px 12px;
  font-weight: 700;
  font-size: .9rem;
}

/* ---------- Responsive ---------- */
@media (max-width: 900px) {
  .mprc-pub-counters { grid-template-columns: repeat(2, 1fr); }
  .mprc-pub-results-layout { grid-template-columns: 1fr; }
  .mprc-pub-sidebar { position: static; }
  .mprc-pub-extras-grid,
  .mprc-pub-dashboard-grid,
  .mprc-pub-advanced-panel { grid-template-columns: 1fr; }
  .mprc-pub-results-header { flex-direction: column; align-items: stretch; }
  .mprc-pub-results-controls { justify-content: space-between; }
  .mprc-pub-grid--list .mprc-pub-card-body,
  .mprc-pub-list-header { grid-template-columns: 1fr; }
  .mprc-pub-grid--list .mprc-pub-card-meta,
  .mprc-pub-grid--list .mprc-pub-card-journal { grid-column: 1; }
}
@media (max-width: 860px) {
  /* Below ~860px: filter row collapses to 2 columns, then 1 column on phones */
  .mprc-pub-filters { grid-template-columns: 1fr 1fr; }
  .mprc-pub-filters .mprc-pub-search { grid-column: 1 / -1; }
  .mprc-pub-filters .mprc-pub-advanced-toggle { grid-column: 1 / -1; }
}
@media (max-width: 560px) {
  .mprc-pub-grid--grid,
  .mprc-pub-grid--card { grid-template-columns: 1fr 1fr; }
  .mprc-pub-filters { grid-template-columns: 1fr; }
  .mprc-pub-filters > * { width: 100%; }
}

/* ============================================================================
 * Phase 6 — Selection + Export workflow (2026-05-13)
 * ============================================================================ */

/* Phase 8d — Card checkbox visibility (third pass).
 * Make the empty state more obvious by filling with cream + dark check icon
 * outline. Avoid white-on-white when checked. */
.mprc-pub-card { position: relative; }
.mprc-pub-card-select {
  position: absolute;
  top: 10px;
  left: 10px;
  z-index: 4;
  width: 28px; height: 28px;
  display: flex; align-items: center; justify-content: center;
  background: var(--mprc-cream-soft, #F2EBDB);
  border: 2px solid var(--mprc-terra);
  border-radius: 5px;
  cursor: pointer;
  transition: transform 120ms, box-shadow 120ms, background 120ms;
  box-shadow: 0 2px 8px rgba(0,0,0,0.25);
}
.mprc-pub-card-select:hover { transform: scale(1.08); box-shadow: 0 3px 12px rgba(0,0,0,0.35); }
.mprc-pub-card-select-input {
  appearance: none !important;
  -webkit-appearance: none !important;
  width: 22px !important; height: 22px !important;
  margin: 0 !important;
  border: 2px solid var(--mprc-charcoal) !important;
  border-radius: 5px !important;
  cursor: pointer;
  background-color: var(--mprc-white) !important;
  background-image: none !important;
  position: relative;
}
/* Phase 8j — single source of truth for the ticked checkbox state.
 * Highest specificity wins via `.mprc-pub-archive` prefix so no Elementor
 * input rule, no `.is-selected` repaint, no shorthand-vs-longhand quirk
 * can take it back to white. The SVG is a clean 16x16 checkmark, stroke
 * width 3, rounded caps, rendered at 14x14 inside the 22x22 box. */
.mprc-pub-archive .mprc-pub-card-select-input:checked,
.mprc-pub-archive .mprc-pub-card.is-selected .mprc-pub-card-select-input {
  background-color: var(--mprc-terra) !important;
  border-color: var(--mprc-terra) !important;
  background-image: url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath fill='none' stroke='%23fff' stroke-width='3' stroke-linecap='round' stroke-linejoin='round' d='M3 8.5l3.5 3.5 7-7.5'/%3E%3C/svg%3E") !important;
  background-size: 14px 14px !important;
  background-position: center !important;
  background-repeat: no-repeat !important;
}
.mprc-pub-card.is-selected { outline: 2px solid var(--mprc-terra); outline-offset: -2px; }

/* In List + Compact views, the checkbox needs to sit inline (not absolute) */
.mprc-pub-grid--list .mprc-pub-card,
.mprc-pub-grid--compact .mprc-pub-card { padding-left: 36px; }
.mprc-pub-grid--list .mprc-pub-card-select,
.mprc-pub-grid--compact .mprc-pub-card-select {
  position: absolute;
  left: 8px;
  top: 50%;
  transform: translateY(-50%);
  background: transparent;
  border: none;
}

/* Selection bar — appears above the grid when 1+ rows selected.
 * Phase 8n — centered column to match toolbar + cards. */
.mprc-pub-selection-bar {
  display: flex;
  align-items: center;
  gap: var(--mprc-space-2);
  padding: 10px var(--mprc-space-2);
  background: var(--mprc-cream-soft);
  border-bottom: 1px solid var(--mprc-grey-300);
  font-size: .85rem;
  color: var(--mprc-charcoal);
  max-width: 1400px;
  width: 100%;
  box-sizing: border-box;
  margin: 0 auto var(--mprc-space-2);
}
.mprc-pub-selection-bar[hidden] { display: none; }
.mprc-pub-selection-count strong { color: var(--mprc-terra); font-weight: 700; }
.mprc-pub-sel-action {
  background: var(--mprc-white);
  border: 1px solid var(--mprc-grey-400, #c4c4c4);
  border-radius: var(--mprc-radius);
  padding: 4px 10px;
  font-size: .8rem;
  cursor: pointer;
  color: var(--mprc-charcoal);
  font-weight: 500;
  transition: background 120ms, border-color 120ms;
}
.mprc-pub-sel-action:hover { background: var(--mprc-cream); border-color: var(--mprc-terra); }
.mprc-pub-sel-clear { color: var(--mprc-terra); border-color: var(--mprc-terra); }
.mprc-pub-sel-clear:hover { background: var(--mprc-terra); color: var(--mprc-white); }

/* Export button — change state when selection is active */
.mprc-pub-export-btn.is-selection-active {
  background: var(--mprc-terra);
  color: var(--mprc-white);
  border-color: var(--mprc-terra);
}
.mprc-pub-export-btn.is-selection-active .mprc-pub-export-count-badge {
  display: inline;
  margin-left: 6px;
  background: var(--mprc-white);
  color: var(--mprc-terra);
  font-weight: 700;
  border-radius: 999px;
  padding: 1px 8px;
  font-size: .75rem;
}
.mprc-pub-export-count-badge { display: none; }
.mprc-pub-export-header-mode { font-size: .75rem; color: var(--mprc-grey-700); margin-top: 2px; }

/* =============================================================================
   Phase 8j (2026-05-14) — beat Elementor's `.elementor button` cascade on the
   remaining controls: Export button (idle + active), View toggle (segmented
   control), and pagination prev/next pills. Same pattern as 8h on the
   Advanced Filters and View Statistics Dashboard toggles.
   ========================================================================== */

/* Export button — idle (no selection): cream pill, charcoal text, hairline border */
.mprc-pub-archive .mprc-pub-export-btn {
  background: var(--mprc-cream-soft) !important;
  color: var(--mprc-charcoal) !important;
  border: 1px solid var(--mprc-grey-300) !important;
  border-radius: var(--mprc-radius-pill) !important;
  padding: 10px 18px !important;
  font-weight: 600 !important;
  height: 44px !important;
}
.mprc-pub-archive .mprc-pub-export-btn:hover {
  background: var(--mprc-cream) !important;
  border-color: var(--mprc-terra) !important;
  color: var(--mprc-terra) !important;
}
.mprc-pub-archive .mprc-pub-export-btn:disabled {
  opacity: .55 !important;
  cursor: not-allowed !important;
}

/* Export button — active (selection present): terracotta fill */
.mprc-pub-archive .mprc-pub-export-btn.is-selection-active {
  background: var(--mprc-terra) !important;
  color: var(--mprc-white) !important;
  border-color: var(--mprc-terra) !important;
}
.mprc-pub-archive .mprc-pub-export-btn.is-selection-active:hover {
  background: var(--mprc-terra-dark) !important;
  border-color: var(--mprc-terra-dark) !important;
}

/* View toggle — segmented control sits in a cream pill wrapper.
   Inactive buttons are transparent; active button is terracotta. */
.mprc-pub-archive .mprc-pub-view-switch {
  background: var(--mprc-cream-soft) !important;
  border: 1px solid var(--mprc-grey-300) !important;
  border-radius: var(--mprc-radius-pill) !important;
  padding: 4px !important;
}
.mprc-pub-archive .mprc-pub-view-btn {
  background: transparent !important;
  color: var(--mprc-grey-700) !important;
  border: none !important;
  border-radius: var(--mprc-radius-pill) !important;
  width: 36px !important;
  height: 36px !important;
}
.mprc-pub-archive .mprc-pub-view-btn:hover {
  background: var(--mprc-cream) !important;
  color: var(--mprc-charcoal) !important;
}
.mprc-pub-archive .mprc-pub-view-btn.is-active {
  background: var(--mprc-terra) !important;
  color: var(--mprc-white) !important;
}

/* Pagination — prev/next pill style, active page chip */
.mprc-pub-archive .mprc-pub-page-prev,
.mprc-pub-archive .mprc-pub-page-next,
.mprc-pub-archive .mprc-pub-page-btn {
  background: var(--mprc-white) !important;
  color: var(--mprc-charcoal) !important;
  border: 1px solid var(--mprc-grey-300) !important;
  border-radius: var(--mprc-radius-pill) !important;
  padding: 10px 18px !important;
}
.mprc-pub-archive .mprc-pub-page-prev:hover,
.mprc-pub-archive .mprc-pub-page-next:hover,
.mprc-pub-archive .mprc-pub-page-btn:hover {
  background: var(--mprc-terra) !important;
  color: var(--mprc-white) !important;
  border-color: var(--mprc-terra) !important;
}
.mprc-pub-archive .mprc-pub-page-btn.is-current,
.mprc-pub-archive .mprc-pub-page-btn.is-active {
  background: var(--mprc-terra) !important;
  color: var(--mprc-white) !important;
  border-color: var(--mprc-terra) !important;
}

/* Per-page dropdown + sort dropdown — same pill treatment as filter row.
 * Phase 8k — longhand background-color + explicit chevron SVG so the
 * dropdown arrow stays visible. */
.mprc-pub-archive .mprc-pub-results-controls select,
.mprc-pub-archive .mprc-pub-per-page,
.mprc-pub-archive .mprc-pub-sort {
  background-color: var(--mprc-white) !important;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 8'%3E%3Cpath fill='%23BC5C39' d='M6 8L0 0h12z'/%3E%3C/svg%3E") !important;
  background-repeat: no-repeat !important;
  background-position: right 16px center !important;
  background-size: 10px !important;
  border: 1px solid var(--mprc-grey-300) !important;
  border-radius: var(--mprc-radius-pill) !important;
  padding: 10px 36px 10px 18px !important;
  height: 44px !important;
  color: var(--mprc-charcoal) !important;
  appearance: none !important;
  -webkit-appearance: none !important;
}

/* Phase 8k — Advanced Filters pill needs more horizontal room so
 * "HIDE ADVANCED FILTERS" doesn't feel cramped. */
.mprc-pub-archive .mprc-pub-advanced-toggle {
  padding: 12px 32px !important;
  min-width: 200px !important;
}

/* Phase 8k — Export dropdown menu needs explicit cream background and
 * cream-soft hover. Elementor's `.elementor button` was painting the option
 * rows dark teal. */
.mprc-pub-archive .mprc-pub-export-menu {
  background: var(--mprc-white) !important;
  border: 1px solid var(--mprc-grey-300) !important;
  border-radius: var(--mprc-radius) !important;
}
.mprc-pub-archive .mprc-pub-export-opt {
  background-color: var(--mprc-white) !important;
  color: var(--mprc-charcoal) !important;
  border: none !important;
  border-bottom: 1px solid var(--mprc-grey-300) !important;
  border-radius: 0 !important;
  padding: 14px 20px !important;
}
.mprc-pub-archive .mprc-pub-export-opt:last-child {
  border-bottom: none !important;
}
.mprc-pub-archive .mprc-pub-export-opt:hover,
.mprc-pub-archive .mprc-pub-export-opt:focus-visible {
  background-color: var(--mprc-cream-soft) !important;
  color: var(--mprc-charcoal) !important;
}
.mprc-pub-archive .mprc-pub-export-opt strong {
  color: var(--mprc-charcoal) !important;
  font-weight: 700 !important;
}
.mprc-pub-archive .mprc-pub-export-opt span {
  color: var(--mprc-grey-500) !important;
}

/* Phase 8k — Selection toolbar action buttons (Select all on this page,
 * Select all matching filters, Clear selection). Currently painted dark
 * by Elementor's `.elementor button`. Switch to cream pill, terracotta hover. */
.mprc-pub-archive .mprc-pub-sel-action {
  background-color: var(--mprc-white) !important;
  color: var(--mprc-charcoal) !important;
  border: 1px solid var(--mprc-grey-300) !important;
  border-radius: var(--mprc-radius-pill) !important;
  padding: 8px 16px !important;
  font-weight: 600 !important;
  font-size: .8rem !important;
  text-transform: uppercase !important;
  letter-spacing: .04em !important;
}
.mprc-pub-archive .mprc-pub-sel-action:hover {
  background-color: var(--mprc-terra) !important;
  color: var(--mprc-white) !important;
  border-color: var(--mprc-terra) !important;
}
.mprc-pub-archive .mprc-pub-sel-clear {
  background-color: var(--mprc-cream-soft) !important;
  color: var(--mprc-terra) !important;
  border-color: var(--mprc-terra) !important;
}
.mprc-pub-archive .mprc-pub-sel-clear:hover {
  background-color: var(--mprc-terra) !important;
  color: var(--mprc-white) !important;
  border-color: var(--mprc-terra) !important;
}

/* Phase 8l — focus ring only on KEYBOARD focus (:focus-visible), not on
 * mouse click (:focus). Mouse-clicked buttons no longer paint a halo that
 * reads as "overflow" on the pill controls. Keyboard users still get the
 * accessibility cue. */
.mprc-pub-archive button:focus,
.mprc-pub-archive input:focus,
.mprc-pub-archive select:focus {
  outline: none !important;
  box-shadow: none !important;
}
.mprc-pub-archive button:focus-visible,
.mprc-pub-archive input:focus-visible,
.mprc-pub-archive select:focus-visible {
  outline: none !important;
  box-shadow: 0 0 0 2px rgba(188, 92, 57, 0.25) !important;
}

/* Phase 8j — focus state for every pill control inside the archive.
 * The browser default outline draws a SQUARE around the pill (the "blue
 * overflow" Robert circled). Replace it with a box-shadow ring that follows
 * the pill's border-radius. Reset outline to none, then paint a 3px
 * terracotta-tinted halo when focused via keyboard or pointer. */
.mprc-pub-archive button,
.mprc-pub-archive input,
.mprc-pub-archive select,
.mprc-pub-archive .mprc-pub-page-btn,
.mprc-pub-archive .mprc-pub-page-prev,
.mprc-pub-archive .mprc-pub-page-next,
.mprc-pub-archive .mprc-pub-view-btn,
.mprc-pub-archive .mprc-pub-advanced-toggle,
.mprc-pub-archive .mprc-pub-dashboard-toggle,
.mprc-pub-archive .mprc-pub-export-btn {
  outline: none !important;
}
.mprc-pub-archive button:focus,
.mprc-pub-archive button:focus-visible,
.mprc-pub-archive input:focus,
.mprc-pub-archive input:focus-visible,
.mprc-pub-archive select:focus,
.mprc-pub-archive select:focus-visible {
  outline: none !important;
  box-shadow: 0 0 0 3px rgba(188, 92, 57, 0.35) !important;
}
