#primary {
  box-sizing: border-box;
  width: 100%;
  max-width: 1200px; /* keeps content readable on very large screens */
  margin: 0 auto; /* center */
  padding: 24px 20px; /* comfortable gutter */
  background: transparent;
  -webkit-font-smoothing: antialiased;
}

/* Make main content flow nicely */
#primary .site-main,
#primary article,
#primary .entry-content {
  width: 100%;
  box-sizing: border-box;
}

/* Images inside primary: responsive */
#primary img {
  max-width: 100%;
  height: auto;
  display: block;
  object-fit: contain;
}

/* Table wrapper: allow small-screen horizontal scroll as fallback */
#primary .footable_parent,
#primary .ninja_table_wrapper,
#primary #footable_parent_104224 {
  width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  margin: 0;
  padding-bottom: 8px;
}

/* Make the table fill the available width */
#primary table {
  width: 100%;
  min-width: 720px; /* reasonable min so wide tables still scroll */
  border-collapse: collapse;
  table-layout: auto; /* allow variable column widths */
}

/* Improve table cell spacing and wrap text */
#primary table td,
#primary table th {
  padding: 10px 12px;
  vertical-align: middle;
  word-break: break-word;
  hyphens: auto;
}

/* Small logo images inside table get a sensible max size */
#primary table img {
  max-width: 120px;
  width: auto;
  height: auto;
}

/* Mobile-first tweaks */
@media (max-width: 1024px) {
  #primary {
    padding: 20px 16px;
  }
  /* slightly smaller table cells on tablet */
  #primary table td,
  #primary table th {
    padding: 9px 10px;
    font-size: 0.95rem;
  }
}

/* Tablets / large phones */
@media (max-width: 768px) {
  #primary {
    padding: 16px 12px;
    max-width: 100%;
  }

  /* Make search input stretch and remain usable */
  #primary .company-search {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
  }
  #primary .company-search label {
    flex: 0 0 100%;
    margin-bottom: 4px;
  }
  #primary .company-search input {
    flex: 1 1 100%;
    max-width: 100%;
  }

  /* Allow the table to be scrolled horizontally and reduce min-width */
  #primary table {
    min-width: 640px;
    font-size: 0.95rem;
  }
}

/* Phones (narrow) */
@media (max-width: 480px) {
  #primary {
    padding: 12px 10px;
  }

  /* Reduce table min width so it fits better; horizontal scroll remains available */
  #primary table {
    min-width: 560px;
    font-size: 0.92rem;
  }

  /* Reduce images to avoid stretching rows too much */
  #primary table img {
    max-width: 80px;
  }

  /* Make footable/filters and other headers stack neatly */
  #primary .foo-table .footable-filtering,
  #primary .foo-table thead,
  #primary .foo-table tfoot {
    font-size: 0.92rem;
  }
}

@media (max-width: 420px) {
  #primary table,
  #primary thead,
  #primary tbody,
  #primary th,
  #primary td,
  #primary tr {
    display: block;
  }
  #primary thead tr {
    position: absolute;
    top: -9999px;
    left: -9999px;
  }
  #primary tr {
    border: 1px solid #eee;
    margin-bottom: 10px;
    padding: 10px;
  }
  #primary td {
    border: none;
    position: relative;
    padding-left: 50%;
    white-space: normal;
  }
  #primary td:before {
    position: absolute;
    left: 12px;
    width: 45%;
    padding-right: 10px;
    white-space: nowrap;
    font-weight: 600;
    content: attr(
      data-label
    ); /* requires server-side addition of data-label on each td */
  }
}
