html {
  font-size: 16px;
  min-height: 100%;
}

body {
  background: #f7f9fc;
  color: #1f2a34;
  margin: 0;
}

h1, h2, h3, h4, h5, h6 {
  color: #1E88E5;
}

.brand-title {
  font-family: "Permanent Marker", cursive;
}

.page-heading {
  font-family: "Permanent Marker", cursive;
  color: #1E88E5;
}

.page-section {
  background: #fff;
  padding: 24px;
  border-radius: 12px;
  box-shadow: 0 8px 28px rgba(0, 0, 0, 0.08);
}

.placeholder-card {
  border: 1px dashed #90caf9;
  background: #e3f2fd;
  padding: 16px;
  border-radius: 10px;
  margin-top: 16px;
}

.lead {
  color: #455a64;
}

a.nav-link {
  font-weight: 600;
}

.btn-primary {
  background-color: #1E88E5;
  border-color: #1E88E5;
}

/* Legacy search page styling */
.filter-block {
  border: 1px solid silver;
  margin-bottom: 10px;
  padding: 10px;
  border-radius: 4px;
  background-color: white;
}

.filter-block-enabled {
  background-color: #E1F5FE;
}

.filter-title {
  font-weight: bold;
  font-size: larger;
}

.filter-footnote {
  margin-top: 20px;
  text-align: right;
}

span.unknown-value {
  font-style: italic;
  color: silver;
}

div.result-header {
  background-color: #ECEFF1;
  border: 1px solid gainsboro;
  padding: 10px;
  border-radius: 4px;
}

div.compatible-foods {
  background-color: #E8F5E9;
  border: 1px solid #A5D6A7;
}

div.incompatible-foods {
  background-color: #FFCDD2;
  border: 1px solid #EF9A9A;
}

table.food-table tr td,
table.food-table tr th {
  padding: 6px;
  border-bottom: 1px solid #efefef;
}

tr.inner-table-head th {
  vertical-align: bottom;
  border-bottom: 2px solid black;
}

table.food-table {
  border-top: 1px solid silver;
}

table.food-table .note {
  font-style: italic;
  color: silver;
}

table.results-table tbody td {
  white-space: nowrap;
}

div.bignum {
  color: white;
  font-size: large;
  font-weight: bold;
  text-align: center;
  vertical-align: middle;
  border-radius: 50%;
  background-color: dodgerblue;
  width: 30px;
  height: 30px;
  line-height: 30px;
}

table.instruction-table td {
  padding-bottom: 20px;
  font-size: large;
}
