/* ════════════════════════════════════════════════════════════════
   recipe-list.css — page-specific styles for /recipes/
   Loaded via {% block extra_head %} in templates/recipes/list.html.

   The shared components (.recipe-grid, .rcard*, .pagination*,
   .empty-state*, .search-box*) live in cosmic.css and are reused as-is.
   Only the page chrome the mockup introduces lives here:
   .page wrapper, .page-header/.page-title/.page-count, .controls-bar,
   the filter controls (.filter-group/.filter-select/.filter-chip) and
   .sort-menu. These are promotion candidates if a second list page
   reuses them.
   ════════════════════════════════════════════════════════════════ */

/* .page wrapper is canonical in cosmic.css (shared by all content pages). */

/* ── Page header ────────────────────────────────────────────────── */
.page-header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 2rem;
  margin-bottom: 2rem;
  padding-bottom: 1.5rem;
  border-bottom: 1px solid var(--line);
}
.page-title {
  font-family: 'Fraunces', Georgia, serif;
  font-weight: 400;
  font-size: 2.8rem;
  color: var(--text);
  letter-spacing: -.015em;
  margin: 0;
}
.page-count {
  font-family: 'DM Mono', monospace;
  font-size: .76rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--muted);
}

/* ── Controls bar ───────────────────────────────────────────────── */
.controls-bar {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  align-items: center;
  margin-bottom: 2rem;
  padding-bottom: 1.5rem;
  border-bottom: 1px solid var(--line);
}
.filter-group {
  display: flex;
  gap: .5rem;
  flex-wrap: wrap;
  flex: 1;
}

/* Native <select>s styled to sit alongside the chip toggle. */
.filter-select {
  appearance: none;
  -webkit-appearance: none;
  padding: .5rem .95rem;
  background: var(--surface-low);
  border: 1px solid transparent;
  border-radius: var(--r-pill);
  font-family: 'Manrope', sans-serif;
  font-size: .82rem;
  font-weight: 500;
  color: var(--text);
  cursor: pointer;
  transition: background .2s, color .2s;
}
.filter-select:hover { background: rgba(43,38,32,0.08); }
.filter-select:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

/* Boolean toggle, styled as a chip; the checkbox itself is hidden. */
.filter-chip {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  padding: .5rem .95rem;
  background: var(--surface-low);
  border: 1px solid transparent;
  border-radius: var(--r-pill);
  font-family: 'Manrope', sans-serif;
  font-size: .82rem;
  font-weight: 500;
  color: var(--text);
  cursor: pointer;
  transition: background .2s, color .2s;
}
.filter-chip:hover { background: rgba(43,38,32,0.08); }
.filter-chip.is-active {
  background: var(--primary-deep);
  color: #fff;
}
.filter-chip.is-active::after {
  content: '✕';
  font-size: .7rem;
  opacity: .85;
  margin-left: .15rem;
}

/* ── Sort menu ──────────────────────────────────────────────────── */
.sort-menu {
  display: flex;
  align-items: center;
  gap: .5rem;
  font-family: 'Space Grotesk', sans-serif;
  font-size: .68rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--muted);
}
.sort-menu select {
  background: none;
  border: none;
  outline: none;
  font-family: inherit;
  font-size: inherit;
  letter-spacing: inherit;
  color: var(--text);
  cursor: pointer;
  padding: .3rem .5rem;
}

/* (a.rcard link reset is canonical in cosmic.css.) */

/* .pagination* styles live in cosmic.css */

@media (max-width: 640px) {
  .page-header { flex-direction: column; align-items: flex-start; gap: .5rem; }
  .page-title { font-size: 2.2rem; }
  .controls-bar { gap: .75rem; }
  .search-box { min-width: 100%; }
  .recipe-grid { grid-template-columns: repeat(2, 1fr); gap: 1rem; }
}

/* ════════════════════════════════════════════════════════════════
   Seasonal ingredient picker
   Ported from the v1 /recipes/ page, re-tokened to cosmic.css. Pills,
   year-round boxout and free-text add box AJAX-search recipes; while a
   selection is active the browse grid is swapped for #picker-results.
   ════════════════════════════════════════════════════════════════ */
.ingredient-picker {
  margin-bottom: 2rem;
  padding-bottom: 1.75rem;
  border-bottom: 1px solid var(--line);
}
.ingredient-picker__heading {
  font-family: 'Fraunces', Georgia, serif;
  font-weight: 400;
  font-size: 1.5rem;
  color: var(--text);
  letter-spacing: -.01em;
  margin: 0 0 .35rem;
}
.ingredient-picker__sub {
  display: block;
  font-family: 'DM Mono', monospace;
  font-size: .68rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 1rem;
}
.ingredient-picker__body {
  display: flex;
  align-items: flex-start;
  gap: 1.25rem;
}
.ingredient-picker__main { flex: 1; min-width: 0; }

/* ── Pills ──────────────────────────────────────────────────────── */
.season-pills {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
}
.season-pill {
  background: var(--surface-low);
  color: var(--text);
  border: 1px solid transparent;
  border-radius: var(--r-pill);
  padding: .4rem .9rem;
  font-family: 'Manrope', sans-serif;
  font-size: .82rem;
  font-weight: 500;
  cursor: pointer;
  transition: background .2s, color .2s, border-color .2s;
}
.season-pill:hover:not(.is-active) { background: rgba(43,38,32,0.08); }
.season-pill.is-active {
  background: var(--primary-deep);
  color: #fff;
  border-color: var(--primary);
}

/* ── Free-text add + autocomplete ───────────────────────────────── */
.ingredient-add-row {
  display: flex;
  align-items: center;
  gap: .5rem;
  margin-top: .85rem;
  flex-wrap: wrap;
}
.ingredient-add-wrap { position: relative; display: inline-block; }
.ingredient-add-input {
  background: var(--surface-low);
  color: var(--text);
  border: 1px solid transparent;
  border-radius: var(--r-pill);
  padding: .45rem .95rem;
  font-family: 'Manrope', sans-serif;
  font-size: .82rem;
  outline: none;
  width: 15rem;
  transition: border-color .2s, background .2s;
}
.ingredient-add-input::placeholder { color: var(--muted); }
.ingredient-add-input:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}
.ingredient-add-btn {
  background: var(--surface-hi);
  color: var(--primary-deep);
  border: 1px solid transparent;
  border-radius: var(--r-pill);
  padding: .45rem .95rem;
  font-family: 'Manrope', sans-serif;
  font-size: .82rem;
  font-weight: 600;
  cursor: pointer;
  transition: background .2s, color .2s;
}
.ingredient-add-btn:hover { background: var(--primary-deep); color: #fff; }
.ingredient-autocomplete {
  position: absolute;
  top: calc(100% + 4px);
  left: 0;
  min-width: 15rem;
  background: var(--surface-raised);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  box-shadow: 0 8px 32px rgba(0,0,0,0.25);
  overflow: hidden;
  z-index: 100;
  list-style: none;
  margin: 0;
  padding: .3rem 0;
}
.ingredient-autocomplete li button {
  width: 100%;
  background: none;
  border: none;
  text-align: left;
  padding: .4rem .95rem;
  font-family: 'Manrope', sans-serif;
  font-size: .82rem;
  color: var(--text);
  cursor: pointer;
  transition: background .1s, color .1s;
}
.ingredient-autocomplete li button:hover,
.ingredient-autocomplete li button.is-focused {
  background: var(--primary-deep);
  color: #fff;
}

/* ── Year-round boxout ──────────────────────────────────────────── */
.yearround-boxout {
  flex-shrink: 0;
  width: 28%;
  background: var(--surface-low);
  border-radius: var(--r-lg);
  padding: .85rem .9rem .95rem;
}
.yearround-boxout .ingredient-picker__sub { margin-bottom: .65rem; }
.yr-cat-pills {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: .4rem;
}
.yr-cat-pill {
  background: var(--surface-raised);
  color: var(--muted);
  border: none;
  border-radius: var(--r-pill);
  padding: .3rem .75rem;
  font-family: 'Manrope', sans-serif;
  font-size: .76rem;
  font-weight: 500;
  cursor: pointer;
  transition: background .2s, color .2s;
}
.yr-cat-pill:hover { color: var(--text); }
.yr-cat-pill.is-active { background: var(--primary-deep); color: #fff; }

/* ── Picker results ─────────────────────────────────────────────── */
.picker-results { margin-bottom: 2.5rem; }
.picker-results__status {
  font-family: 'DM Mono', monospace;
  font-size: .72rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--muted);
  margin: 0 0 1rem;
}

@media (max-width: 699px) {
  .ingredient-picker__body { flex-direction: column; }
  .yearround-boxout { width: 100%; }
  .ingredient-add-input { width: 100%; }
  .ingredient-add-wrap { flex: 1; display: block; }
}
