/*!*********************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[13].oneOf[7].use[2]!./node_modules/next/dist/build/webpack/loaders/postcss-loader/src/index.js??ruleSet[1].rules[13].oneOf[7].use[3]!./src/app/shared.module.css ***!
  \*********************************************************************************************************************************************************************************************************************************************************************/
.shared_mainLayout__4NX_F {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1rem;
  padding: 0.5rem;
  max-width: var(--max-width);
  margin: 0 auto;
}

.shared_mainWithHeader__yGRcu {
  margin-top: 1rem;
}

.shared_accent-text__nK7Vn {
  color: transparent;
  text-shadow: 0.1rem 0.1rem var(--accent);
  text-stroke: 1px var(--text-stroke);
  -webkit-text-stroke: 1px var(--text-stroke);
}

.shared_title__A8PMZ {
  text-shadow: 0.25rem 0.25rem var(--accent);
  font-size: clamp(2rem, 10vw, 8rem);
  text-align: center;
  margin: 0;
}

.shared_titleH2__rBo8F {
  font-size: clamp(2rem, 8vw, 5rem);
}

.shared_titleH3__db_ED {
  font-size: clamp(2rem, 6vw, 4rem);
}

.shared_card__vLMY7 {
  background: var(--card-background);
  border-radius: var(--border-radius);
  box-shadow: var(--shadow-lg);
  border: 1px solid var(--card-border);
  padding: 1rem;
}

.shared_errorCardContent__DJ6u_ {
  height: 100%;
  padding: 0 1rem 1rem 1rem;
}

.shared_errorCardContentStandalone__HsqZZ {
  height: 100%;
  padding: 1rem;
  min-height: 5rem;
}

.shared_cardWithTable__88_dt {
  padding: 0;
}

.shared_smallCard___qBml {
  display: flex;
  flex: 0 0 auto;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
  min-width: 15rem;
  max-width: 25rem;
}

.shared_smallCardSkeleton__eKdyb {
  display: flex;
  justify-content: center;
}

.shared_constrainedWrapper__Bj9t2 {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: inherit;
  width: 100%;
}

.shared_constrainWidth__Mbrf_ {
  max-width: 40rem;
  width: 100%;
  height: 100%;
}

.shared_highlight__1FBBy {
  padding: 0.25rem 0 0.5rem 0;
  font-size: 2rem;
  font-weight: bold;
}

.shared_plainList__28QPz {
  list-style: none;
  padding: 0;
  margin: 0;
}

.shared_plainListItem__aIqSo {
  padding: 0.5rem 0;
}

.shared_hasFade__X3XVU {
  -webkit-mask-size: 100% 100%;
  mask-size: 100% 100%;
  -webkit-mask-position:
    0 0,
    100% 0;
  mask-position:
    0 0,
    100% 0;
  -webkit-mask-repeat: no-repeat, no-repeat;
  mask-repeat: no-repeat, no-repeat;
}

.shared_goalAccomplished__VoGi0,
.shared_checkmark__oVQoP {
  fill: green;
  max-width: 1rem;
}

.shared_goalFailed__Z8U0c,
.shared_xMark__x6Jfx {
  fill: red;
  max-width: 1rem;
}

.shared_goalMixed__FPjTO {
  fill: var(--main-text);
  max-width: 1rem;
  font-weight: bold;
}

.shared_goalInline__mCrjQ {
  max-height: 100%;
}

@media (min-width: 500px) {
  .shared_highlight__1FBBy {
    font-size: clamp(2rem, 5vw, 3rem);
    white-space: nowrap;
  }
}

@media (min-width: 1200px) {
  .shared_mainLayout__4NX_F {
    padding: 0.5rem 2rem;
  }
}

@media (min-width: 1600px) {
  .shared_mainLayout__4NX_F {
    padding: 0.5rem 4rem;
  }
}

@media (min-width: 2000px) {
  .shared_mainLayout__4NX_F {
    padding: 0.5rem 6rem;
  }
}

/*!**************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[13].oneOf[7].use[2]!./node_modules/next/dist/build/webpack/loaders/postcss-loader/src/index.js??ruleSet[1].rules[13].oneOf[7].use[3]!./src/app/components/expenditures.module.css ***!
  \**************************************************************************************************************************************************************************************************************************************************************************************/
.expenditures_card___CReK {
  grid-area: byParty;
  display: flex;
  flex-direction: column;
  flex-grow: 1;
}

.expenditures_svgWrapper__U_i6A {
  overflow: hidden;
}

.expenditures_growWrapper__4PQVH {
  flex-grow: 1;
}

.expenditures_svg__4Rmmm {
  width: 100%;
  height: 100%;
  fill: var(--main-text);
}

.expenditures_svgText__AjwPm {
  fill: var(--main-text);
}

.expenditures_expendituresBarLabel__C_cfc {
  text-align: center;
  overflow: hidden;
  text-overflow: ellipsis;
  word-wrap: break-word;
  -webkit-hyphens: auto;
  hyphens: auto;
  padding: 0.25rem;
  font-size: 0.8rem;
  color: var(--color-slate-200);
}

.expenditures_expendituresBarLabelOffBar__JKYNk {
  display: flex;
  height: 100%;
  align-items: flex-end;
  color: var(--main-text);
}

.expenditures_expendituresBarLabelSpan__TrD6z {
  min-width: 0;
}

.expenditures_supportOpposeLabel__fO3i_ {
  font-size: 0.9rem;
  font-weight: bold;
  text-align: center;
}

.expenditures_skeletonBar__hKHhy {
  fill: var(--chart-skeleton);
}

.expenditures_partyLabel__X4mNE {
  text-align: center;
  font-weight: bold;
}

.expenditures_footerLink__3tEKg {
  justify-self: flex-end;
}

/*!*********************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[13].oneOf[7].use[2]!./node_modules/next/dist/build/webpack/loaders/postcss-loader/src/index.js??ruleSet[1].rules[13].oneOf[7].use[3]!./src/app/components/home/chloroplethMap.module.css ***!
  \*********************************************************************************************************************************************************************************************************************************************************************************************/
.chloroplethMap_mapWrapper__grfF3 {
  position: relative;
}

.chloroplethMap_svg__4YctG {
  fill: var(--map-background);
  stroke: var(--secondary-text);
}

.chloroplethMap_svgText__go6Yr {
  fill: var(--main-text);
  stroke: none;
}

.chloroplethMap_legend__crTnY {
  stroke: var(--secondary-text);
}

.chloroplethMap_activeState__7M_qR {
  font-weight: bold;
}

.chloroplethMap_svgSkeleton__C5cYQ {
  fill: transparent;
  stroke: var(--color-slate-300);
}

.chloroplethMap_mapLoadingError__DrC_V {
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
  margin: auto;
  max-width: 15rem;
  max-height: 5rem;
}

.chloroplethMap_stateFillError__qD4jQ {
  fill: rgba(0, 0, 0, 0);
}

.chloroplethMap_stateFill0__uJQ62 {
  fill: var(--map-background);
}

.chloroplethMap_stateFill1__Dytku {
  fill: var(--color-blue-50);
}

.chloroplethMap_stateFill2__o8UME {
  fill: var(--color-blue-100);
}

.chloroplethMap_stateFill3__4KLRZ {
  fill: var(--color-blue-200);
}

.chloroplethMap_stateFill4__gAVWX {
  fill: var(--color-blue-300);
}

.chloroplethMap_stateFill5__pgmo_ {
  fill: var(--color-blue-400);
}

.chloroplethMap_stateFill6__LQj51 {
  fill: var(--color-blue-600);
}

.chloroplethMap_stateFill7__CZHGE {
  fill: var(--color-blue-800);
}

.chloroplethMap_stateFill1__Dytku,
.chloroplethMap_stateFill2__o8UME,
.chloroplethMap_stateFill3__4KLRZ,
.chloroplethMap_stateFill4__gAVWX,
.chloroplethMap_stateFill5__pgmo_,
.chloroplethMap_stateFill6__LQj51,
.chloroplethMap_stateFill7__CZHGE {
  cursor: pointer;
}

.chloroplethMap_stateLink__dF29p {
  &:hover,
  &:focus,
  &:active {
    filter: brightness(0.9);
    outline: none;
  }
}

@media (prefers-color-scheme: dark) {
  .chloroplethMap_svgSkeleton__C5cYQ {
    stroke: var(--secondary-text);
  }

  .chloroplethMap_stateFill1__Dytku,
  .chloroplethMap_stateFill2__o8UME,
  .chloroplethMap_stateFill3__4KLRZ,
  .chloroplethMap_stateFill4__gAVWX,
  .chloroplethMap_stateFill5__pgmo_,
  .chloroplethMap_stateFill6__LQj51,
  .chloroplethMap_stateFill7__CZHGE {
    fill: var(--color-blue-400);
  }

  .chloroplethMap_stateFill1__Dytku {
    fill-opacity: 0.2;
  }

  .chloroplethMap_stateFill2__o8UME {
    fill-opacity: 0.3;
  }

  .chloroplethMap_stateFill3__4KLRZ {
    fill-opacity: 0.4;
  }

  .chloroplethMap_stateFill4__gAVWX {
    fill-opacity: 0.5;
  }

  .chloroplethMap_stateFill5__pgmo_ {
    fill-opacity: 0.6;
  }

  .chloroplethMap_stateFill6__LQj51 {
    fill-opacity: 0.8;
  }

  .chloroplethMap_stateFill7__CZHGE {
    fill-opacity: 1;
  }

  .chloroplethMap_stateLink__dF29p {
    &:hover,
    &:focus,
    &:active {
      filter: brightness(1.3);
    }
  }
}

/*!********************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[13].oneOf[7].use[2]!./node_modules/next/dist/build/webpack/loaders/postcss-loader/src/index.js??ruleSet[1].rules[13].oneOf[7].use[3]!./src/app/components/tables.module.css ***!
  \********************************************************************************************************************************************************************************************************************************************************************************/
.tables_inheritBorderRadius__GrU0R {
  border-top-left-radius: inherit;
  border-top-right-radius: inherit;
  border-bottom-left-radius: inherit;
  border-bottom-right-radius: inherit;
}

.tables_superPacCard__3x8gD,
.tables_influencedCard__hOZLR,
.tables_recentExpendituresCard__21K6A,
.tables_qpqCard__Et6jN {
  position: relative;
  display: flex;
  flex-direction: column;
  width: 100%;
}

.tables_influencedCard__hOZLR {
  grid-area: influencedCard;
}

.tables_superPacCard__3x8gD {
  grid-area: superPacCard;
}

.tables_superPacTable__MlaU8,
.tables_influencedTable__yQjQU {
  width: 100%;
  flex-grow: 1;
}

.tables_superPacTableHeader__kE5id,
.tables_influencedTableHeader__UXV4X {
  position: -webkit-sticky;
  position: sticky;
  top: 0;
  background-color: var(--card-background);
  border-radius: inherit;
}

.tables_superPacRow__eLjzo,
.tables_influencedTableRow__XWjvT,
.tables_oppositionSpendingRow__I8e5g,
.tables_beneficiariesRow__9radT,
.tables_qpqRow__C66S9 {
  &:nth-child(odd) {
    background: var(--table-background-secondary);
  }
}

.tables_superPacErrorRow__pG2AW {
  height: 10rem;
  text-align: center;
}

.tables_superPacCryptoRow__oDT_I {
  background-color: var(--table-highlight-color);
}

.tables_superPacTableCellMinWidth__VfmFl {
  min-width: 7rem;
}

.tables_tableCardContent__8LujH {
  padding: 1rem;
}

.tables_viewMoreLinks__J4SPu {
  display: flex;
  flex-wrap: wrap;
  flex-direction: row;
  gap: 0.25rem;
}

.tables_viewMoreLink__LMjyI:not(:last-child) {
  margin-right: 1rem;
}

/* Fallback for very small viewports */
.tables_influencedList__oqXEJ {
  display: flex;
  flex-direction: column;
  flex-grow: 1;
}

.tables_influencedRow__oasjy {
  display: flex;
  flex-direction: row;
  align-items: center;
  flex-grow: 1;
  white-space-collapse: preserve;
  padding: 0.5rem 0.5rem 0.5rem 0;
  gap: 0.5rem 0;
}

.tables_influencedRowOutcome__17FQe {
  margin-top: 0.5rem;
}

.tables_goalIconWrapper__ZKUy_ {
  display: inline-flex;
  width: 0.9em;
  height: 0.7rem;
  align-items: center;
}

@media (max-width: 1000px) {
  .tables_tableCellCollapse1__I5H7R {
    display: none;
  }
}

@media (max-width: 800px) {
  .tables_tableCellCollapse2__Md4zA {
    display: none;
  }
}

/*!***********************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[13].oneOf[7].use[2]!./node_modules/next/dist/build/webpack/loaders/postcss-loader/src/index.js??ruleSet[1].rules[13].oneOf[7].use[3]!./src/app/components/candidate.module.css ***!
  \***********************************************************************************************************************************************************************************************************************************************************************************/
.candidate_candidateInfoBlock__hmXVi {
  display: flex;
  align-items: center;
}

.candidate_candidateImageWrapper___X5Ex {
  display: inherit;
  flex-shrink: 0;
  border-radius: 50%;
  border-width: 4px;
  border-style: solid;
  width: 58px;
  height: 58px;
  margin-left: 0.5em;
  margin-right: 0.5em;
  color: var(--placeholder-color);
}

.candidate_chartCandidateImageWrapper__y_yY4 {
  width: 24px;
  height: 24px;
  border-width: 2px;
}

.candidate_candidateImage__KIOVE {
  display: inherit;
  border-radius: 50%;
  width: 50px;
  height: 50px;
}

.candidate_noMargins___A7xf {
  margin-left: 0;
}

.candidate_chartCandidateImage__2bdog,
.candidate_chartPlaceholderImage__pURfZ {
  width: 20px !important;
  height: 20px !important;
}

.candidate_placeholderImage__Sdi4N {
  width: 50px;
  height: 50px;
}

.candidate_unknownCandidateQuestionMark__R_jOG {
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--card-background);
  font-weight: bold;
  font-size: 300px;
}

.candidate_unknownCandidateText__HYjSt {
  color: var(--secondary-text);
  font-style: italic;
}

.candidate_defeatedCandidateImage__GvmVO {
  position: relative;
  &:after {
    content: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" version="1.1" id="Layer_1" x="0px" y="0px" viewBox="0 0 96 96" enable-background="new 0 0 96 96" xml:space="preserve"><polygon fill="red" points="96,14 82,0 48,34 14,0 0,14 34,48 0,82 14,96 48,62 82,96 96,82 62,48 "/></svg>');
    position: absolute;
    top: -4px;
    left: -4px;
    width: 60px;
    height: 60px;
  }
}

.candidate_party-R__h2sTR {
  border-color: var(--party-republican);
}

.candidate_party-D__tkHf_ {
  border-color: var(--party-democrat);
}

.candidate_party-L__mNUAW {
  border-color: var(--party-libertarian);
}

.candidate_party-G__T0dxy {
  border-color: var(--party-green);
}

.candidate_party-I__do0rW {
  border-color: var(--party-independent);
}

.candidate_party-unknown__5OALt {
  border-color: var(--color-slate-500);
}

.candidate_party-loading__YCZ9T {
  border-color: var(--skeleton-end);
}

/*!********************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[13].oneOf[7].use[2]!./node_modules/next/dist/build/webpack/loaders/postcss-loader/src/index.js??ruleSet[1].rules[13].oneOf[7].use[3]!./src/app/components/skeletons/skeleton.module.css ***!
  \********************************************************************************************************************************************************************************************************************************************************************************************/
@keyframes skeleton_pulse__ZQ037 {
  0% {
    background-position: 0% 0%;
  }
  100% {
    background-position: -135% 0%;
  }
}

.skeleton_pulse__ZQ037 {
  background: linear-gradient(-90deg, var(--skeleton-start) 0%, var(--skeleton-end) 50%, var(--skeleton-start) 100%);
  background-size: 400% 400%;
  animation: skeleton_pulse__ZQ037 1.2s ease-in-out infinite;
}

.skeleton_cardPulse__8Jcqz {
  background: linear-gradient(
    -90deg,
    var(--skeleton-on-card-start) 0%,
    var(--skeleton-on-card-end) 50%,
    var(--skeleton-on-card-start) 100%
  );
  background-size: 400% 400%;
  animation: skeleton_pulse__ZQ037 1.2s ease-in-out infinite;
}

.skeleton_skeletonLayout__9ROdn {
  width: 100%;
  height: 1rem;
  margin-bottom: 0.5rem;
}

.skeleton_skeleton__OW6su {
}

.skeleton_skeletonCard__1N4Yg {
}

/*!**********************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[13].oneOf[7].use[2]!./node_modules/next/dist/build/webpack/loaders/postcss-loader/src/index.js??ruleSet[1].rules[13].oneOf[7].use[3]!./src/app/components/informationalTooltip.module.css ***!
  \**********************************************************************************************************************************************************************************************************************************************************************************************/
.informationalTooltip_tooltipButton__qD_0e {
  background-color: transparent;
  border-width: 0;
  font-family: inherit;
  font-size: 0.8rem;
  font-style: inherit;
  font-weight: inherit;
  line-height: inherit;
  padding: 0;
  cursor: pointer;
}

.informationalTooltip_tooltip__SR1Td {
  padding: 0.5rem;
  box-shadow: var(--shadow-md);
  border: 1px solid var(--card-border);
  border-radius: 4px;
  background-color: var(--card-background);
  max-width: 12rem;
  font-size: 0.9rem;
}

/*!********************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[13].oneOf[7].use[2]!./node_modules/next/dist/build/webpack/loaders/postcss-loader/src/index.js??ruleSet[1].rules[13].oneOf[7].use[3]!./src/app/components/recentExpenditures.module.css ***!
  \********************************************************************************************************************************************************************************************************************************************************************************************/
.recentExpenditures_recentExpendituresSectionHeader__mr_xY {
  padding: 1rem 1rem 0 1rem;
  font-size: 1.5rem;
}

.recentExpenditures_recentExpenditureRow__sV1j1 {
  display: flex;
  flex-direction: column;
  padding: 1rem;

  &:nth-child(even) {
    background: var(--table-background-secondary);
  }
}

.recentExpenditures_topGroup__g8SA9 {
  margin: 0.5rem 0;
}

.recentExpenditures_expenditureNameAndAmount__ZvCVy {
  display: flex;
  justify-content: space-between;
}

.recentExpenditures_expenditureTarget__YJzpC {
  margin-right: 0.25rem;
}

.recentExpenditures_expenditureDescription__lIO2M {
  font-size: 0.9rem;
  font-style: italic;
}

.recentExpenditures_tableCardContent__eOzY2 {
  padding: 1rem;
}

/*!*******************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[13].oneOf[7].use[2]!./node_modules/next/dist/build/webpack/loaders/postcss-loader/src/index.js??ruleSet[1].rules[13].oneOf[7].use[3]!./src/app/page.module.css ***!
  \*******************************************************************************************************************************************************************************************************************************************************************/
.page_titleWrapper__mv4nm {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0;
}

.page_title__3jonF {
  display: flex;
  justify-content: center;
  margin: 0 2rem;
}

.page_titleH1__kbFXP {
  display: block;
  text-align: center;
  font-size: clamp(2rem, 5vw, 6rem);
  margin: 0;
}

.page_logoArrow__1l9OG {
  display: flex;
  font-weight: bold;
  font-size: clamp(2rem, 5vw, 6rem);
}

.page_totalsRow__WauH8 {
  display: grid;
  grid-gap: inherit;
  gap: inherit;
  grid-template-columns: 1fr;
  margin: 0 auto;
}

.page_mainCards__vUYJ_ {
  display: grid;
  grid-gap: 1rem;
  gap: 1rem;
  grid-template-columns: minmax(20rem, 1fr);
  grid-template-rows: repeat(2, 20rem) repeat(3, auto);
  grid-template-areas:
    "byParty"
    "byCommittee"
    "influencedCard"
    "superPacCard"
    "expenditures";
}

.page_spentTopSection__5AXek {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 2.4rem;
}

.page_expendituresByCommitteeCard__Dxx3S {
  grid-area: byCommittee;
}

.page_recentExpenditures__YyT_P {
  grid-area: expenditures;
  position: relative;
  display: flex;
  flex-direction: column;
}

.page_recentExpendituresWrapper__Op4Qc {
  height: 100%;
}

@media (min-width: 576px) {
  .page_totalsRow__WauH8 {
    grid-template-columns: repeat(2, minmax(10rem, 25rem));
  }

  .page_titleH1__kbFXP,
  .page_logoArrow__1l9OG {
    text-shadow: 0.25rem 0.25rem var(--accent);
  }
}

@media (min-width: 768px) {
  .page_mainCards__vUYJ_ {
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: 20rem repeat(3, auto);
    grid-template-areas:
      "byParty byCommittee"
      "influencedCard influencedCard"
      "superPacCard superPacCard"
      "expenditures expenditures";
  }
}

@media (min-width: 1200px) {
  .page_mainCards__vUYJ_ {
    grid-template-columns: 2fr 1fr;
    grid-template-rows: 20rem 20rem auto;
    grid-template-areas:
      "influencedCard byParty"
      "influencedCard byCommittee"
      "superPacCard expenditures";
  }
}
