/* =========================================================
   Conjurly News Feed
   ========================================================= */

.cnjrly-news-feed-wrap {
  display: flex;
  flex-direction: column;
}

/* =========================================================
   Filter Form
   ========================================================= */
.cnjrly-news-feed__filter-form {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 24px;
}

/* Primary row: one line on desktop, no wrap */
.cnjrly-news-feed__filter-primary {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: nowrap;
}

/* Secondary row: state/country */
.cnjrly-news-feed__filter-secondary {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: nowrap;
}

/* Action row: Apply + Clear */
.cnjrly-news-feed__filter-actions {
  display: flex;
  align-items: center;
  gap: 8px;
}

/* Shared select styling */
.cnjrly-news-feed__filter-select {
  flex: 1 1 0;
  min-width: 0;
  height: 40px;
  padding: 0 28px 0 12px;
  border: 1px solid var(--cj-border-light, #e6e7eb);
  border-radius: var(--cj-radius-input, 10px);
  background: var(--cj-surface-primary, #fff);
  font-size: 0.875rem;
  font-weight: 500;
  color: rgba(0, 0, 0, 0.72);
  cursor: pointer;
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23aaa' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 10px center;
  transition: border-color 0.14s, box-shadow 0.14s;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.cnjrly-news-feed__filter-select:hover {
  border-color: rgba(0, 0, 0, 0.28);
}

.cnjrly-news-feed__filter-select:focus {
  outline: none;
  border-color: var(--cj-link, #4c187e);
  box-shadow: 0 0 0 3px rgba(76, 24, 126, 0.12);
}

.cnjrly-news-feed__filter-select.cnjrly-active {
  border-color: var(--cj-link, #4c187e);
  color: var(--cj-link, #4c187e);
  font-weight: 600;
}

/* Apply button */
.cnjrly-news-feed__apply {
  height: 40px;
  padding: 0 20px;
  border: 0;
  border-radius: var(--cj-radius-btn, 10px);
  background: var(--cj-indigo, #4c187e);
  color: var(--cj-surface-primary-text, #fff);
  font-size: 0.875rem;
  font-weight: 700;
  cursor: pointer;
  transition: filter 0.14s;
  white-space: nowrap;
}

.cnjrly-news-feed__apply:hover {
  filter: brightness(1.06);
}

/* Clear link — Ember by default, muted on hover */
.cnjrly-news-feed__clear {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  height: 40px;
  padding: 0 10px;
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--cj-link, #4c187e);
  text-decoration: none;
  white-space: nowrap;
  transition: color 0.14s;
}

.cnjrly-news-feed__clear:hover {
  color: var(--cj-link-hover, #6f4697);
  text-decoration: none;
}

/* Mobile toggle button — now shown on ALL screen sizes */
.cnjrly-news-feed__filter-toggle {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  height: 40px;
  padding: 0 16px;
  margin-bottom: 4px;
  border: 1px solid var(--cj-border-light, #e6e7eb);
  border-radius: var(--cj-radius-btn, 10px);
  background: var(--cj-surface-primary, #fff);
  font-size: 0.875rem;
  font-weight: 600;
  color: rgba(0, 0, 0, 0.7);
  cursor: pointer;
  transition: border-color 0.14s;
}

.cnjrly-news-feed__filter-toggle:hover {
  background: var(--cj-indigo, #4c187e);
  border-color: var(--cj-indigo, #4c187e);
  color: var(--cj-surface-primary-text, #fff);
}

/* Open state */
.cnjrly-news-feed__filter-toggle[aria-expanded="true"] {
  border-color: var(--cj-indigo, #4c187e) !important;
  color: var(--cj-indigo, #4c187e) !important;
  background: var(--cj-surface-primary, #fff) !important;
  opacity: 1 !important;
}

/* Form hidden by default on ALL screen sizes — toggle opens it */
.cnjrly-news-feed__filter-form {
  display: none;
}

.cnjrly-news-feed__filter-form.cnjrly-filter-form--open {
  display: flex;
}

/* AJAX results */
.cnjrly-news-feed-results {
  transition: opacity 0.25s ease;
}

/* Pagination */
.cnjrly-news-feed__pagination {
  margin-top: 2rem;
}

.cnjrly-news-feed__pagination .page-numbers {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 2.4rem;
  height: 2.4rem;
  margin: 0 0.2rem 0.4rem 0;
  padding: 0 0.75rem;
  border: 1px solid var(--cj-border-light, #e6e7eb);
  border-radius: var(--cj-radius-btn, 10px);
  background: var(--cj-surface-primary, #fff);
  color: var(--cj-indigo, #4c187e);
  text-decoration: none;
  font-weight: 500;
  cursor: pointer;
  transition: background-color 0.15s ease, border-color 0.15s ease, color 0.15s ease, box-shadow 0.15s ease;
}

.cnjrly-news-feed__pagination .page-numbers:hover {
  border-color: var(--cj-indigo, #4c187e);
  background: rgba(76, 24, 126, 0.06);
  color: var(--cj-indigo-hover, #6f4697);
  text-decoration: none;
}

.cnjrly-news-feed__pagination .current,
.cnjrly-news-feed__pagination .current:hover {
  font-weight: 700;
  border-color: var(--cj-indigo, #4c187e);
  background: var(--cj-indigo, #4c187e);
  color: var(--cj-surface-primary-text, #fff);
  cursor: default;
}

.cnjrly-news-feed__pagination .page-numbers.dots,
.cnjrly-news-feed__pagination .page-numbers.dots:hover {
  border-color: transparent;
  background: transparent;
  cursor: default;
  color: rgba(0,0,0,0.4);
}

/* =========================================================
   Feed grid
   ========================================================= */
.cnjrly-news-feed {
  display: grid;
  gap: 1.5rem;
  margin-top: 1.6rem;
}

.cnjrly-news-feed__entry { margin: 0; }

.cnjrly-news-feed__item {
  display: grid;
  grid-template-columns: minmax(260px, 340px) minmax(0, 1fr);
  gap: 0;
  border: 1px solid rgba(0, 0, 0, 0.08);
  border-radius: var(--cj-radius-card, 14px);
  background: var(--cj-surface-primary, #fff);
  color: inherit;
  text-decoration: none;
  overflow: hidden;
  transition: transform 0.16s ease, box-shadow 0.16s ease, border-color 0.16s ease;
}

.cnjrly-news-feed__item:hover,
.cnjrly-news-feed__item:focus { color: inherit; text-decoration: none; }

.cnjrly-news-feed__item:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 22px rgba(0, 0, 0, 0.06);
  border-color: rgba(0, 0, 0, 0.12);
}

.cnjrly-news-feed__item:focus-visible {
  outline: 2px solid var(--cj-focus-outline-color, #4c187e);
  outline-offset: 2px;
}

.cnjrly-news-feed__item--no-thumb { grid-template-columns: 1fr; }

.cnjrly-news-feed__thumb {
  display: block;
  margin: 0;
  overflow: hidden;
  background: var(--bb-content-alternate-background-color, #f7f7f7);
  align-self: stretch;
}

.cnjrly-news-feed__thumb img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.cnjrly-news-feed__content {
  min-width: 0;
  padding: 1rem 1.1rem 1.1rem;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
}

.cnjrly-news-feed__type {
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--cj-indigo, #4c187e);
  margin-bottom: 0.35rem;
}

.cnjrly-news-feed .cnjrly-news-feed__title {
  margin: 0 0 0.42rem;
  font-family: var(--cnjrly-news-headline-font-family, var(--cj-font-serif, "IBM Plex Serif", serif));
  font-weight: var(--cnjrly-news-headline-font-weight, 600);
  font-size: var(--cnjrly-news-headline-font-size-feed, clamp(1.8rem, 2.25vw, 2.2rem));
  line-height: var(--cnjrly-news-headline-line-height, 1.05);
  letter-spacing: var(--cnjrly-news-headline-letter-spacing, -0.015em);
  color: rgba(0, 0, 0, 0.88);
  transition: color 0.16s ease;
}

.cnjrly-news-feed .cnjrly-news-feed__item:hover .cnjrly-news-feed__title,
.cnjrly-news-feed .cnjrly-news-feed__item:focus-visible .cnjrly-news-feed__title {
  color: var(--cj-indigo, #4c187e);
}

.cnjrly-news-feed__date {
  font-size: 0.9rem;
  color: rgba(0, 0, 0, 0.65);
  margin-bottom: 0.22rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.cnjrly-news-feed__meta {
  font-size: 0.9rem;
  color: rgba(0, 0, 0, 0.6);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* =========================================================
   Desktop
   ========================================================= */
@media (min-width: 783px) {
  /* Fixed card height anchors both image and content columns equally */
  .cnjrly-news-feed__item {
    align-items: stretch;
    height: 260px;
  }

  .cnjrly-news-feed__thumb {
    align-self: stretch;
    overflow: hidden;
  }

  .cnjrly-news-feed__thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center center;
  }

  .cnjrly-news-feed .cnjrly-news-feed__title {
    letter-spacing: var(--cnjrly-news-headline-letter-spacing-tight, -0.02em);
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
    overflow: hidden;
    min-height: calc(var(--cnjrly-news-headline-line-height, 1.05) * 3em);
  }
}

/* =========================================================
   Mobile
   ========================================================= */
@media (max-width: 782px) {

  /* Stack all rows vertically on mobile */
  .cnjrly-news-feed__filter-primary,
  .cnjrly-news-feed__filter-secondary {
    flex-direction: column;
    align-items: stretch;
  }

  /* Full width selects */
  .cnjrly-news-feed__filter-select {
    flex: none;
    width: 100%;
    height: 44px;
    font-size: 0.9rem;
  }

  /* Apply takes full width, clear sits beside it */
  .cnjrly-news-feed__filter-actions {
    flex-wrap: wrap;
  }

  .cnjrly-news-feed__apply {
    flex: 1;
    height: 44px;
    font-size: 0.9rem;
  }

  /* Card layout */
  .cnjrly-news-feed__item { grid-template-columns: 1fr; }

  .cnjrly-news-feed__thumb img {
    width: 100%;
    height: auto;
    aspect-ratio: 16 / 9;
    object-fit: cover;
  }

  .cnjrly-news-feed__content { padding: 0.95rem 1rem 1.05rem; }

  .cnjrly-news-feed .cnjrly-news-feed__title { font-size: 1.7rem; line-height: 1.06; }
}

/* =========================================================
   Date range filter row
   ========================================================= */
.cnjrly-news-feed__filter-date-row {
  display: flex;
  align-items: center;
  gap: 8px;
}

.cnjrly-news-feed__filter-date {
  flex: 1 1 0;
  height: 40px;
  padding: 0 12px;
  border: 1px solid var(--cj-border-light, #e6e7eb);
  border-radius: var(--cj-radius-input, 10px);
  background: var(--cj-surface-primary, #fff);
  font-size: 0.875rem;
  font-weight: 500;
  color: rgba(0, 0, 0, 0.72);
  cursor: pointer;
  transition: border-color 0.14s, box-shadow 0.14s;
  min-width: 0;
}

.cnjrly-news-feed__filter-date:focus {
  outline: none;
  border-color: var(--cj-link, #4c187e);
  box-shadow: 0 0 0 3px rgba(76, 24, 126, 0.12);
}

.cnjrly-news-feed__filter-date::-webkit-calendar-picker-indicator {
  opacity: 0.5;
  cursor: pointer;
}

.cnjrly-news-feed__filter-date-sep {
  flex-shrink: 0;
  color: rgba(0, 0, 0, 0.35);
  font-size: 0.9rem;
}

@media (max-width: 782px) {
  .cnjrly-news-feed__filter-date {
    height: 44px;
    font-size: 0.9rem;
  }
}

/* =========================================================
   Feed loader — CSS spinner
   ========================================================= */
.cnjrly-feed-loader {
  display: none;
  text-align: center;
  padding: 20px 0 12px;
}

.cnjrly-feed-loader.cnjrly-feed-loader--active {
  display: block;
}

.cnjrly-feed-loader__spinner {
  display: inline-block;
  width: 36px;
  height: 36px;
  border: 3px solid var(--cj-border-light, #e6e7eb);
  border-top-color: var(--cj-indigo, #4c187e);
  border-radius: 50%;
  animation: cnjrly-spin 0.7s linear infinite;
}

@keyframes cnjrly-spin {
  to { transform: rotate(360deg); }
}

/* =========================================================
   Toggle row — description left | Clear All + Filter button right
   ========================================================= */
.cnjrly-news-feed__toggle-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 4px;
}

.cnjrly-news-feed__filter-desc {
  flex: 1 1 0;
  min-width: 0;
  font-size: 0.82rem;
  font-weight: 500;
  color: rgba(0, 0, 0, 0.55);
}

/* Desktop: all inline with pipe separators */
.cnjrly-filter-desc__heading {
  font-weight: 700;
  color: rgba(0, 0, 0, 0.65);
  display: block;
  margin-bottom: 3px;
}

/* Default state (no active filters) — all inline on one line */
.cnjrly-filter-desc--default .cnjrly-filter-desc__heading {
  display: inline;
  margin-bottom: 0;
}

.cnjrly-filter-desc--default .cnjrly-filter-desc__sep {
  display: inline;
}

.cnjrly-filter-desc__sep {
  display: none; /* Stacking everywhere — sep not needed */
}

.cnjrly-filter-desc__item {
  display: block;
  padding-left: 8px;
  line-height: 1.6;
}

/* No CSS ::before pipe — pipes emitted by JS where needed */

.cnjrly-filter-desc__lbl {
  font-weight: 600;
  color: rgba(0, 0, 0, 0.6);
}

.cnjrly-filter-desc__val {
  color: rgba(0, 0, 0, 0.75);
}

.cnjrly-news-feed__toggle-actions {
  display: flex;
  align-items: center;
  gap: 4px;
  flex-shrink: 0;
  margin-left: auto;
}

/* Mobile: toggle row stacks when filters active, single row when default */
@media (max-width: 782px) {
  .cnjrly-news-feed__toggle-row {
    flex-direction: column;
    align-items: stretch;
    gap: 6px;
  }

  /* Default state — keep on one row with Filter button */
  .cnjrly-feed--default .cnjrly-news-feed__toggle-row {
    flex-direction: row;
    align-items: center;
    gap: 10px;
  }

  .cnjrly-news-feed__toggle-actions {
    width: 100%;
    justify-content: flex-end;
  }

  .cnjrly-feed--default .cnjrly-news-feed__toggle-actions {
    width: auto;
    flex-shrink: 0;
  }
}

.cnjrly-news-feed-results {
  position: relative;
}


/* =========================================================
   News feed page — two-column layout with right rail
   Mirrors single news rail width (300px) for consistency
   ========================================================= */
.cnjrly-news-page-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 300px;
  gap: 24px;
  align-items: start;
}

.cnjrly-news-page-main {
  min-width: 0;
}

.cnjrly-news-page-rail {
  min-width: 0;
}

/* Widget styling within the rail */
.cnjrly-news-page-rail .cj-widget {
  margin-bottom: 1.5rem;
}

.cnjrly-news-page-rail .cj-widget-title {
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(0, 0, 0, 0.45);
  margin-bottom: 12px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--cj-border-light, #e6e7eb);
}

/* Collapse to single column on mobile */
@media (max-width: 782px) {
  .cnjrly-news-page-layout {
    grid-template-columns: 1fr;
  }

  .cnjrly-news-page-rail--right {
    display: none;
  }
}


/* =========================================================
   News Feed rail behavior
   Reserve right rail width whenever show_sidebar="yes"
   Header/filter/results all live in the main content column
   ========================================================= */

.cnjrly-news-page-main {
  width: 100%;
}

.cnjrly-news-page-rail--right {
  min-height: 1px;
}


/* =========================================================
   News Feed rail behavior
   Reserve right rail width whenever show_sidebar="yes"
   Header, filters, and results all sit inside the main column
   ========================================================= */
.cnjrly-news-page-layout {
  align-items: start;
}

.cnjrly-news-page-main {
  min-width: 0;
  width: 100%;
}

.cnjrly-news-page-rail--right {
  min-width: 0;
  min-height: 1px;
}




/* =========================================================
   News Feed header + filter shell
   ========================================================= */
.cnjrly-news-section-card {
  margin: 0 0 1.5rem;
  overflow: hidden;
  border: none; /* components.css adds border to outer wrapper; suppressed until UI Core removes it */
  background: transparent; /* components.css adds white background; transparent prevents bleeding through header bottom corners and collapsed-margin gap */
}

.cnjrly-news-section-card .cnjrly-section-card__header {
  margin: 0;
  border-radius: var(--cj-radius-card, 14px) var(--cj-radius-card, 14px) 0 0;
  padding: 14px 18px 15px; /* explicit values replace --cj-page-header-pad-y-bottom (~0px) which allows title margin-bottom to collapse out of the header */
}

.cnjrly-news-section-card .cnjrly-section-card__title {
  margin: 0; /* header padding-bottom now provides spacing; margin: 0 prevents any residual collapse */
  font-family: var(--cj-font-headline, 'IBM Plex Sans Condensed', sans-serif); /* News zone serif headline bleeds into UI chrome without explicit override */
}

.cnjrly-news-section-card .cnjrly-section-card__body {
  padding: 14px 16px;
  border-top: 0;
  border-radius: 0 0 var(--cj-radius-card, 14px) var(--cj-radius-card, 14px);
  border: 1px solid rgba(0, 0, 0, 0.08);
  border-top: none;
}

.cnjrly-news-section-card .cnjrly-news-feed__filter-form {
  margin-bottom: 0;
}

.cnjrly-news-section-card .cnjrly-news-feed__toggle-row {
  margin-bottom: 4px;
}

@media (max-width: 782px) {
  .cnjrly-news-section-card .cnjrly-section-card__body {
    padding: 20px;
  }
}

/* Limited Ember accent: curated News Watch label only */
.cnjrly-news-feed__item--cnjrly_news_watch .cnjrly-news-feed__type {
  color: var(--cj-ember, #d97d37);
}
