* {
  box-sizing: border-box;
  -webkit-tap-highlight-color: transparent;
}
html {
  -webkit-text-size-adjust: none;
}
body {
  background-color: #fff;
  margin: 0;
  padding: 33px 0;
  font: 14px/1.4 'NPRSans', 'Helvetica Neue', 'Helvetica', 'Arial', sans-serif;
  color: #555;
  touch-action: manipulation;
}
img,
svg {
  max-width: 100%;
}
h1 {
  font-family: 'NPRSans', 'Helvetica Neue', 'Helvetica', 'Arial', sans-serif;
  font-weight: normal;
  letter-spacing: 0.01em;
  margin: 0 0 22px 0;
  font-size: 20px;
  color: #333;
  font-weight: 600;
  line-height: 1.3;
  -webkit-font-smoothing: antialiased;
}
h2 {
  font-family: 'NPRSans', 'Helvetica Neue', 'Helvetica', 'Arial', sans-serif;
  letter-spacing: 0.01em;
  font-weight: normal;
  color: #636363;
  font-size: 14px;
  margin: -11px 0 33px 0;
  line-height: 1.6;
}
h3 {
  font-family: 'NPRSans', 'Helvetica Neue', 'Helvetica', 'Arial', sans-serif;
  font-weight: normal;
  letter-spacing: 0.01em;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-weight: 500;
  -webkit-font-smoothing: antialiased;
  margin: 0 0 15px 0;
  padding-top: 0;
  line-height: 1.2;
  font-size: 12px;
  color: #333;
}
.nowrap {
  white-space: nowrap;
}
.footnotes {
  margin-bottom: 20px;
}
.footnotes h4 {
  margin: 2px 0 7px 0;
  color: #666;
  font-size: 11px;
}
.footnotes p,
.footer p {
  margin: 2px 0 0 0;
  font-size: 12px;
  line-height: 1.7;
  color: #808080;
}
.footer p {
  font-style: italic;
}
.footer p em {
  font-style: normal;
}
.footnotes p strong {
  color: #666;
}
a,
a:link,
a:visited {
  color: #4774CC;
  text-decoration: none;
}
a:hover,
a:active {
  color: #bccae5;
}
.graphic-wrapper {
  position: relative;
}
.graphic {
  position: relative;
  margin-bottom: 11px;
}
.graphic::after {
  content: "";
  display: block;
  height: 0;
  clear: both;
}
.graphic img {
  max-width: 100%;
  height: auto;
}
.key {
  margin: -11px 0 33px 0;
  padding: 0;
  list-style-type: none;
}
.key .key-item {
  display: inline-block;
  margin: 0 18px 0 0;
  padding: 0;
  line-height: 15px;
}
.key .key-item b {
  display: inline-block;
  width: 15px;
  height: 15px;
  margin-right: 6px;
  float: left;
}
.key .key-item label {
  white-space: nowrap;
  font-size: 12px;
  color: #666;
  font-weight: normal;
  -webkit-font-smoothing: antialiased;
}
svg {
  overflow: hidden;
}
.axis {
  font-family: 'NPRSans', 'Helvetica Neue', 'Helvetica', 'Arial', sans-serif;
  font-weight: normal;
  letter-spacing: 0.01em;
  font-size: 11px;
  -webkit-font-smoothing: antialiased;
  fill: #999;
}
.axis path,
.axis line {
  fill: none;
  stroke: #ccc;
  shape-rendering: crispEdges;
}
.axis.y path {
  display: none;
}
.axis.y .tick line {
  display: none;
}
.grid path {
  display: none;
}
.grid .tick {
  stroke: #eee;
  color: #eee;
  stroke-width: 1px;
  shape-rendering: crispEdges;
}
.grid.y g:first-child line {
  display: none;
}
.zero-line {
  stroke: #666;
  stroke-width: 1px;
  shape-rendering: crispEdges;
}
line,
rect {
  shape-rendering: crispEdges;
}
.bars rect {
  fill: #17807E;
}
.labels {
  position: absolute;
  margin: 0;
  padding: 0;
  list-style-type: none;
  border: none;
}
.labels li {
  position: absolute;
  text-align: right;
  font-size: 12px;
  line-height: 1.4;
  color: #666;
  display: table;
  -webkit-font-smoothing: antialiased;
}
.labels li span {
  display: table-cell;
  vertical-align: middle;
}
.value text {
  font-size: 11px;
  -webkit-font-smoothing: antialiased;
}
.value text.in {
  fill: #fff;
}
.value text.out {
  fill: #636363;
}
body.hp {
  padding-top: 0;
  padding-bottom: 10px;
}
body.childlink {
  margin-left: auto;
  margin-right: auto;
  max-width: 800px;
}
img:not([alt]) {
  outline: 3px solid red;
}
[role="img"] img:not([alt]) {
  outline: none;
}
.sr-only {
  opacity: 0;
  position: absolute;
  left: -1000px;
  clip: inset(0, 0, 0, 0);
  width: 1px;
  height: 1px;
}
body {
  padding-top: 10px;
}
.menu-container {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: center;
  max-width: 680px;
  margin-left: auto;
  margin-right: auto;
}
.menu-container a {
  color: black;
  padding: 15px;
  background-color: #ebebeb;
  text-align: center;
  margin: 5px;
  max-width: 300px;
  border-radius: 15px;
  transition: 0.3s;
}
.menu-container a.investigate_trump {
  background-image: linear-gradient(#F8E2CA, white);
  color: #714616;
}
.menu-container a.law {
  background-image: linear-gradient(#e6e6fa, white);
  color: #58427c;
}
.menu-container a.trump_official {
  background-image: linear-gradient(#C5DFDF, white);
  color: #0B403F;
}
.menu-container a.protestor {
  background-image: linear-gradient(#F5D1CA, white);
  color: #6C2315;
}
.menu-container a.opponent {
  background-image: linear-gradient(#D3EAF7, white);
  color: #28556F;
}
.menu-container a.university {
  background-image: linear-gradient(#FBF1CD, white);
  color: #77631B;
}
.menu-container a.media {
  background-image: linear-gradient(#ebebeb, white);
}
.menu-container a:hover.investigate_trump,
.menu-container a:focus.investigate_trump {
  background-image: linear-gradient(#F1C696, white);
  color: #714616;
}
.menu-container a:hover.law,
.menu-container a:focus.law {
  background-image: linear-gradient(#d0d0ff, white);
  color: #58427c;
}
.menu-container a:hover.trump_official,
.menu-container a:focus.trump_official {
  background-image: linear-gradient(#8BC0BF, white);
  color: #0B403F;
}
.menu-container a:hover.protestor,
.menu-container a:focus.protestor {
  background-image: linear-gradient(#ECA395, white);
  color: #6C2315;
}
.menu-container a:hover.opponent,
.menu-container a:focus.opponent {
  background-image: linear-gradient(#A8D5EF, white);
  color: #28556F;
}
.menu-container a:hover.university,
.menu-container a:focus.university {
  background-image: linear-gradient(#F7E39B, white);
  color: #77631B;
}
.menu-container a:hover.media,
.menu-container a:focus.media {
  background-image: linear-gradient(#d1d1d1, white);
}
h1,
h2 {
  margin-left: auto;
  margin-right: auto;
  max-width: 650px;
  text-align: center;
}
h1 {
  font-size: 18px;
}
.footer,
.footnotes {
  margin-left: auto;
  margin-right: auto;
  max-width: 650px;
}
.graphic {
  max-width: 1300px;
  margin-left: auto;
  margin-right: auto;
}
@media screen and (max-width: 500px) {
  .grid-container {
    display: none;
  }
  .table-container {
    display: block;
  }
  .laptop.table-container {
    display: none;
  }
  .laptop.grid-container {
    display: block;
  }
}
@media screen and (min-width: 501px) {
  .grid-container {
    display: block;
  }
  .table-container {
    display: none;
  }
}
@media screen and (min-width: 901px) {
  .grid-container.investigate_trump .show-more,
  .grid-container.protestor .show-more,
  .grid-container.university .show-more {
    display: none;
  }
}
@media screen and (min-width: 901px) {
  .grid-container.law .show-more.law-sue,
  .grid-container.law .show-more.law-other {
    display: none;
  }
}
.grid {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: center;
}
.grid.laptop .grid-item {
  width: 20%;
  background-color: white;
  padding: 5px;
  margin: 5px;
  border-radius: 0px;
}
.grid.laptop .grid-item .header,
.grid.laptop .grid-item .content {
  padding: 0px;
}
.grid.laptop .grid-item .name {
  font-weight: normal;
}
@media screen and (max-width: 500px) {
  .grid.laptop .name {
    font-size: 14px;
  }
}
.show-all .show-more:focus {
  outline: none;
  border: none;
}
.grid-item {
  background-color: #EBEBEB;
  margin: 5px;
  width: 300px;
  border-radius: 15px;
}
@media screen and (max-width: 500px) {
  .grid-item {
    width: 100%;
  }
  .grid-item:nth-child(n+4 of .show) {
    display: none;
  }
}
@media screen and (min-width: 501px) and (max-width: 900px) {
  .grid-item {
    width: 45%;
  }
  .grid-item:nth-child(n+7 of .show) {
    display: none;
  }
}
@media screen and (min-width: 901px) {
  .grid-item:nth-child(n+9 of .show) {
    display: none;
  }
}
.grid-item.show {
  display: block;
}
.grid-item.hide {
  display: none;
}
.show-all .grid-item.show {
  display: block;
}
.grid.law h3,
.table-container.law h3 {
  font-size: 14px;
  color: #58427c;
}
.grid.law .sub-cat,
.table-container.law .sub-cat {
  margin-bottom: 10px;
}
.grid.law .sub-hdr,
.table-container.law .sub-hdr {
  text-align: center;
}
.grid.law .sub-grid,
.table-container.law .sub-grid {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}
@media screen and (max-width: 900px) {
  .grid.law .grid-item:nth-child(n+3 of .show),
  .table-container.law .grid-item:nth-child(n+3 of .show) {
    display: none;
  }
}
@media screen and (min-width: 901px) {
  .grid.law .grid-item:nth-child(n+5 of .show),
  .table-container.law .grid-item:nth-child(n+5 of .show) {
    display: none;
  }
}
.grid.law .name,
.table-container.law .name {
  font-size: 14px;
  color: #555 !important;
}
@media screen and (min-width: 901px) {
  .grid.law .law-sue .grid-item,
  .table-container.law .law-sue .grid-item,
  .grid.law .law-other .grid-item,
  .table-container.law .law-other .grid-item {
    display: block !important;
  }
}
.grid.law hr,
.table-container.law hr {
  border-top: 2px solid #ebebeb;
  width: 70%;
  margin-bottom: 30px;
}
.grid.law .show-more,
.table-container.law .show-more {
  margin-bottom: 40px;
}
.grid .show-all .grid-item.show,
.table-container .show-all .grid-item.show {
  display: block !important;
}
.table-container.law .header {
  font-family: 'NPRSans', 'Helvetica Neue', 'Helvetica', 'Arial', sans-serif;
  font-weight: normal;
  letter-spacing: 0.01em;
  text-transform: none;
  font-weight: bold;
}
.table-container.law .table-item:nth-child(n+3 of .show) {
  display: none;
}
.table-container .show-all .table-item.show {
  display: table-row !important;
}
.table-item.show {
  display: table-row;
}
.table-item.hide {
  display: none;
}
.table-item:nth-child(n+5 of .show) {
  display: none;
}
.show-all .table-item.show {
  display: table-row;
}
.name {
  font-weight: bold;
  font-size: 16px;
  color: #333;
}
.title {
  font-style: italic;
}
.grid .header {
  padding: 10px 10px 0px 10px;
  text-align: center;
}
h1.investigate_trump {
  color: #714616;
}
h1.opponent {
  color: #28556F;
}
h1.trump_official {
  color: #0B403F;
}
h1.protestor {
  color: #6C2315;
}
h1.law {
  color: #58427c;
}
h1.university {
  color: #77631B;
}
.investigate_trump .grid-item,
.investigate_trump td {
  background-image: linear-gradient(#F8E2CA, white);
}
.investigate_trump .grid-item .name,
.investigate_trump td .name {
  color: #714616;
}
.investigate_trump .show-more {
  color: #714616;
}
.opponent .grid-item,
.opponent td {
  background-image: linear-gradient(#D3EAF7, white);
}
.opponent .grid-item .name,
.opponent td .name {
  color: #28556F;
}
.opponent .show-more {
  color: #28556F;
}
.trump_official .grid-item,
.trump_official td {
  background-image: linear-gradient(#C5DFDF, white);
}
.trump_official .grid-item .name,
.trump_official td .name {
  color: #0B403F;
}
.trump_official .show-more {
  color: #0B403F;
}
.protestor .grid-item,
.protestor td {
  background-image: linear-gradient(#F5D1CA, white);
}
.protestor .grid-item .name,
.protestor td .name {
  color: #6C2315;
}
.protestor .show-more {
  color: #6C2315;
}
.law .grid-item,
.law td {
  background-image: linear-gradient(#e6e6fa, white);
}
.law .grid-item .name,
.law td .name {
  color: #58427c;
}
.law .show-more {
  color: #58427c;
}
.university .grid-item,
.university td {
  background-image: linear-gradient(#FBF1CD, white);
}
.university .grid-item .name,
.university td .name {
  color: #77631B;
}
.university .show-more {
  color: #77631B;
}
.media .grid-item,
.media td {
  background-image: linear-gradient(#ebebeb, white);
}
.content {
  padding: 10px 15px 10px 15px;
}
.relationship {
  text-align: center;
}
.label {
  font-weight: bold;
  color: #666;
  margin-top: 10px;
  text-align: center;
}
.action-single {
  margin-bottom: 10px;
  text-align: center;
}
ul {
  padding-left: 20px;
}
.source {
  text-align: center;
}
.source a {
  color: #989898;
  text-decoration: underline;
}
.show-more {
  font-family: 'NPRSans', 'Helvetica Neue', 'Helvetica', 'Arial', sans-serif;
  font-weight: normal;
  letter-spacing: 0.01em;
  background-color: #fff;
  border: none;
  border-top: 2px solid #eee;
  box-shadow: none;
  box-sizing: border-box;
  color: #4774CC;
  display: block;
  font-weight: bold;
  margin-top: 0;
  margin-bottom: 22px;
  padding: 10px;
  text-transform: uppercase;
  width: 100%;
}
.show-more:hover {
  cursor: pointer;
  opacity: 0.7;
}
#state-table .source {
  text-align: left;
}
#state-table .name {
  font-size: 14px;
}
table {
  border-collapse: collapse;
  padding: 0;
  width: 100%;
  font-size: 13px;
}
table tr.shadedrow {
  background-color: #f1f1f1;
  color: #333;
  font-weight: bold;
}
table th {
  font-family: 'NPRSans', 'Helvetica Neue', 'Helvetica', 'Arial', sans-serif;
  font-weight: normal;
  letter-spacing: 0.01em;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-weight: 500;
  -webkit-font-smoothing: antialiased;
  line-height: 1.2;
  text-align: left;
  vertical-align: bottom;
  color: #333;
}
table td {
  vertical-align: top;
}
table th.sort-header {
  cursor: pointer;
}
table th.sort-header::-moz-selection,
table th.sort-header::selection {
  background: transparent;
}
table th.sort-header .sorter {
  border-top: 2px solid #404040;
  visibility: hidden;
}
table th.sort-header .sorter .icon {
  content: '';
  width: 1px;
  margin: 3px auto 7px auto;
  border-width: 0 4px 4px;
  border-style: solid;
  border-color: #404040 transparent;
}
table th.sort-header:hover .sorter {
  visibility: visible;
}
table th[aria-sort="descending"] .sorter,
table th[aria-sort="ascending"] .sorter,
table th[aria-sort="ascending"]:hover .sorter {
  visibility: visible;
  opacity: 0.4;
}
table th[aria-sort="descending"] .sorter .icon {
  border-bottom: none;
  border-width: 4px 4px 0;
}
/*
* larger-than-small-screen styles
* ~ defining some desktop-only styles here to avoid
* ~ writing extra mobile styles to undo them.
*/
table th,
table td {
  padding: 10px;
}
table th:first-child,
table td:first-child {
  padding-left: 0;
}
table th:last-child,
table td:last-child {
  padding-right: 0;
}
table th.amt,
table td.amt {
  text-align: right;
}
table th {
  padding-top: 0;
}
table td {
  background-color: #ebebeb;
  border-bottom: 3px solid white;
}
table td.target-mobile {
  border-top-left-radius: 15px;
  border-bottom-left-radius: 15px;
  padding-left: 10px;
}
table td.actions-mobile {
  border-top-right-radius: 15px;
  border-bottom-right-radius: 15px;
  padding-right: 10px;
}
