/* css */

/* -----------------------
   Base / page-level
   ----------------------- */

:root {
  --facet-line-height: 2rem; /* adjust to taste */
  --btn-bg: #1B444B;
  --btn-bg-hover: #2E6B74;
  --btn-highlight: #9b9b9b;
  --btn-border: #083036;
  /* Set to the surrounding UI background where the button sits (change if needed) */
  --btn-gap-color: #fafafa;
}

body {
    font-family: system-ui, -apple-system, "Open Sans", sans-serif;
    margin: 0;
    background: #ebebeb;
    color: #111111;
    box-sizing: border-box;
    overflow: visible !important;
}

html, body {
  height: auto !important;
  min-height: 0 !important;
}

pre {
    background: #f5f5f5;
    padding: 1rem;
    border-radius: 4px;
    overflow-x: auto;
    font-size: 0.9rem;
}

/* utility for screen-reader-only text */
.visually-hidden {
    position:absolute;
    left:-10000px;
    width:1px;
    height:1px;
    overflow:hidden;
}


/* -----------------------
   Layout: facets + results
   - Desktop: two-column grid (260px sidebar)
   - Tablet: keeps sidebar but responsive grid for cards
   - Phone: facets stacked above results
   ----------------------- */
.layout {
    display: grid;
    grid-template-columns: 260px 1fr;
    grid-template-areas: "facets results";
    gap: 1rem;
    align-items: start;
}

/* area mapping */
.facets { grid-area: facets; }
.results { grid-area: results; flex: 1; }

/* css */
/* -----------------------
   Facets panel (tidy, accessible)
   ----------------------- */
.facet-group fieldset {
  border: none;
  box-shadow: none;
  margin: 0;
  padding: 0;
  min-inline-size: 0;
}

/* Visible heading for the group (or use legend with .visually-hidden to hide visually) */
.facet-group legend{
  display: block;
  margin: 0 0 0.5rem 0;
  padding: 0;
  font-weight: 700;
  font-size: 1rem;
  line-height: 1.2;
  color: inherit;
}

/* Use the single site-wide helper (defined earlier) for screen-reader-only text.
   If you need a clipping variant specifically for legend, reuse .visually-hidden. */

/* Base select styling (single-line dropdowns) */
.facet-group .facet-options select {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  padding: 0.35rem 0.6rem;
  border: 1px solid #bfc9cb;      /* subtle but sufficient contrast against white */
  background: #ffffff;
  border-radius: 4px;
  width: 100%;
  box-sizing: border-box;
  height: var(--facet-line-height);
  line-height: var(--facet-line-height);
  color: #111111;
  text-align: left;
  text-overflow: ellipsis;
  white-space: nowrap;
  overflow: hidden;
  cursor: pointer;
}

/* Multi-select listbox: show internal scrollbar and ~4 rows by default */
.facet-group .facet-options select[multiple] {
  -webkit-appearance: listbox;
  appearance: listbox;
  height: calc(1.2em * 4 + 0.8em);
  max-height: calc(1.2em * 4 + 0.8em);
  overflow-y: auto;
  white-space: normal;
  padding: 0.35rem 0.5rem;
  min-height: auto;
  cursor: auto;
}

/* If a multi-select is forced to behave like a one-line dropdown (size="1"),
   keep the one-line appearance while remaining keyboard accessible. */
.facet-group .facet-options select[size="1"],
.facet-group .facet-options select[multiple][size="1"] {
  -webkit-appearance: menulist-button;
  appearance: menulist-button;
  height: var(--facet-line-height);
  line-height: var(--facet-line-height);
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
  cursor: pointer;
  padding: 0.35rem 0.6rem;
  margin-bottom: 0.5rem;
}

.facet-group .facet-options input[type="text"],
.facets input[type="text"] {
  height: var(--facet-line-height);
  line-height: var(--facet-line-height);
  padding: 0.35rem 0.6rem;
  box-sizing: border-box;
  border: 1px solid #bfc9cb;
  border-radius: 4px;
  background: #ffffff;
  width: 100%;
  overflow: hidden;
}

/* Accessible focus: strong visible focus ring and a contrasty border change */
.facet-group .facet-options select:focus,
.facet-group .facet-options select[size="1"]:focus,
.facet-group .facet-options select[multiple]:focus {
  outline: none;
  border-color: #1B444B; /* darker accent */
  box-shadow: 0 0 0 3px rgba(46,107,116,0.18);
  background-color: #fff;
}

/* Facets container */
.facets {
  box-sizing: border-box;
  width: 260px;
  border: 1px solid #ddd;
  border-radius: 4px;
  padding: 1rem;
  background: #fafafa;
  font-size: 0.9rem;
}

/* Spacing and small helpers */
.facet-group {
  margin-bottom: 0.5rem;
}

.facet-option {
  display: block;
  margin-bottom: 0.25rem;
  white-space: nowrap;
}

.checkbox-options {
  font-size: 0.75rem;
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
}

.facet-checkbox {
  display: block;
}

.facet-checkbox input {
  margin-right: 0.2rem;
}

/* Actions row */
.facet-actions {
  margin-top: 0.5rem;
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
}

.facet-actions button,
.facet-actions a {
  font-size: 0.8rem;
}


/* -----------------------
   Results header / controls
   ----------------------- */

.results-summary { font-size: 0.9rem; }

/* consolidated view-toggle styling */
.view-toggle {
    display: flex;
    align-items: center;
    gap: 0.25rem;
    font-size: 0.85rem;
}

.view-toggle-label { font-size: 0.85rem; color: #fff; }

.results {
  display: flex;
  flex-direction: column;
  align-items: center; /* center inner content so header aligns with grids */
}

/* give header, grids and empty message the same constrained width/padding */
.results > .results-header,
.results > .card-grid,
.results > .list-grid,
.results > .empty-message {
  width: 100%;
  max-width: 1180px; /* adjust to match your content width */
  box-sizing: border-box;
  padding: 0 1rem; /* match page gutter */
}

/* keep header layout and ensure toggle sits to the right */
.results-header {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 1rem;
}

.pagination-controls {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-top: 1rem;
  margin-bottom: 1rem;
}

/* -----------------------
   Buttons
   ----------------------- */

/* css */
/* Replace buttons section in `v6/static/styles.css` with this consolidated block */

/* apply to all button-like controls (buttons, anchors, view/clear controls, facet/card actions) */
.btn,
a.btn,
span.btn,
button.btn,
.view-btn,
.clear-search,
.facet-actions button,
.facet-actions a,
.card-actions button,
.card-actions a {
  box-sizing: border-box;
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  position: relative;
  background-color: var(--btn-bg);
  color: #ffffff;
  border: none;
  padding: 0.45rem 0.75rem;
  border-radius: 4px;
  cursor: pointer;
  text-decoration: none;
  white-space: nowrap;
  transition: background-color 150ms ease, box-shadow 150ms ease, filter 120ms ease;
  will-change: box-shadow, background-color;
}

/* make smaller variants consistent */
.view-btn,
.clear-search {
  padding: 0.25rem 0.5rem;
  font-size: 0.85rem;
}

/* remove underlines from pseudo-elements */
.btn::before,
.btn::after,
a.btn::before,
a.btn::after {
  text-decoration: none;
}

/* hover (ignore disabled) */
.btn:hover:not(.disabled),
a.btn:hover:not(.disabled),
.view-btn:hover:not(.disabled),
.clear-search:hover:not(.disabled),
.facet-actions button:hover:not(:disabled),
.facet-actions a:hover:not(.disabled),
.card-actions button:hover:not(:disabled),
.card-actions a:hover:not(.disabled) {
  background-color: var(--btn-bg-hover);
  filter: none;
}

/* shared active / focus visuals:
   - inner gap: 3px of surrounding UI background
   - outer ring: total 5px (so 2px visible mid-grey)
*/
.btn:active,
.btn:focus,
.btn:focus-visible,
a.btn:active,
a.btn:focus,
a.btn:focus-visible,
.view-btn:active,
.view-btn:focus,
.view-btn:focus-visible,
.clear-search:active,
.clear-search:focus,
.clear-search:focus-visible,
.facet-actions button:active,
.facet-actions button:focus,
.facet-actions button:focus-visible,
.facet-actions a:active,
.facet-actions a:focus,
.facet-actions a:focus-visible,
.card-actions button:active,
.card-actions button:focus,
.card-actions button:focus-visible,
.card-actions a:active,
.card-actions a:focus,
.card-actions a:focus-visible {
  outline: none;
  background-color: var(--btn-bg-hover);
  box-shadow:
    0 0 0 3px var(--btn-gap-color),  /* inner gap = UI background */
    0 0 0 5px var(--btn-highlight);   /* outer 2px mid-grey ring */
}

/* add a subtle outer focus ring for keyboard users */
.btn:focus-visible,
a.btn:focus-visible,
.view-btn:focus-visible,
.clear-search:focus-visible,
.facet-actions button:focus-visible,
.facet-actions a:focus-visible,
.card-actions button:focus-visible,
.card-actions a:focus-visible {
  box-shadow:
    0 0 0 3px var(--btn-gap-color),
    0 0 0 5px var(--btn-highlight),
    0 0 0 8px rgba(46,107,116,0.12);
}

/* disabled state */
.btn.disabled,
.btn[aria-disabled="true"],
.facet-actions button:disabled,
.card-actions button:disabled {
  opacity: 0.5;
  pointer-events: none;
  cursor: default;
}

/* -----------------------
   Card grid and card styling
   - default: 3 columns
   - tablet: 2 columns
   - phone: 1 column (and facets stack above)
   ----------------------- */
.card-grid {
    display: grid;
    gap: 1rem;
    margin-top: 1rem;
    /* default: 3 columns to meet "3 on laptop/pc" requirement */
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

/* item card container */
.item-card {
    display: flex;
    flex-direction: column;
    border-bottom: 10px solid #1B444B;
    border-radius: 4px;
    background: #fff;
    font-size: 0.9rem;
    box-shadow: 0 2px 4px rgba(0,0,0,0.12);
    overflow: hidden;
}
/* -----------------------
   Card header (single consolidated block)
   - fixed height
   ----------------------- */
.card-header {
    color: #ffffff;
    background: #247A49;
    padding: 0.5rem 0.75rem;
    height: 4.6rem;           /* fixed header height */
    box-sizing: border-box;
    overflow: hidden;
    display: flex;
    flex-direction: column;   /* stack item-type above title */
    justify-content: flex-start; /* valid replacement for `top` */
    align-items: flex-start;
    gap: 0.2rem;
}

/* small type label inside header */
.card-header .item-type {
    font-size: 0.75rem;
    color: rgba(255,255,255,0.85);
    margin: 0;
    line-height: 1;
}

/* title: clamp to 3 lines and apply thin outline */
.card-header .card-title {
    margin: 0;
    font-size: 0.8rem;
    font-family: "futura-pt", sans-serif;
    font-weight: 600;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
    color: #ffffff;
    width: 100%;
}

.card-subheader {
    background: #016C76;
    font-size: 0.7rem;
    color: #fff;
    padding: 0.25rem 0.75rem;
    border-bottom: 1px solid #eee;
}

/* Card content */
.card-body {
    padding: 0.75rem;
    margin-bottom: 0.5rem;
}

.card-description { font-size: 0.9rem; margin-bottom: 0.5rem; }
.card-metadata  { font-size: 0.8rem; margin-bottom: 0.5rem; }
.card-impact    { flex-grow: 1; margin-bottom: 0.5rem; }

/* action row pinned to bottom of card */
.card-actions {
    margin-top: auto;
    padding: 0.75rem;
    display: flex;
    justify-content: flex-end;
    gap: 0.5rem;
}


/* -----------------------
   List view (alternate view)
   ----------------------- */
.list-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1rem;
    margin-top: 1rem;
    width: 95%;
    border: 1px solid #ddd;
    border-radius: 4px;
    padding-top: 1rem !important;
    padding-bottom: 1rem !important;
    background: #fff;
    font-size: 0.9rem;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.12);
}

.item-list {
    background: #fff;
    padding-left: 12px; /* keep content clear of the border */
    margin-bottom: 0;
    margin-top: 0;
    border-bottom: 1px solid #ccc;
}

.item-title,
.item-list h3,
.item-list .item-title {
  font-size: 1rem;
  font-family: "futura-pt", sans-serif;
  font-weight: 600;
  color: #1B444B;
  margin: 0 0 0.25rem 0;
}

.item-list p, .item-card p {
    margin: 0.1rem 0;
    font-size: 0.8rem;
}

/* -----------------------
   Tables and messages
   ----------------------- */
table.results-table {
    background: #ffffff;
    border-collapse: collapse;
    width: 100%;
    margin-top: 1.5rem;
    font-size: 0.9rem;
}

th {
    background: #2E6B74;
    color: #fff;
    padding: 0.75rem;
    text-align: left;
    font-size: 1rem;
}

td {
    border: 1px solid #ddd;
    padding: 0.5rem;
    vertical-align: top;
}

.empty-message {
    text-align: center;
    padding-top: 1rem;
    padding-bottom: 1rem;
    margin-top: 1rem;
    margin-bottom: 1rem;
    background: #ffffff;
    border: 1px solid #666666;
    border-radius: 4px;
}

.view-toggle {
  margin-left: auto;
}

/* hide the apply filters on desktop */
.facet-actions .apply-filters {
    display: none !important;
    visibility: hidden !important;
    pointer-events: none !important;
}


/* -----------------------
   Responsive breakpoints
   - Tablet: up to 1023px -> 2 columns
   - Phone: up to 767px -> stack facets and 1 column cards
   ----------------------- */
@media (max-width: 1023px) {
    .card-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr)); /* 2 columns on tablets */
    }
    /* keep facets sidebar width but allow shrinking if layout requires */
    .facets { width: 260px; }
}

@media (max-width: 767px) {
    .layout {
        grid-template-columns: 1fr;
        grid-template-areas:
      "facets"
      "results";
    }

    .facets {
        width: 100%;
    }

    .facets select, .facets input[type="text"] {
        width: 100%;
        box-sizing: border-box;
        display: block;
    }

    .facets {
        width: 100%;
        margin-bottom: 1rem;
    }

    .card-grid {
        grid-template-columns: 1fr;
    }

    .facets select,
    .facets input[type="text"] {
        width: 100%;
        box-sizing: border-box;
        display: block;
        min-height: 24px;
        height: auto;
        padding: 0.5rem 0.6rem;
    }

    .facets select[multiple] {
        height: auto;
        min-height: 24px;
        height: auto;
    }

    .facet-actions .apply-filters {
        display: inline-block !important;
        visibility: visible !important;
        pointer-events: auto !important;
    }
}






