/* OVERRIDES */
body.page_home {
	background-image: none !important;
}
.page_home header {
	height: 136px;
	background: transparent;
}
.page_home .main-content {
	box-shadow: none;
	margin-top: 0px;
	margin-bottom: 0px;
}
@media (max-width: 979px) {
	.page_home header {
		height: auto;
		background: #000;
	}
}

/* GENERIC */
.module:after {
	content: "";
	display: block;
	clear: both;
}
.module h2.module-title {
	margin: 0;
	padding: 0;
	text-align: center;
	height: 178px;
	line-height: 178px;
	background: #321901 center top no-repeat;
	color: #fff;
	text-transform: uppercase;
	font-family: 'Oswald', serif;
	font-size: 44px;
	font-weight: 400;
	text-shadow: 2px 2px 3px rgba(0,0,0,.5);
	box-shadow: 4px 4px 10px rgba(0, 0, 0, .35);
	position: relative;
	z-index: 10;
}
.module .module-content {
	padding: 80px 0;
	background: #e9e9e9;
	background: -webkit-linear-gradient(#e9e9e9, #ffffff); /* For Safari 5.1 to 6.0 */
    background: -o-linear-gradient(#e9e9e9, #ffffff); /* For Opera 11.1 to 12.0 */
    background: -moz-linear-gradient(#e9e9e9, #ffffff); /* For Firefox 3.6 to 15 */
    background: linear-gradient(#e9e9e9, #ffffff); /* Standard syntax (must be last) */
}
@media (max-width: 979px) {
	.module h2.module-title {
		font-size: 34px;
	}
}
@media (max-width: 767px) {
	.module .module-content {
		padding: 40px;
	}
}
/* FEATURED */
#featured {
	color: #fff;
}
#featured .tabs {
	height: 464px;
}
#featured .tabs .tab {
	display: none;
	height: 464px;
	background: url(../images/bg_1.jpg) top center no-repeat;
	background-size: cover;
	text-align: center;
}
#featured .tabs .tab .tab-overlay {
	height: 464px;
	background: rgba(0, 0, 0, .55);
}
#featured .tabs .tab.is-visible {
	display: block;
}
#featured .tabs .tab .title {
	margin: 70px 0 20px;
	padding: 0;
	color: #fff;
	font-family: 'Oswald', serif;
	font-weight: 400;
	font-size: 42px;
	line-height: 52px;
	text-shadow: 2px 2px 4px #000000;
}
#featured .tabs .tab .abstract {
	margin: 0 0 20px;
	padding: 0;
	font-size: 20px;
	line-height: 30px;
	text-shadow: 2px 2px 4px #000000;
}
#featured .tabs .tab .learn-more {
	display: block;
	font-size: 18px;
	line-height: 20px;
	padding: 20px;
	border: 1px solid #fff;
	color: #fff;
	font-weight: 700;
	text-transform: uppercase;
	text-align: center;
	max-width: 200px;
	margin: 0 auto;
}
#featured .tabs .tab .learn-more:hover {
	color: #38383b;
	background: #fff;
	text-decoration: none;
}

#featured .tabs-nav {
	height: 0;
	display: none;
}
#featured:hover .tabs-nav {
	display: block;
}
#featured .tabs-nav .container {
	position: relative;
}
#featured .tabs-nav .container button {
	display: block;
	position: absolute;
	top: -404px;
	width: 74px;
	height: 344px;
	margin: 0;
	border: 0;
	padding: 0;
	background: transparent 0 0 no-repeat;
	outline: 0;
	text-indent: -10000px;
}
#featured .tabs-nav .container button:hover {
	background-position: 0 -344px;
}
#featured .tabs-nav .container button.previous {
	background-image: url(../images/ft_prev.png);
	left: 0px;
}
#featured .tabs-nav .container button.next {
	background-image: url(../images/ft_next.png);
	right: 0px;
}
@media (max-width: 979px) {
	#featured .tabs .tab .title {
		font-size: 24px;
		line-height: 34px;
	}
	#featured .tabs .tab .abstract {
		font-size: 18px;
		line-height: 28px;
	}
	#featured .tabs-nav {
		display: block;
	}
}
@media (max-width: 767px) {
	#featured .tabs {
		height: auto;
	}
	#featured .tabs .tab {
		display: block;
		height: auto;
	}
	#featured .tabs .tab .tab-overlay {
		height: auto;
		padding: 40px;
	}
	#featured .tabs .tab .title {
		margin-top: 0;
	}
	#featured .tabs-nav {
		display: none !important;
	}
}
/* SERVICES */
#services {
	padding: 80px 0;
	background: url(../images/bg_services.png) center center repeat;
	color: #fff;
	box-shadow: 0px 0px 25px rgba(0, 0, 0, 1) inset;
}
#services h2 {
	margin: 0 0 40px;
	padding: 0;
	text-align: center;
	text-transform: uppercase;
	font-family: 'Oswald', serif;
	font-size: 44px;
	line-height: 44px;
	font-weight: 400;
	text-shadow: 2px 2px 3px rgba(0,0,0,.5);
}
#services ul {
	width: 840px;
	margin: 0 auto;
	padding: 0;
	list-style: none;
}
#services ul li {
	float: left;
	margin-left: 14px;
	margin-right: 14px;
}
#services ul li a {
	display: block;
	text-align: center;
	font-family: 'Oswald', serif;
	font-size: 16px;
	text-transform: uppercase;
	font-weight: 400;
	line-height: 18px;
	color: #b5b5b7;
	width: 112px;
}
#services ul li a:hover {
	text-decoration: none;
}
#services ul li a .circle {
	content: "";
	display: block;
	width: 112px;
	height: 112px;
	background: url(../images/services_circle.png) 0 0 no-repeat;
	margin-bottom: 20px;
}
#services ul li a:hover .circle {
	background-position: 0 -112px;
}
#services ul li a .circle:after {
	content: "";
	display: block;
	width: 112px;
	height: 112px;
	background: center center no-repeat;
}
#services ul li.email a .circle:after {
	background-image: url(../images/services_emailthesenator.png);
}
#services ul li.flags a .circle:after {
	background-image: url(../images/services_flag.png);
}
#services ul li.visit a .circle:after {
	background-image: url(../images/services_visitdc.png);
}
#services ul li.assistance a .circle:after {
	background-image: url(../images/services_fedasst.png);
}
#services ul li.meeting a .circle:after {
	background-image: url(../images/services_req.png);
}
#services ul li.signup a .circle:after {
	background-image: url(../images/services_newsletter.png);
}
@media (max-width: 979px) {
	#services {
		padding: 40px 0;
	}
	#services h2 {
		display: none;
	}
	#services ul {
		width: 280px;
	}
	#services ul li {
		height: 200px
	}
}
/* UTAH FIRST */
#utah-first h2.module-title {
	background-image: url(../images/header_utahfirst.jpg);
}
#utah-first .module-content {
	background: #fff;
}
#utah-first .issue {
	text-align: center;
}
#utah-first .issue .image {
	display: block;
	width: 112px;
	height: 112px;
	background: url(../images/utahfirst_utahvets.jpg) center center no-repeat;
	margin: 0 auto 20px;
}
#utah-first .issue .image .image-overlay {
	display: block;
	width: 100%;
	height: 100%;
	background: url(../images/utahfirst_imgoverlay.png) center center no-repeat;
}
#utah-first .issue .title {
	display: block;
	margin-bottom: 10px;
	font-family: 'Oswald', serif;
	font-size: 26px;
	line-height: 30px;
	color: #bf6405;
	font-weight: 400;
}
#utah-first .issue .abstract {
	display: block;
	margin-bottom: 20px;
	font-size: 16px;
	line-height: 20px;
	color: #38383b;
}
#utah-first .issue .learn-more {
	display: block;
	text-align: center;
	text-transform: uppercase;
	font-weight: 700;
	font-size: 18px;
	color: #bf6405;
	border: 1px solid #bf6405;
	padding: 20px;
}
#utah-first .issue .learn-more:hover {
	color: #fff;
	text-decoration: none;
	background: #bf6405;
}
@media (max-width: 979px) {
	#utah-first .issue .title {
		font-size: 22px;
		line-height: 24px;
	}
}
@media (max-width: 767px) {
	#utah-first .issue {
		margin-bottom: 20px;
	}
	#utah-first .issue .learn-more {
		max-width: 200px;
		margin-left: auto;
		margin-right: auto;
	}
}
/* ABOUT */
#about h2.module-title {
	background-image: url(../images/header_aboutmikelee.jpg);
}
#about .box {
	background: #fff;
	box-shadow: 2px 2px 4px rgba(0, 0, 0, .2);
	padding: 25px 30px;
	color: #38383b;
	margin-bottom: 22px;
}
#about .box.bio img {
	float: left;
}
#about .box.bio p {
	margin: 0 0 0 130px;
	padding: 0;
}
#about .box.bio p a {
	text-transform: uppercase;
}
#about .box.stay-connected h3 {
	float: right;
	margin: 0;
	padding: 0;
	line-height: 48px;
	font-family: 'Oswald', serif;
	font-size: 16px;
	color: #38383b;
	text-transform: uppercase;
	font-weight: 400;
}
#about .box.stay-connected ul {
	float: left;
	margin: 0;
	padding: 0;
	list-style: none;
}
#about .box.stay-connected ul li {
	float: left;
	margin-right: 10px;
}
#about .box.stay-connected ul li a {
	display: block;
	width: 48px;
	height: 48px;
	text-indent: -10000px;
	outline: 0;
	background: transparent 0 0 no-repeat;
}
#about .box.stay-connected ul li a:hover {
	background-position: 0 -48px;
}
#about .box.stay-connected ul li.facebook a {
	background-image: url(../images/aboutmike_fb.png);
}
#about .box.stay-connected ul li.twitter a {
	background-image: url(../images/aboutmike_tw.png);
}
#about .box.stay-connected ul li.youtube a {
	background-image: url(../images/aboutmike_yt.png);
}
#about .box.stay-connected ul li.instagram a {
	background-image: url(../images/aboutmike_ig.png);
}
#about .box.stay-connected ul li.pinterest a {
	background-image: url(../images/aboutmike_pin.png);
}
#about .box.stay-connected ul li.vekeo a {
	background-image: url(../images/soc_vekeo.png);
}

@media (min-width: 1200px) {
	#about .box.stay-connected h3 {
		font-size: 22px;
	}
}
@media (max-width: 979px) {
	#about .box.bio img {
		margin-right: 10px;
		margin-bottom: 10px;
	}
	#about .box.bio p {
		margin-left: 0;
	}
	#about .box.stay-connected h3 {
		display: none;
	}
}
@media (max-width: 767px) {
	#about .box.stay-connected {
		padding: 0;
		background: transparent;
		box-shadow: none;
	}
	#about .box.stay-connected ul {
		float: none;
		max-width: 290px; /* (48px + 10px) * 5 */
		margin: 0 auto;
	}
	#about .box.stay-connected ul li {
		margin: 5px;
	}
}
/* ISSUES */
#issues h2.module-title {
	background-image: url(../images/header_issues.jpg);
}
#issues .issue a {
	display: block;
	height: 252px;
	position: relative;
	box-shadow: 2px 2px 4px rgba(0, 0, 0, .2);
	margin-bottom: 20px;
}
#issues .issue a .image {
	display: block;
	background: #000 center center no-repeat;
	background-image: url(../images/issues_fiscal.jpg);
	background-size: cover;
	width: 100%;
	height: 200px;
	position: absolute;
	top: 0;
	left: 0;
}
#issues .issue a .image .image-overlay {
	display: block;
	width: 100%;
	height: 100%;
}
#issues .issue a:hover .image .image-overlay {
	background: rgba(174, 91, 4, .45);
}
#issues .issue a .title {
	display: block;
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	background: #B25D05 url(../images/issues_titlebg.png) right center repeat-y;
}
#issues .issue a .title .title-inner {
	display: block;
	padding: 17px 20px;
	font-family: 'Oswald', serif;
	font-size: 16px;
	line-height: 18px;
	text-transform: uppercase;
	color: #fff;
	font-weight: 400;
}
#issues .issue a:hover .title .title-inner {
	text-decoration: none;
}
@media (min-width: 1200px) {
	#issues .issue a {
		margin-bottom: 30px;
	}
}
@media (max-width: 979px) and (min-width: 768px) {
	#issues .issue {
		width: 352px;
	}
}
/* PRESS */
#press h2.module-title {
	background-image: url(../images/header_press.jpg);
}
#press .press-tab-nav-full {
	display: block;
}
#press .press-tab-nav-full ul {
	margin: 0 0 20px;
	padding: 0 0 10px;
	list-style: none;
	border-bottom: 1px solid #ceced8;
}
#press .press-tab-nav-full ul li {
	float: left;
	margin-right: 30px;
}
#press .press-tab-nav-full ul li a {
	display: block;
	font-family: 'Oswald', serif;
	font-weight: 400;
	text-transform: uppercase;
	font-size: 20px;
	line-height: 22px;
	color: #5a5a5f;
}
#press .press-tab-nav-full ul li a:hover,
#press .press-tab-nav-full ul li a.highlighted {
	text-decoration: none;
	color: #bf6400;
}
#press .press-tab-nav-mobile {
	display: none;
}
#press .press-tabs {
	margin-bottom: 10px;
}
#press .press-tabs .press-tab {
}
#press .press-tabs .press-tab ul {
	margin: 0;
	padding: 0;
	list-style: none;
}
#press .press-tabs .press-tab ul li {
	margin: 0 0 20px;
	padding: 0 0 0 50px;
	background: url(../images/press_icon_pr.png) left top no-repeat;
	min-height: 34px;
}
#press .press-tabs .press-tab ul li.type-press-releases {
	background-image: url(../images/press_icon_pr.png);
}
#press .press-tabs .press-tab ul li.type-blog {
	background-image: url(../images/press_icon_blog.png);
}
#press .press-tabs .press-tab ul li.type-op-eds {
	background-image: url(../images/press_icon_oped.png);
}
#press .press-tabs .press-tab ul li.type-speeches {
	background-image: url(../images/press_icon_speech.png);
}
#press .press-tabs .press-tab ul li.type-videos {
	background-image: url(../images/press_icon_video.png);
}
#press .press-tabs .press-tab ul li .title {
	display: block;
	font-size: 16px;
	line-height: 18px;
	color: #38383b;
}
#press .press-tabs .press-tab ul li .title:hover {
	text-decoration: none;
	color: #bf6400;
}
#press .press-tabs .press-tab ul li .date {
	display: block;
	font-size: 14px;
	line-height: 16px;
	font-style: italic;
	color: #38383b;
}
#press .twitter-update {
	border: 1px solid #ceced8;
	background: #fff;
	box-shadow: 5px 5px rgba(0, 0, 0, .07);
	min-height: 72px;
}
#press .twitter-update .twitter-icon {
	display: block;
	position: relative;
	float: left;
	margin-left: -1px;
	margin-top: -1px;
	margin-right: 20px;
	margin-bottom: 20px;
	width: 74px;
	height: 74px;
	background: #be6405;
	background: -webkit-linear-gradient(#be6405, #974f04); /* For Safari 5.1 to 6.0 */
    background: -o-linear-gradient(#be6405, #974f04); /* For Opera 11.1 to 12.0 */
    background: -moz-linear-gradient(#be6405, #974f04); /* For Firefox 3.6 to 15 */
    background: linear-gradient(#be6405, #974f04); /* Standard syntax (must be last) */
}
#press .twitter-update .twitter-icon:after {
	content: "";
	display: block;
	position: absolute;
	right: 0;
	top: 33px;
	width: 4px;
	height: 9px;
	background: url(../images/press_twitter_arrow.png) 0 0 no-repeat;
}
#press .twitter-update .twitter-icon .twitter-icon-inner {
	display: block;
	width: 100%;
	height: 100%;
	background: url(../images/press_twitter.png) center center no-repeat;
}
#press .twitter-update .tweet {
	height: 72px;
	display: table-cell;
	vertical-align: middle;
	padding-right: 20px;
	font-size: 18px;
	line-height: 20px;
	color: #38383b;
	font-weight: 700;
	font-style: italic;
}
@media (max-width: 767px) {
	#press .press-tab-nav-full {
		display: none;
	}
	#press .press-tab-nav-mobile {
		display: block;
	}
	#press .twitter-update .tweet {
		display: block;
		height: auto;
		padding: 20px;
	}
}
/* LEGISLATION */
#legislation h2.module-title {
	background-image: url(../images/header_legislation.jpg);
}
#legislation .leg-button a {
	display: block;
	text-align: center;
	line-height: 150px;
	font-size: 22px;
	color: #fff;
	font-family: 'Oswald', serif;
	font-weight: 400;
	text-transform: uppercase;
	background: #1b1b1d;
	background: -webkit-linear-gradient(#1b1b1d, #343437); /* For Safari 5.1 to 6.0 */
    background: -o-linear-gradient(#1b1b1d, #343437); /* For Opera 11.1 to 12.0 */
    background: -moz-linear-gradient(#1b1b1d, #343437); /* For Firefox 3.6 to 15 */
    background: linear-gradient(#1b1b1d, #343437); /* Standard syntax (must be last) */
    box-shadow: 2px 2px 4px rgba(0, 0, 0, .2);
}
#legislation .leg-button a:hover {
	text-decoration: none;
	background: #bf6405;
}
@media (min-width: 1200px) {
	#legislation .leg-button a {
		font-size: 26px;
	}
}
@media (max-width: 979px) {
	#legislation .leg-button a {
		line-height: 90px;
		font-size: 18px;
	}
}
@media (max-width: 767px) {
	#legislation .leg-button a {
		margin-bottom: 20px;
	}
}
/* CONTACT */
#contact h2.module-title {
	background-image: url(../images/header_contact.jpg);
}
#contact h3 {
	margin: 0;
	padding: 0;
	font-size: 26px;
	line-height: 30px;
	font-weight: 700;
	color: #38383a;
}
#contact p.note {
	margin: 0 0 20px;
	padding: 0;
	font-size: 16px;
	line-height: 18px;
	font-style: italic;
	color: #38383a;
}
#contact .contact-form {
	margin: 0 0 30px;
	padding: 0;
}
#contact .contact-form fieldset {
	margin: 0 0 20px;
	padding: 0;
}
#contact .contact-form fieldset > label {
	display: block;
	font-size: 16px;
	line-height: 18px;
	color: #38383a;
	margin: 0 0 5px;
}
#contact .contact-form fieldset > input {
	display: block;
	width: 100%;
	margin: 0;
	border: 1px solid #ceced8;
	background: #fff;
	padding: 0 10px;
	box-sizing: border-box;
	box-shadow: 1px 1px 4px rgba(0, 0, 0, .1) inset;
	height: 50px;
	line-height: 50px;
	font-family: 'Source Sans Pro', sans-serif;
	font-size: 16px;
	color: #38383b;
	border-radius: 0;
}
#contact .contact-form fieldset > select {
	display: block;
	width: 100%;
	height: 50px;
	margin: 0;
}
#contact .contact-form fieldset > textarea {
	display: block;
	width: 100%;
	margin: 0;
	border: 1px solid #ceced8;
	background: #fff;
	padding: 10px;
	box-sizing: border-box;
	box-shadow: 1px 1px 4px rgba(0, 0, 0, .1) inset;
	height: 200px;
	font-family: 'Source Sans Pro', sans-serif;
	font-size: 16px;
	line-height: 18px;
	color: #38383b;
	border-radius: 0;	
}
#contact .contact-form fieldset > button {
	display: block;
	font-size: 18px;
	line-height: 20px;
	padding: 15px 20px;
	border: 1px solid #bf6405;
	color: #bf6405;
	font-weight: 700;
	text-transform: uppercase;
	text-align: center;
	background: transparent;
	font-family: 'Source Sans Pro', sans-serif;
	width: 100%;
}
#contact .contact-form fieldset > button:hover {
	color: #fff;
	background: #bf6405;
	text-decoration: none;
}
#contact .signup-form {
	background: #1b1b1d;
	background: -webkit-linear-gradient(#1b1b1d, #343437); /* For Safari 5.1 to 6.0 */
	background: -o-linear-gradient(#1b1b1d, #343437); /* For Opera 11.1 to 12.0 */
	background: -moz-linear-gradient(#1b1b1d, #343437); /* For Firefox 3.6 to 15 */
	background: linear-gradient(#1b1b1d, #343437); /* Standard syntax (must be last) */
	box-shadow: 2px 2px 4px rgba(0, 0, 0, .2);
	color: #fff;
	padding: 30px 0;
}
#contact .signup-form h3 {
	color: #fff;
	font-family: 'Oswald', serif;
	font-size: 28px;
	line-height: 50px;
	margin: 0;
	padding: 0 0 0 30px;
	font-weight: 400;
	text-transform: uppercase;
}
#contact .signup-form h3 strong {
	font-weight: 700;
}
#contact .signup-form fieldset {
	margin: 0;
	padding: 0 20px;
	background: #fff;
	height: 50px;
	position: relative;
}
#contact .signup-form fieldset label {
	display: block;
	position: absolute;
	top: 0;
	left: 20px;
	font-size: 16px;
	line-height: 50px;
	color: #38383b;
}
#contact .signup-form fieldset.has-text label,
#contact .signup-form fieldset.has-focus label {
	display: none;
}
#contact .signup-form fieldset input {
	display: block;
	width: 100%;
	height: 50px;
	margin: 0;
	border: 0;
	padding: 0;
	background: transparent;
	font-family: 'Source Sans Pro', sans-serif;
	font-size: 16px;
	line-height: 50px;
	color: #38383b;
	border-radius: 0;
	outline: 0;
	box-shadow: none;
}
#contact .signup-form .button-container {
	padding-right: 30px;
}
#contact .signup-form button {
	display: block;
	font-size: 18px;
	line-height: 20px;
	padding: 15px 20px 14px;
	border: 1px solid #fff;
	color: #fff;
	font-weight: 700;
	text-transform: uppercase;
	text-align: center;
	background: transparent;
	font-family: 'Source Sans Pro', sans-serif;
	width: 100%;
}
#contact .signup-form button:hover {
	color: #38383b;
	background: #fff;
	text-decoration: none;
}
@media (min-width: 1200px) {
	#contact .signup-form h3 {
		padding-left: 100px;
		background: url(../images/contact_icon_newsletter.png) 30px center no-repeat;
	}
}
@media (max-width: 979px) {
	#contact .signup-form h3 {
		font-size: 22px;
	}
}
@media (max-width: 767px) {
	#contact .signup-form {
		padding: 20px;
	}
	#contact .signup-form h3 {
		padding-left: 0;
		margin-bottom: 20px;
		line-height: 24px;
	}
	#contact .signup-form fieldset {
		margin-bottom: 20px;
	}
	#contact .signup-form .button-container {
		padding-right: 0;
	}
}
/* OFFICE LOCATIONS */
#office-locations h2.module-title {
	background-image: url(../images/header_officelocations.jpg);
}
#office-locations .module-content {
	height: 388px;
	background: #38383b url(../images/map_bg.jpg) center top no-repeat;
	color: #fff;
	padding-bottom: 0px;
}
#office-locations .office {
	margin-bottom: 30px;
}
#office-locations .office h3 {
	margin: 0 0 15px;
	padding: 0;
	font-family: 'Oswald', serif;
	font-size: 26px;
	line-height: 30px;
	text-shadow: 2px 2px 2px rgba(0,0,0,1);
	font-weight: 400;
}
#office-locations .office address {
	margin: 0;
	padding: 0;
	font-size: 16px;
	line-height: 18px;
	text-shadow: 2px 2px 2px rgba(0,0,0,1);
}
#office-locations .office address * {
	margin: 0;
	padding: 0;
}
#office-locations .office .view {
	display: block;
	font-size: 18px;
	line-height: 20px;
	padding: 20px;
	border: 1px solid #fff;
	color: #fff;
	font-weight: 700;
	text-transform: uppercase;
	text-align: center;
}
#office-locations .office .view:hover {
	color: #38383b;
	background: #fff;
	text-decoration: none;
}
@media (min-width: 768px) and (max-width: 979px) {
	#office-locations .span3 {
		width: 228px; /* turning them into span4s */
	}
	#office-locations .span3.map-container {
		display: none;
	}
}
@media (max-width: 767px) {
	#office-locations .module-content {
		height: auto;
		padding: 40px;
		background-image: none;
	}
	#office-locations .map-container {
		display: none;
	}
	#office-locations .office .view {
		max-width: 200px;
	}
}

