html {
   background: white; 
   width: 100%;
   height: 100%; 
}	

.wrap { position: relative; }


/* Colors */  

.orange 		{ background-color: #e93d33; }  
.dark-blue 	{ background-color: #263e74; }
.light-blue	{ background-color: #2054A2; }
.black 			{	background-color: black; }  
.gray 			{ background-color: #e3e3e3; } 
.white 			{	background-color: white; }   

.orange *, .dark-blue *, .light-blue *, .black * {
	color: white;
  }

.orange h1, .orange h2, .orange h3, .orange h4,
.dark-blue h1, .dark-blue h2, .dark-blue h3, .dark-blue h4,
.light-blue h1, .light-blue h2, .light-blue h3, .light-blue h4,
.black h1, .black h2, .black h3, .black h4 { 
	color: white;
	}	

/* --- Endorse --- */
.endorse { 
  display: block; 
  position: relative;
  background: #2054A2;
  text-align: center;
  overflow: hidden;
  padding: 5em 3em;
  color: white; 
  height: 100%;
  }

@media only screen and (min-width: 1100px) { 
  .endorse { padding: 4em 0;}
  }

.endorse h2 { 
    font-size: 3.5em;
    color: white;
    margin-bottom: .25em;
    text-transform: none;
	}

.endorse form { 
   max-width: 500px;
   margin: 0 auto !important;}

.endorse.form.inline input { 
   font-size: 125%;
   -webkit-border-radius: 100px;
    border-radius: 100px;
}

.endorse.form.inline button { 
   font-size: 150%;
   background: white;
   color: #2054A2;
   padding: .75em 2em;
   font-weight: 800; 
   font-family: 'Barlow Condensed', sans-serif;
   text-transform: uppercase;
   line-height: 1.1;
}
	
.endorse.form.inline button:hover,
.endorse.form.inline button:active{ 
   background: #AF190E;
   color: white;
}
  


/* Contribution Button */

.footer-button { 
  padding: 1em;
  width: 100%;
  text-align: center;
  margin: 0;
  }
  
@media only screen and (min-width: 740px) { 
  .footer-button { 
    padding: 0 2em 2em;
    }
  #home .footer-button { 
    padding: 2em;
    }
  }

.contribute { 
  background: #de6328;
  font-size: 110%;
  font-weight: 700;
  text-transform: uppercase;
  padding: .5em 1em;
  color: white;
  display: inline-block;
  line-height: 1;
  -moz-transition:    all .3s cubic-bezier(0.75, -0.25, 0.25, 0.75);
  -o-transition:      all .3s cubic-bezier(0.75, -0.25, 0.25, 0.75);
  -webkit-transition: all .3s cubic-bezier(0.75, -0.25, 0.25, 0.75);
  transition:         all .3s cubic-bezier(0.75, -0.25, 0.25, 0.75);  
  }

.contribute:hover,
.contribute:active{ 
  color: white;
  background: #c2511b;
  }
  
@media only screen and (min-width: 1100px) { 
  .contribute { 
    font-size: 150%;
    }
  }


.endorse-button { 
   font-size: 120%;
   font-weight: 800;
   text-transform: uppercase;
   padding: .5em 1em;
   color: white;
   display: inline-block;
   line-height: 1;
   background: #e93d33;
   color: white;
   -webkit-border-radius: 100px;
   border-radius: 100px;
  }

.endorse-button:hover,
.endorse-button:active{ 
  color: white;
  background: #518efe;
  }
  
@media only screen and (min-width: 1100px) { 
  .endorse-button { 
    font-size: 150%;
    }
  }


  
/* --- Footer --- */

footer { 
  padding: 3em 1em;
  position: relative;
  text-align: center; 
  background: #ececec;
  width: 100%;
  }
  
footer .wrap {
   width: 100%;
   max-width: 100%;
   margin: 2em auto;
}

@media only screen and (min-width: 1100px) { 
   footer .wrap {
      display: flex;
      max-width: 1600px;
   }
} 
 
footer .paidfor { 
  font-size: 1.1em; 
  border: 1px solid #e3e3e3;
  padding: .5em;
  display: inline-block;
  }



@media only screen and (min-width: 1200px) { 
.paidfor { 
  font-size: 1.4em;
  }
}
  
  
/* --- Tiles --- */


.tiles { 
  text-align: center;
  padding: 1em;
  }
  
@media only screen and (min-width: 768px) { 
	.tiles { 
	  padding: 1.5em;
	  }
  }  
  
@media only screen and (min-width: 1200px) { 
	.tiles { 
	  padding: 2em;
	  }
  } 
  
@media only screen and (min-width: 1200px)   { 
	.tiles .table  { 
		max-width: 1400px;
		}
	}  

.tiles article { 
  padding-bottom: 1.5em;
  position: relative;
  display: inline-block;   
  vertical-align: text-top; 
  width: 100%;
  }

@media only screen and (min-width: 740px)   { 
	.tiles .table article { 
		padding-right: 2.5px; 
		padding-left: 2.5px; 
		padding-bottom: 1.5em;
		width: 49.5%;/* ?????*/
		}
	}
	
@media only screen and (min-width: 1100px)   { 
	#home .tiles .table article { 
		padding-bottom: 0;
		}
	}
	


@media only screen and (min-width: 1200px) { 
  .tiles .table article  { width: 24.5%; }
  }
  
.tiles article a { 
	display: block;
	padding: 0 !important;
  -webkit-transition: all .2s ease-in-out;
  -moz-transition:    all .2s ease-in-out;
  -o-transition:      all .2s ease-in-out;
  -ms-transition:     all .2s ease-in-out;
  transition:         all .2s ease-in-out; 
  z-index: 1;
  }

.tiles article h4 {
  font-weight: 400;
  margin-bottom: .7em; 
  font-family: 'Roboto',sans-serif;
  line-height: 1;
  font-size: 100%;
  }  
  
.tiles article small { 
  color: #acacac; 
  text-transform: uppercase; 
  display: block; 
  margin-bottom: .5em;
  font-size: .8em; 
  }

@media only screen and (min-width: 1000px) { 
	.tiles article a { padding: 0 2.2em 2.2em; }  
	} 
	
	
/* --- image block --- */

.tiles figure { 
  position: relative;
  overflow: hidden;
  height: 0;
  padding-bottom: 52.3333%;
  margin-bottom: .5em;
  }	
  
.tiles.photos figure { 
  padding-bottom: 100%;
  }		
	
.tiles .tile-image { 
  background-position: center center;
  background-repeat: no-repeat;  
  -webkit-background-size: cover;
  -moz-background-size:    cover;
  -o-background-size:      cover;
  background-size:         cover;  
  -webkit-transition: all 1s ease-in-out;
  -moz-transition:    all 1s ease-in-out;
  -o-transition:      all 1s ease-in-out;
  -ms-transition:     all 1s ease-in-out;
  transition:         all 1s ease-in-out;
  height: 110%;
  width: 110%;
  position: absolute;
  top: -5%;
  left: -5%;
  z-index: 10;
  }
  
.tiles article:hover .tile-image { 
  -moz-transform:    scale(.925);
  -ms-transform:     scale(.925);
  -webkit-transform: scale(.925);
  transform:         scale(.925); 
  }	
	
	
/* --- News tiles --- */
	
.tiles.news article {
  padding: 1.5em; 
  text-align: left;
  -webkit-transition: background .1s ease-in-out;
  -moz-transition:    background .1s ease-in-out;
  -o-transition:      background .1s ease-in-out;
  -ms-transition:     background .1s ease-in-out;
  transition:         background .1s ease-in-out;
  }
  
.tiles.news article:hover {
  background: rgba(0,0,0,.05);
  }
  
.tiles.news.reveal article  {
}  
  
.tiles.news article a * {
	}  
	
.tiles.news article h3 {
  font-weight: 800;
  margin-bottom: .7em; 
  }  

.tiles.news article small { 
  opacity: .75;
  text-transform: uppercase; 
  display: block; 
  margin-bottom: .5em;
  font-weight: 400;
  }

.tiles.news .source  { 
  margin-top: 1.5em;
  opacity: .75;
  text-transform: uppercase; 
  position: relative;
  font-size: .9em;
  }
  
.tiles.news .source::before {
  background: rgba(0,0,0,.2);
  content: "";
  display: block;
  height: 1px;
  left: 0;
  position: absolute;
  bottom: 160%;
  width: 3em;
}
  
	
	

/* Video Section */

figure.player { 
  max-width: 100%;    
  height: 0; 
  padding-bottom: 56.25%; 
  position: relative;   
  overflow: hidden; 
} 
  
@media only screen and (min-width: 1000px) {
  figure.player { 
    width: 100vw;
    height: 56.25vw;
    max-height: 81vh;
    max-width: 144vh;
    padding-bottom: 0;
  } 
}
figure.player iframe, 
figure.player object, 
figure.player embed { 
  width: 100%; 
  height: 100%;   
  position: absolute;
  left: 0;   
  top: 0; 
}

/* ------------ Video Indicator ----------- */
 
.video-indicator { 
  background: black;
  background: rgba(0,0,0,.5);
  color: white;
  font-size: 36px !important;
  line-height: .75;
  padding: 10px;
  display: inline-block;
  position: absolute;
  text-align: center;
  -moz-border-radius:    20%;
  -webkit-border-radius: 20%;
  border-radius:         20%;
  top: 50%;
  left: 50%;
	margin-top: -24px;
  margin-left: -26px;
  -webkit-transition: all .2s ease-in-out;
  -moz-transition:    all .2s ease-in-out;
  -o-transition:      all .2s ease-in-out;
  -ms-transition:     all .2s ease-in-out;
  transition:         all .2s ease-in-out;
  z-index: 20;
  }
	
a:hover .video-indicator { 
  background: #de6328;
  color: white;
  }
  	






/* -------- Issues -------- */
.icons.issue-icon:before {
  display: block;
  font-size: 400%;
  margin-bottom: .2em;
}
.veterans .icons.issue-icon:before {
  content: "v";
}
.safety .icons.issue-icon:before {
  content: "s";
}
.second-acts .icons.issue-icon:before {
  content: "s";
}
.domestic-violence .icons.issue-icon:before {
  content: "d";
}
.childrens-health .icons.issue-icon:before {
  content: "c";
}
.economy .icons.issue-icon:before {
  content: "l";
}
.education .icons.issue-icon:before {
  content: "i";
}
.healthcare .icons.issue-icon:before {
  content: "u";
}
.transportation .icons.issue-icon:before {
  content: "n";
}
.civil-rights .icons.issue-icon:before {
  content: "r";
}
.working-families .icons.issue-icon:before {
  content: "w";
}
.second-acts .icons.issue-icon:before {
  content: "a";
}


/* -------- Transition Delays -------- */
.delay1 {
    -webkit-transition-delay: .1s !important;
    transition-delay: .1s !important; }
.delay2 {
    -webkit-transition-delay: .2s !important;
    transition-delay: .2s !important; }
.delay3 {
    -webkit-transition-delay: .3s !important;
    transition-delay: .3s !important; }
.delay4 {
    -webkit-transition-delay: .4s !important;
    transition-delay: .4s !important; }
.delay5 {
    -webkit-transition-delay: .5s !important;
    transition-delay: .5s !important; }
.delay6 {
    -webkit-transition-delay: .6s !important;
    transition-delay: .6s !important; }    
.delay7 {
    -webkit-transition-delay: .7s !important;
    transition-delay: .7s !important; }
.delay8 {
    -webkit-transition-delay: .8s !important;
    transition-delay: .8s !important; }
.delay9 {
    -webkit-transition-delay: .9s !important;
    transition-delay: .9s !important; }
.delay10 {
    -webkit-transition-delay: 1s !important;
    transition-delay: 1s !important; }
.delay11 {
    -webkit-transition-delay: 1.1s !important;
    transition-delay: 1.1s !important; }
.delay12 {
    -webkit-transition-delay: 1.2s !important;
    transition-delay: 1.2s !important; }
.delay13 {
    -webkit-transition-delay: 1.3s !important;
    transition-delay: 1.3s !important; }
.delay14 {
    -webkit-transition-delay: 1.4s !important;
    transition-delay: 1.4s !important; }
.delay15 {
    -webkit-transition-delay: 1.5s !important;
    transition-delay: 1.5s !important; }
.delay16 {
    -webkit-transition-delay: 1.6s !important;
    transition-delay: 1.6s !important; }    
.delay17 {
    -webkit-transition-delay: 1.7s !important;
    transition-delay: 1.7s !important; }
.delay18 {
    -webkit-transition-delay: 1.8s !important;
    transition-delay: 1.8s !important; }
.delay19 {
    -webkit-transition-delay: 1.9 !important;
    transition-delay: 1.9 !important; }
.delay20 {
    -webkit-transition-delay: 2s !important;
    transition-delay: 2s !important; }

.trigger {
  opacity: 0;
  -moz-transition:    all .3s cubic-bezier(0.75, -0.25, 0.25, 0.75);
  -o-transition:      all .3s cubic-bezier(0.75, -0.25, 0.25, 0.75);
  -webkit-transition: all .3s cubic-bezier(0.75, -0.25, 0.25, 0.75);
  transition:         all .3s cubic-bezier(0.75, -0.25, 0.25, 0.75); 
	-moz-transform:    translateY(1rem);
	-ms-transform:     translateY(1rem);
	-webkit-transform: translateY(1rem);
	transform:         translateY(1rem);  
}
.trigger.reveal {
  opacity: 1;
  -moz-transform:    translateY(0);
	-ms-transform:     translateY(0);
	-webkit-transform: translateY(0);
	transform:         translateY(0);  
}

/* -------- More Buttons -------- */

.more { 
	font-weight: 700; 
	display: inline-block;
	position: relative;
	}

.more::after { 
	font-family: 'fionaicons';
	content:'>';
	position: absolute;
	right: -1.25em;
	opacity: .7;
	top: 0;
	-webkit-transition: all .3s ease-in-out;
  -moz-transition:    all .3s ease-in-out;
  -o-transition:      all .3s ease-in-out;
  -ms-transition:     all .3s ease-in-out;
  transition:         all .3s ease-in-out;
	}

.more:hover::after { 
	right: -1.4em;
	opacity: .8;
	}



/* --- Letter --- */

.video-intro { 
  display: block; 
  position: relative;
  background: white;
  text-align: center;
  margin: 1.5em;
  }
.video-intro-holder { 
   width: 100%;
   background: white;
   padding: 0;
   margin: 1.5em;
   overflow: hidden;
   max-width: 960px; 
   text-align: left;
   font-size: 1.1em;
   line-height: 1.2;
}  

.video-aspect-ratio {
    height: 0;
    width: 100%;
    padding-bottom: 80%;
    overflow: hidden;
}  
.video-image {
    width: 100%;
    height: 100%;
    display: block;
    background-position: center center;
    background-repeat: no-repeat;
    background-size: cover;
    position: absolute;
    top: 0;
    left: 0;
   -webkit-transition: all .35s ease-in-out;
   -moz-transition: all .35s ease-in-out;
   -ms-transition: all .35s ease-in-out;
   -o-transition: all .35s ease-in-out;
   transition: all .35s ease-in-out;        
}
.video-anchor {
    width: 100%;
    height: 100%;
    display: block;
    position: absolute;
    top: 0;
    left: 0;
}
.video-message {
    display: block;
    width: 100%;
    position: absolute;
    bottom: 0;
    transform: translateX(-50%);
    text-align: center;
}
.video-play {
    display: inline-block;
    margin: auto;
    font-size: 2.625rem;
}
.video-play-icon {
    background: #fff;
    width: 1.875em;
    height: 1.875em;
    border-radius: 50%;
    display: block;
    fill: #263e74;
    vertical-align: middle;
    margin: auto;
    transition: all 0.6s cubic-bezier(0.5, 1.65, 0.4, 0.8);
    -webkit-box-shadow: 0 0 25px 0 #263e74;
   box-shadow: 0 0 25px 0 #263e74;
}
.video-play-label {
   line-height: 1rem;
   margin: auto;
   vertical-align: middle;
   color: #fff;
   font-weight: 800; 
   font-family: 'Barlow Condensed', sans-serif;
   text-transform: uppercase;
   background: #263e74;
   padding: .15rem .5rem .3rem;
}

@media only screen and (min-width: 1100px) {
   .video-intro { margin: 0; }
   .video-aspect-ratio {
      padding-bottom: 56.25%;
   }
   .video-message {
      position: absolute;
      bottom: 2rem;
   }
   .video-play-icon {
      width: 5.625rem;
      height: 5.625rem;
      display: inline-block;
   }
   .video-play-label {
      white-space: nowrap;
      margin: auto auto auto 1rem;
      line-height: 5.625rem;
      padding: .25rem 1rem .5rem;
   }
   .video-intro-holder { 
      font-size: 1.3em;
      line-height: 1.3;
      padding: 0; 
      margin: 0 auto;
      position: relative;
      top: -3em;
      z-index: 10;
      box-shadow: 0 20px 20px 0px  rgba(0,0,0,.15);
      -webkit-transition: all .35s ease-in-out;
      -moz-transition: all .35s ease-in-out;
      -ms-transition: all .35s ease-in-out;
      -o-transition: all .35s ease-in-out;
      transition: all .35s ease-in-out;        
   }
   .video-intro-holder:hover {
      top: -5em;
   }
   .video-intro-holder:hover .video-image {
      -moz-transform: scale(1.1);
      -webkit-transform: scale(1.1);
      -o-transform: scale(1.1);
      -ms-transform: scale(1.1);
      transform: scale(1.1);
   }   
   .video-intro-holder.reveal { 
      box-shadow: 0 1em 3em 0 rgba(0,0,0,.1);
   }
}

.about .video-intro {
   margin: 1em 0 4em 0;
}
.about .video-intro-holder {
   top: 0;
}

.video-modal {
  display: none;
  /*width: 90%;
  max-width: 1200px;*/
  position: relative;
  text-align: center !important;
  opacity: 0;
  transform: scale(0.9);
  transition: all .3s ease-in-out;
}

.video-modal-player {
  display: block;
  position: relative;
  width: 100vw;
  height: 56.25vw;
  max-height: 81vh;
  max-width: 144vh;
  overflow: hidden;
  z-index: 100;
  margin: auto auto 1.5rem auto;
}

.video-modal-player iframe,
.video-modal-player object,
.video-modal-player embed {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.video-modal .close {
  position: absolute;
  top: 0;
  right: 0;
  z-index: 1000;
  display: block;
  width: 3em;
  height: 3em;
  padding: .75em;
  border-radius: 50%;
  cursor: pointer;
  border: none;
  background: transparent;
  display: none;
  transform: translateX(50%) translateY(-50%);
  transition: all .3s ease-in-out;
}

.video-modal_close.button {
   display: inline-block;
   font-size: 150%;
   color: #263e74;
	background: white;
	padding: .75em 2em;
   font-weight: 800; 
   font-family: 'Barlow Condensed', sans-serif;
   text-transform: uppercase;
   line-height: 1.1;
   -webkit-border-radius: 100px;
    border-radius: 100px;   
}

@media (min-width: 48em) {
  .video-modal .close {
    display: block;
  }
}
.close.video-modal_close  {
   background: white;
}

.video-modal .close svg {
  fill: #263e74;
  width: 1.5em;
  max-height: 3em;
}

.video-modal .close svg:hover {
  fill: #f34035;
}

.popup_visible .video-modal {
  opacity: 1;
  transform: scale(1);
}

.popup_background {
  background: #263e74 !important;
  opacity: 0.9 !important;
}

	
/* Issues Structure */

.issues.layer a p { 
	font-size: 130%; 
	line-height: 1.3; 
	}

/* Individual Issues */

div.issue {
  width: 49%; 
  display: inline-block;
  vertical-align: text-top;
  position: relative;
  }
div.issue a {
  padding: 1em .5em;  
  font-size: 1.1em;  
  display: block;
  -webkit-transition: all .3s ease-in-out;
  -moz-transition:    all .3s ease-in-out;
  -o-transition:      all .3s ease-in-out;
  -ms-transition:     all .3s ease-in-out;
  transition:         all .3s ease-in-out;
}
div.issue a .icons {
  -webkit-transition: all .3s ease-in-out;
  -moz-transition:    all .3s ease-in-out;
  -o-transition:      all .3s ease-in-out;
  -ms-transition:     all .3s ease-in-out;
  transition:         all .3s ease-in-out;
}  

@media only screen and (min-width: 740px) { 
  div.issue { 
    width: 32%;
    padding: 1em;
    }
}
@media only screen and (min-width: 1100px) { 
  div.issue {
    width: 16%; 
    font-size: 100%;
    }  
} 


  
/* -------- General Slide -------- */

.controls {
  position: relative;
}

.controls::after {
  background: rgba(0,0,0,.1);
  content: "";
  display: block;
  height: 2px;
  left: 50%;
  position: absolute;
  bottom: 120%;
  width: 4em;
  transform: translateX(-50%);
}





/*** Jump Nav ***/

nav.jump {
    text-align: center;
    text-transform: uppercase;
    font-size: .75em;
    padding: 3em 1em 2em;
}
nav.jump .label {
    font-size: 1.3em;
    display: block;
    padding-bottom: .6em;
}
nav.jump ul {
    display: inline-block;
    list-style: none;
    margin: 0 auto 0 1em;
    text-align: center;
}
nav.jump  li {
    background: #e3e3e3;
    display: inline-block;
    padding: 0;
    margin: 2px;
    -webkit-transition: all .25s ease-in-out;
    -moz-transition:    all .25s ease-in-out;
    -o-transition:      all .25s ease-in-out;
    -ms-transition:     all .25s ease-in-out;
    transition:         all .25s ease-in-out;	
}
nav.jump li:hover {
    background: #263e74;
}

nav.jump li a {
    color: #263e74;
    padding: .7em .6em;
    display: block;
    position: relative;
    z-index: 100;
    -webkit-transition: color .25s ease-in-out;
    -moz-transition:    color .25s ease-in-out;
    -o-transition:      color .25s ease-in-out;
    -ms-transition:     color .25s ease-in-out;
    transition:         color .25s ease-in-out;      
}
nav.jump li:hover a {
    color: #fff;
}

@media only screen and (min-width: 500px) {
    nav.jump {
        padding: 4em 2em 2em;
        font-size: .75em;
    }
}
@media only screen and (min-width: 1000px) {
    nav.jump {
        padding: 7em 2em 2em;      
        font-size: .85em;
    }
    nav.jump.label {
        display: inline-block;
    }
   nav.jump  li {
      margin: 0; 
   }
   nav.jump li a {
        padding: .5em .7em;
    }
}
