/* Copyright (c) We Decide Canada */
/* File: poll_listing.css */
/* Purpose: Styling for poll listing pages. */

.poll_listing_page {
  padding: 24px 0 48px;
}

.poll_listing_container {
  max-width: 1100px;
}

.poll_listing_header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 16px;
  margin-bottom: 20px;
}

.poll_listing_title {
  margin: 0 0 8px;
}

.poll_listing_subtitle {
  margin: 0;
  color: var(--color-text-muted, #9aa0a6);
}

.poll_listing_create_btn {
  display: inline-block;
  padding: 10px 14px;
  border-radius: 10px;
  text-decoration: none;
  background: var(--color-accent, #2d6cdf);
  color: #fff;
}

.poll_listing_filters {
  display: grid;
  gap: 12px;
  padding: 16px;
  border: 1px solid var(--color-border, #333);
  border-radius: 14px;
  margin-bottom: 20px;
  background: var(--color-surface, rgba(255,255,255,0.02));
}

.poll_listing_filter_row {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.poll_listing_filter_group {
  display: grid;
  gap: 6px;
}

.poll_listing_filter_group input,
.poll_listing_filter_group select {
  width: 100%;
  min-height: 42px;
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid var(--color-border, #333);
  background: var(--color-bg, #111);
  color: var(--color-text, #fff);
}

.poll_listing_filter_actions {
  align-items: end;
  display: flex;
  gap: 10px;
}

.poll_listing_filter_actions button,
.poll_listing_filter_actions a {
  min-height: 42px;
  padding: 10px 14px;
  border-radius: 10px;
  border: 1px solid var(--color-border, #333);
  text-decoration: none;
  background: var(--color-surface, #1b1b1b);
  color: var(--color-text, #fff);
}

.poll_listing_results {
  display: grid;
  gap: 14px;
}

.poll_card {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  padding: 16px;
  border: 1px solid var(--color-border, #333);
  border-radius: 14px;
  background: var(--color-surface, rgba(255,255,255,0.02));
}

.poll_card__eligible {
  border-color: #3568d4;
}

.poll_card__done {
  border-color: #2f9e44;
}

.poll_card_main {
  min-width: 0;
  flex: 1 1 auto;
}

.poll_card_title {
  margin: 0 0 8px;
  font-size: 1.1rem;
}

.poll_card_title a {
  color: inherit;
  text-decoration: none;
}

.poll_card_meta,
.poll_card_time {
  color: var(--color-text-muted, #9aa0a6);
  font-size: 0.95rem;
}

.poll_card_side {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 10px;
}

.poll_card_status {
  display: inline-block;
  padding: 6px 10px;
  border-radius: 999px;
  font-size: 0.85rem;
  border: 1px solid currentColor;
}

.poll_card_status.is_pending {
  color: #3568d4;
}

.poll_card_status.is_done {
  color: #2f9e44;
}

.poll_card_view_btn {
  display: inline-block;
  padding: 10px 14px;
  border-radius: 10px;
  text-decoration: none;
  border: 1px solid var(--color-border, #333);
  color: var(--color-text, #fff);
}

.poll_listing_empty {
  padding: 24px;
  text-align: center;
  border: 1px dashed var(--color-border, #333);
  border-radius: 14px;
  color: var(--color-text-muted, #9aa0a6);
}

.poll_listing_pagination {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 20px;
}

.poll_listing_page_link {
  display: inline-block;
  min-width: 40px;
  text-align: center;
  padding: 10px 12px;
  border: 1px solid var(--color-border, #333);
  border-radius: 10px;
  text-decoration: none;
  color: var(--color-text, #fff);
}

.poll_listing_page_link.is_active {
  background: var(--color-accent, #2d6cdf);
  color: #fff;
}

@media (max-width: 1024px) {
  .poll_listing_filter_row {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 640px) {
  .poll_listing_header,
  .poll_card {
    flex-direction: column;
  }

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

  .poll_card_side {
    align-items: stretch;
  }
}
