@import url('https://fonts.googleapis.com/css?family=Roboto:100,100i,300,300i,400,400i,500,500i,700,700i,900,900i');

@font-face {
  font-family: 'Montserrat';
  src: url('/global/css/webfonts/Montserrat-Bold.ttf') format('truetype');
  font-weight: 700;
  font-style: normal;
}


html, body {
	margin:0;
	height:100%;
}
html {
	background-color: #2c2c2c;
	-webkit-background-size: cover;
	-moz-background-size: cover;
	-o-background-size: cover;
	background-size: cover;
}
body {
	margin:0;
	padding:0;
	border:none;
	background: #2c2c2c;
}
body, pre, th, td, input, select, textarea, label, p {
	font-family:"Roboto", sans-serif;
	font-size:14px;
}
.event_richtext p {
	margin:0;
}
html.modal {
	height:auto;
	background:none;
}
body.modal {
	background-color:#eaeaea;
	padding:10px;
}
body.modal.white {
	background-color:#FFF;
}
#qa-alert {
	position:absolute;
	top:1px;
	left:2px;
	font-size:32px;
	line-height:32px;
	color:red;
}
a {
	text-decoration:none;
	color:#ff971b;
}
#ppMainPad a:hover {
	color:#19a77b;
}
h1 {
	font-size: 36px;
	font-style: normal;
	font-weight: 400;
	line-height: 1;
	margin:0 0 15px 0;
	padding:0;
}
h2 {
	font-size: 22px;
	font-style: normal;
	font-weight: 400;
	line-height: 1;
	margin:0 0 10px 0;
	padding:0;
}
#ppMainPad img {
	border:none;
}
table {
	border-collapse:collapse;
	border:none;
	padding:0;
	margin:0;
}
.header-box-shadow {
	position: relative;
	z-index: 3;
}
.header-box-shadow:hover {
	z-index: 99999;
}
.header-box-shadow.fixed {
	box-shadow: 0 2px 10px 0 rgba(0, 0, 0, 0.25);
	position: fixed;
	left: 0;
	right: 0;
}
html { --header-height: 131px; }
.fixed-header-padding { height: var(--header-height); }
#ppTopTop {
	background: #0C9F50;
	height: 36px;
	display: flex;
	justify-content: flex-end;
}
#lang-select:hover {
	z-index: 10000000;
}
#ppTop {
	background: #013B27;
	height:95px;
	color:#FFF;
}
#ppTop .precision-logo {
	display: inline-flex;
	align-items: center;
}

#ppTop .precision-logo-mobile{
	height: 24px;
	margin-right: 6px;
	width: 26px;
}

#ppTop .precision-logo-desktop{
	display: none;
}

@media (min-width: 1200px){
	#ppTop .precision-logo-mobile{
		display: none;
	}
	#ppTop .precision-logo-desktop{
		display: block;
		height: 64px;
	}
}

.ppCont {
	position:relative;
	margin:0 auto;
	display: flex;
	justify-content: space-between;
	align-items: center;
	height: 100%;
	padding-left: 20px;
}
img.logo {
	float:left;
	width:239px;
	height:28px;
	margin-top:35px;
}

.ppNav {
	list-style:none;
	flex-grow: 1;
	z-index: 9999999;
}
.ppNav * {
	font-family: "Roboto", sans-serif;
}
.dropdown-nav {
    margin: 0;
    padding: 0;
    height: 100%;
	display: flex;
}
.ppNav > li {
	list-style:none;
	cursor:pointer;
	font-size: 16px;
	display: inline-block;
	height: 100%;
}
.dropdown-nav > li {
    padding-right: 39px;
}
.ppNav li div {
	font-size: 20px;
	font-weight: 400;
	display: flex;
	align-items: center;
	justify-content: center;
	height: 99%;
	position: relative;
}
.ppNav.sidebar-nav li div {
	height: 47px;
}

.dropdown-nav > li:hover > div:before {
	-webkit-transform: scaleY(1);
	-moz-transform: scaleY(1);
	-ms-transform: scaleY(1);
	-o-transform: scaleY(1);
	transform: scaleY(1);
}
.ppNav > li > div:before {
	left: 0;
	right: 0;
	background: #51DF92;
	content: "";
	height: 4px;
	position: absolute;
	bottom: 0;
	transform: scaleY(0);
	transform-origin: 50% 100%;
	transition: transform 250ms ease-in-out;
}
.dropdown-nav > li:first-child {
	padding-left: 40px;
}
.ppNav li div span {
	margin-left: 8px;
	color: #51DF92;
}
.ppNav li div span.glyphicon {
	font-size: 15px;
}
.ppNav li div span.fa {
	font-size: 22px;
}
.ppNav a {
	display:block;
	line-height: 24px;
	color: #fff;
}
.ppNav li,
.ppNav li a {
	text-decoration:none;
	-webkit-transition: none;
	-moz-transition: none;
	transition: none;
}
.dropdown-nav li,
.dropdown-nav li a {
	color: #FFF;
}
.dropdown-nav li li a {
	width: 100%;
}

.ppNav > li span {
	-webkit-transition: transform .25s;
	-moz-transition: transform .25s;
	-ms-transition: transform .25s;
	-o-transition: transform .25s;
	transition: transform .25s;
}
.dropdown-nav > li.open > div span {
	-webkit-transform: rotate(180deg);
	-moz-transform: rotate(180deg);
	-ms-transform: rotate(180deg);
	-o-transform: rotate(180deg);
	transform: rotate(180deg);
}
.ppNav li li span {
    color: rgb(44, 44, 44);
    float: right;
	font-size: 26px;
	line-height: 23px;
	cursor: pointer;
}

.ppNav li li span {
	text-decoration: none;
}
.ppNav li li:hover a {
    text-decoration: underline;
}
.ppNav li li:hover span {
    color: #0C9F50;
    -webkit-transform: translateX(8px);
    -moz-transform: translateX(8px);
    -ms-transform: translateX(8px);
    -o-transform: translateX(8px);
    transform: translateX(8px);
}
.ppNav ul {
	list-style:none;
	margin:0;
	display:none;
	z-index:3;
	background: #0C9F50;
	padding: 32px 120px;
    border-bottom: 4px solid #51DF92;
}
.ppNav.sidebar-nav ul {
	padding: 32px 28px;
}
.ppNav ul li {
	float:none;
	background-color: #fff;
	width:40%;
	min-height: 20px;
	margin: 0 0 12px;
	padding: 12px 24px;
}
.ppNav.sidebar-nav > li > a {
	line-height: 47px;
}
.ppNav li, .ppNav li a, .ppNav > li > div {
	font-size: 18px;
	font-weight: 400;
}
.ppNav li:hover li,
.ppNav li:hover li a {
	color: #0C9F50;
}
.sidebar-nav li div a {
	color: #fff;
}
.sidebar-nav ul li * {
	color: #0C9F50;
}
.dropdown-nav li.open ul {
	display: flex;
	flex-flow: row wrap;
	justify-content: space-between;
	position: absolute;
	left: 0;
	right: 0;

}
.ppNav.dropdown-nav > li > a {
	margin-top: 2em;
}

ul#ppTopNav {
	list-style:none;
	padding:0;
	height: 100%;
	display: flex;
	justify-content: flex-end;
	align-items: center;
	margin: 0 20px 0 0;
}
ul#ppTopNav li {
	position:relative;
	list-style:none;
	/*background-color:#4a4f52;*/
	cursor:pointer;
	font-size:14px;
	font-weight:400;
	text-align:center;
	min-width: 105px;
	margin: 0;
	color:#fff;
	display: flex;
	justify-content: center;
	align-items: center;
	height: 100%;
	padding: 0;
}
ul#ppTopNav li:hover {
	/*background-color:#253747;*/
}
ul#ppTopNav li a {
	text-decoration:none;
	display:block;
	color: white;
}
#openMe.with-image {
	line-height: 100%;
	text-align: center;
}
#myName {
	margin: 0;
	display: flex;
	align-items: center;
}
#myName img {
	vertical-align: middle;
	margin-right: 6px;
}
ul#ppTopNav li:last-child,
ul#ppTopNav li:last-child * {
	/*color:#19a77b;*/
}
ul#ppTopNav li:last-child:hover,
ul#ppTopNav li:last-child:hover * {
	/*color:#127858;*/
}

ul#ppTopNav img.phone {
	height:20px;
	width:20px;
	margin-right:3px;
}
#myAcctWrap {
	position:absolute;
	left:0;
	top:36px;
	width:190px;
	z-index:99999999;
}
ul#myAcct {
	display:none;
	list-style:none;
	padding:0;
	margin:0;
}
ul#myAcct li {
	background-color:#0C9F50;
	list-style:none;
	cursor:pointer;
	font-size:13px;
	padding:10px 20px;
	margin:0;
	border-top: 1px solid rgb(0, 134, 95);
}
ul#myAcct li a {
	display:block;
	color:#FFF;
}
ul#myAcct li:last-child {
	/*-webkit-border-bottom-right-radius: 7px;*/
	/*-webkit-border-bottom-left-radius: 7px;*/
	/*-moz-border-radius-bottomright: 7px;*/
	/*-moz-border-radius-bottomleft: 7px;*/
	/*border-bottom-right-radius: 7px;*/
	/*border-bottom-left-radius: 7px;*/
}
ul#myAcct li:last-child a {
	color:#CCC;
}
ul#myAcct li:hover a {
	color:#19a77b;
}
ul#mn {
	display:none;
	z-index:99;
}
#hamburger {
	position:absolute;
	top:18px;
	right:20px;
	cursor:pointer;
	display:none;
    font-size: 16px;

}
#hamburger span {
    color: #51DF92;
    margin-left: 7px;
    font-size: 18px;
}
.sidebar-nav {
    background: #013B27;
    display: none;
    flex-direction: column;
    padding: 10px 12px;
    z-index: 300;
	overflow: scroll;
	align-self: flex-start;
	top: 57px;
	right: 0;
	left: 0;
	position: absolute;
	max-height: calc(100vh - var(--header-height));
}
.sidebar-nav > li {
    padding-left: 10px;
    margin-bottom: 12px;
    background: #0C9F50;

}
.sidebar-nav .span-wrap {
    margin-left: auto;
    padding: 11px 26px;
    border-left: 3px solid #013B27;
    color: white;
}
.sidebar-nav .open .span-wrap:after,
.sidebar-nav .span-wrap:focus:after,
.sidebar-nav .span-wrap:active:after,
.sidebar-nav .span-wrap:hover:after {
    height: 4px;
}
.sidebar-nav .span-wrap:after {
    content: '';
    position: absolute;
    right: 0;
    bottom: 0;
    width: 100%;
    background: #51DF92;
    height: 0;
    -webkit-transition: all .25s;
    -moz-transition: all .25s;
    -ms-transition: all .25s;
    -o-transition: all .25s;
    transition: all .25s;
}
.sidebar-nav .open .span-wrap span {
    -webkit-transform: rotate(180deg);
    -moz-transform: rotate(180deg);
    -ms-transform: rotate(180deg);
    -o-transform: rotate(180deg);
    transform: rotate(180deg);
}
.sidebar-nav li div {
    justify-content: flex-start;
}

.sidebar-nav .open > ul {
    display: block;
}

.sidebar-nav .open > ul > li {
	width: auto;
}
#ppMain {
	background-color:rgba(255,255,255,0.9);
	/*margin: 0px 40px 20px 40px;*/
	margin: 0;
	min-height:350px;
	/*-webkit-border-radius: 4px;*/
	/*-moz-border-radius: 4px;*/
	/*border-radius: 4px;*/
}
#ppMain.full {
	margin:0;
	-webkit-border-radius:0;
	-moz-border-radius:0;
	border-radius:0;
	min-height:495px;
}
.ppMainPad {
	padding:20px;
}
#ppMain.full .ppMainPad {
	padding:10px;
}
#ppFoot {
	/*background-color:#2b3134;*/
	background-color:rgba(43, 47, 51, 0.5);
	padding:40px;
	color:#cfc9c4;
	text-align:center;
}
#ppFoot,
#ppFoot p {
	font-size:10px;
}

img.emi {
	height:22px;
	width:22px;
	-webkit-border-radius: 5px;
	-moz-border-radius: 5px;
	border-radius: 5px;
}
#fvw {
	display:none !important;
}
#fvw a,
#fvw {
	color:#9fc85d;
}

.alert {
	/*-webkit-border-radius:5px;*/
	/*-moz-border-radius:5px;*/
	/*border-radius:5px;*/
    color: #790000;
    font-family: Tahoma,Geneva,Arial,sans-serif;
    font-size: 14px;
    margin: 10px 0;
    padding: 10px 36px;
    cursor:pointer;
}
.alert.noX {
	cursor:default;
}
.alert.error {
	background:url("/global/images/alerts/error.png") no-repeat scroll 10px 50% #ffecec;
	border:1px solid #f5aca6;
}
.alert.success {
	background:url("/global/images/alerts/success.png") no-repeat scroll 10px 50% #e9ffd9;
	border:1px solid #a6ca8a;
}
.alert.warning {
	background:url("/global/images/alerts/warning.png") no-repeat scroll 10px 50% #fff8c4;
	border:1px solid #f2c779;
}
.alert.notice {
	background:url("/global/images/alerts/notice.png") no-repeat scroll 10px 50% #e3f7fc;
	border:1px solid #8ed9f6;
}
.alert span {
	font-weight:bold;
	text-transform:uppercase;
}
#ppMainPad fieldset {
	/*-webkit-border-radius:5px;*/
	/*-moz-border-radius:5px;*/
	/*border-radius:5px;*/
	border:1px solid #CCC;
	padding:15px;
	margin:15px 0 10px 0;
	background-color:rgba(255,255,255,0.8);
}

#ppMainPad legend {
	font-size:15px;
	color:#19a77b;
}

#myPhotoUploader_mobile {
	display:none;
	text-align:center;
}
.alert {
	padding:10px 36px;
}

.sidebar {
	position:absolute;
	top:var(--header-height);
	left:15px;
	width:190px;
	padding:0 20px 0 20px;
	border-right: 1px solid #eee;
}
.main.viewx {
	margin-left:236px;
}
.main.viewx .col-md-4 {
	width:31%;
}
.box-row {

}
.box-row .col-md-4 {
	padding-left:0;
}

.sidebar .knub {
	display:block;
	position:absolute;
	top:96px;
	left:10px;
	z-index:3;
	opacity:0.7;
}
.sidebar .knub:hover {
	opacity:1.0;
}
.knub .navbar-toggle {
	background-color:#222;
}
.knub .navbar-toggle .icon-bar {
	background-color:#FFF;
}
#sidebarContent {
	padding: 0;
	margin-top: 15px;
	max-height:none;
	overflow-y:visible;
	background-color: #f5f5f5;
}
.toggler-clone {
	visibility:visible;
	width:100%;
}

#pc-btns {
	float:right;
	clear:both;
}

.box.break-pad {

}

.tab-box {
	margin-right:15px;
}

.nav {
	margin-top:0;
}
.nav-sidebar {
	list-style: none outside none;
	padding-left: 0;
	display:block;
}
.nav-sidebar a {
	color: rgb(65, 65, 65);
}
.nav-sidebar > li:not(:first-child) {
	border-top: 2px solid #ededed;
}
.nav-sidebar > li:first-child {
	background: #013B27;
	text-transform: uppercase;
	font-family: 'Montserrat';
	font-weight: 700;
}

.nav-sidebar > li:first-child a {
	color: white;
}
.nav-sidebar li {
	display:block;
	position:relative;
}
.nav-sidebar li:hover {
	text-decoration: underline;
}
.nav-sidebar > li > a {
	display:block;
	padding: 12px;
	position:relative;
}

.main .page-header {
	margin-top: 0;
	padding-top:10px;
}
.placeholders {
	margin-bottom: 30px;
	text-align: center;
}
.placeholders h4 {
	margin-bottom: 0;
}
.placeholder {
	margin-bottom: 20px;
}
.placeholder img {
	display: inline-block;
	border-radius: 50%;
}

.sep {
	clear:both;
	height:20px;
}
.row-pad {
	margin:0;
}
.tab-pad {
	margin:0 20px 0 20px;
}
.no-border {
	padding:20px 0 0 0;
}
.box .no-border h2 {
	font-size:14px;
	padding-left:5px;
	color:#428BCA;
}
.box {
	/*-webkit-border-radius: 10px;*/
	/*-moz-border-radius: 10px;*/
	/*border-radius: 10px;*/
	background-color:#F5F5F5;
	border:1px solid #CCC;
	padding:20px;
	height:100%;
	margin-bottom:15px;
}
.box h2 {
	margin:0 0 7px 0;
	padding:0;
	font-size:16px;
}
table.list {
	border:none;
	border-collapse:collapse;
	width:100%;
	padding:0;
	margin:0;
}
table.list th,
table.list td {
	background-color:#FFF;
	padding:5px 10px;
	text-align:left;
	vertical-align:middle;
	font-size:11px;
	border:1px solid #CCC;
	cursor:default;
}
table.list tr:nth-child(even) th,
table.list tr:nth-child(even) td {
	background-color:#F9F9F9;
}
table.list tr:first-child th,
table.list tr:first-child td {
	border-top:none;
}
table.list tr:last-child th,
table.list tr:last-child td {
	border-bottom:none;
}

table.list.small th,
table.list.small td {
	font-size:9px;
	padding:3px 8px;
}

.box-top,
.box-bottom {
	height:7px;
	background-color:#FFF;
}
.box-top {
	border:1px solid #CCC;
	border-bottom:none;
	/*-webkit-border-top-left-radius: 7px;*/
	/*-webkit-border-top-right-radius: 7px;*/
	/*-moz-border-radius-topleft: 7px;*/
	/*-moz-border-radius-topright: 7px;*/
	/*border-top-left-radius: 7px;*/
	/*border-top-right-radius: 7px;*/
}
.box-bottom {
	border:1px solid #CCC;
	border-top:none;
	/*-webkit-border-bottom-right-radius: 7px;*/
	/*-webkit-border-bottom-left-radius: 7px;*/
	/*-moz-border-radius-bottomright: 7px;*/
	/*-moz-border-radius-bottomleft: 7px;*/
	/*border-bottom-right-radius: 7px;*/
	/*border-bottom-left-radius: 7px;*/
}

.pagination.no-pad {
	margin-top:5px;
}
.row-stat {
	font-size:12px;
}
.right-toolbar {
	float:right;
}

table.table-hover tbody tr td {
	cursor:pointer;
}
table.table-striped tbody tr:nth-child(even) td:nth-child(even) {
	/*	background-color:#F9F9F9;*/
}
#map-container {
	position:relative;
}
#map-canvas {
	height:600px;
	width:100%;
	margin:15px 0 0 0;
	padding:0;
}
#map-panel {
	position:absolute;
	top:5px;
	left:40px;
	z-index:99;
}

a.nolink {
	text-decoration:none;
	color:#000;
}
#ui-search {
	position:relative;
}
#search-spinner {
	top:9px;
	right:5px;
}
input.highlight {
	color:#FF0000;
}

.sortHolder {
	position:relative;
}
span.sort {
	position:absolute;
	top:-5px;
	left:-6px;
	cursor:move;
	background:url('/cc/img/sort.png') top left no-repeat;
	height:26px;
	width:40px;
	display:none;
}
th:hover span.sort {
	display:inline-block;
}
span.gray {
	color:#AAA;
	font-size:11px;
}
th.nowrap {
	white-space:nowrap;
}

.table > thead > tr > th {
	vertical-align:top;
	white-space:nowrap;
}
.table > thead > tr > th small {
	display:block;
	color:#4B6270;
	font-weight:normal;
}

.tblStack_cont.stack_location .tblStack_cont_scroll {
	width:800px;
	height:400px;
}
.tblStack_cont.stack_location .tblStack_cont_scroll iframe.tblStackiFrame {
	height:355px;
}
.ui-helper-hidden-accessible {
	top:-45px;
	right:155px;
}
#search-spinner {
	right:65px;
}
#sideNav #stackTable,
#sideNav #customizeTable {
	background:none;
}
#sideNav h1.chkList {
	background:none;
	color:#777;
	text-align:left;
	padding-left:15px;
}
#sideNav {
	float:left;
	width:20%;
}
#tableUI {
	float:left;
	width:100%;
}
#l1Nav {
	float:right;
}
.csm-row {
	margin:0 0 20px 0;
}
.ui-helper-hidden-accessible {
	top:-22px;
	right:150px;
}
#viewNavToggler {
	display:none;
	padding:5px 10px;
	cursor:pointer;
	color:#9fc85d;
	font-size:12px;
}
#viewNavToggler:hover {
	color:#19a77b;
}
.nav .slug {
	 display: block;
    padding: 10px 15px;
    position: relative;
	font-weight:bold;
}
#toggleSideBarButton {
	float:right;
}
#contWidthSidebar.sideBarHidden .sidebar {
	display:none;
}
#contWidthSidebar.sideBarHidden .main.viewx {
	margin-left:0;
}

#lang-select {
	list-style: none;
	margin: 0;
	padding: 0;
	min-width: 130px;
	z-index: 98;
	position: relative;
}

#lang-select #lang-menu {
	position: absolute;
	background-color: #0C9F50;
	width: 100%;
}
#lang-select #lang-menu { transition: transform .5s; transform-origin: top; }
#lang-select:not(:hover) #lang-menu { transform: scaleY(0); }

#lang-select:not(:hover){
	height: 100% !important;
}

#lang-select .lang-name {
	cursor: pointer;
	padding: 7px;
}
#lang-select .lang-name:hover { background: rgb(255 255 255 / 15%); }
#lang-select .lang-name {
	padding-left: 7px;
	color: white;
	opacity: 0.7;
}

#lang-select .lang-name.selected {
	opacity: 1;
}

.two_col {
  float: left;
  margin: 0;
  overflow: hidden;
  min-height: 100%;
  width: 640px;
}
#footer {
	background: #2c2c2c;
}
#footer .logo-wrapper {
	margin-bottom: 32px;
}

.footer-nav-link-wrap + .footer-nav-link-wrap {
	margin-top: 12px;
}
#footer .pp-foot-nav-col a {
	-webkit-transition: color 250ms ease-in-out;
	-moz-transition: color 250ms ease-in-out;
	-ms-transition: color 250ms ease-in-out;
	-o-transition: color 250ms ease-in-out;
	transition: color 250ms ease-in-out;
}

.truste-consent-track-class {
	color: rgb(51, 51, 51);
	font-family: "Roboto", serif;
	line-height: 27px;
}

#truste-consent-text h1 {
	text-transform: uppercase;
	color: #AE132A;
	font-family: "Roboto", sans-serif !important;
	font-weight: bold;
	margin-top: 0px !important;
	margin-bottom: 10px !important;
	font-size: 30px !important;
	line-height: 1.1;
}

#truste-consent-button, #truste-show-consent{
	background-color: #AE132A;
}

#truste-consent-button:hover,#truste-show-consent:hover {
	background-color: black;
}

#truste-cookie-button, #truste-privacy-button {
	color: #AE132A;
	font-family: "Georgia", serif !important;
	font-size: small;
	font-weight: 400;
}

#truste-cookie-button:hover, #truste-privacy-button:hover {
	color: black !important;
}

#footer .pp-foot-nav-col a:hover {
	color: #51DF92;
	text-decoration: underline;
}

.footer__social-link:hover, .footer__social-link:focus {
	outline: none;
}

.footer__social-link:not(:last-child) {
	margin-right: 16px;
}

.footer__social-link {
	border: 2px solid #51DF92;
	border-radius: 50%;
	position: relative;
	align-items: center;
	display: flex;
	flex: 0 0 auto;
	height: 48px;
	justify-content: center;
	width: 48px;
}

.footer__social-icon {
	fill: white;
	-webkit-transition: color .25s;
	-moz-transition: color .25s;
	-ms-transition: color .25s;
	-o-transition: color .25s;
	transition: color .25s;
	z-index: 1;
}

.footer__social-link:hover .footer__social-icon {
	fill: black;
}

.footer__social-link:hover:before, .footer__social-link:focus:before {
	transform: scale(1);
}

.footer__social-link:before {
	background-color: #51DF92;
	bottom: -1px;
	border-radius: 50%;
	content: "";
	left: -1px;
	position: absolute;
	right: -1px;
	top: -1px;
	transform: scale(0);
	-webkit-transition: transform 250ms ease-in-out;
	-moz-transition: transform 250ms ease-in-out;
	-ms-transition: transform 250ms ease-in-out;
	-o-transition: transform 250ms ease-in-out;
	transition: transform 250ms ease-in-out;
}

.footer__social-link:hover:after, .footer__social-link:focus:after {
	animation: ghost-away 250ms 250ms 1 ease-in-out;
}

.footer__social-link:after {
	bottom: -2px;
	border: 2px solid #51DF92;
	border-radius: 50%;
	content: "";
	left: -2px;
	opacity: 0;
	position: absolute;
	right: -2px;
	top: -2px;
}

@keyframes ghost-away {
	from {
		opacity: 1;
		-webkit-transform: scale(1);
		-moz-transform: scale(1);
		-ms-transform: scale(1);
		-o-transform: scale(1);
		transform: scale(1);
	}
	to {
		opacity: 0;
		-webkit-transform: scale(2);
		-moz-transform: scale(2);
		-ms-transform: scale(2);
		-o-transform: scale(2);
		transform: scale(2);
	}
}

#footer_tagline_container .cell {
  padding-right: 200px;
}
.two_col .cell {
  padding-right: 30px;
  padding-left: 35px;
}
#footer p.tagline {
  font-size: 16px;
}
#footer .contact_buttons {
  margin: 25px 0;
}
#footer .contact_buttons a {
  text-decoration: none;
}
#footer .contact_buttons img {
  margin-right: 9px;
  float: left;
}
@media (max-width:1100px) {
	.main.viewx .col-md-4 {
		width:45%;
	}
}
@media (max-width:1000px) {
	.main.viewx .col-md-4 {
		width:98%;
		float:none;
	}
}
@media (max-width:900px) {
	img.logo {
		margin-top:20px;
		z-index:99;
		position:absolute;
	}
	#ppMain {
		/*margin:0 20px;*/
	}
	#ppFoot {
		padding:10px 0;
	}
}
@media (max-width: 768px) {
	.ui-helper-hidden-accessible {
		display:none;
	}
	#tableUI {
		float:none;
		width:auto;
	}
	#sideNav {
		float:none;
		width:auto;
	}
	.main .page-header {
		clear:both;
		font-size:20px;
	}
	.about{
		white-space: nowrap;
	}
}
@media (max-width:762px) {
	.sidebar {
		top:94px;
	}
	h1 {
		font-size:24px;
		margin-bottom:5px;
	}
	img.logo {
		margin-top:10px;
	}

	#ppTop {
		height:57px;
	}
	#hamburger {
		display:block;
	}
	#mnWrap.open {
		display: flex;
	}
    .dropdown-nav {
        display: none;
    }
	html { --header-height: 93px; }
	ul#ppTopNav {
		width:auto;
	}
	ul#ppTopNav li {
		float:left;
		margin-left:1px;
	}
	ul#ppTopNav li:first-child {
		display:none;
	}
	#myAcctWrap {
		top:36px;
		width:150px;
		right: 19px;
	}
	#openMe {
		width:31px;
	}
	#lang-select {
		width: auto;
	}
}
@media (max-width:680px) {
	#toggleSideBarButton {
		display:none;
	}
	#contWidthSidebar.sideBarHidden .sidebar {
		display:block;
	}
	#viewNavToggler {
		display:block;
	}
	.sidebar {
		display:block;
		top:-10px;
		position:relative;
		padding:0;
		border:0;
		background-color:#FFF;
		margin-bottom:0;
		width:90%;
		z-index:2;
	}
	.nav-sidebar {
		/*margin-right: -10px; !* 20px padding + 1px border *!*/
		/*margin-left: -10px;*/
	}
	#sidebarContent {
		padding:0;
		display:none;
	}
	#sidebarContent.showit {
		display:block;
	}
	#sidebarContent ul {
		background-color:#FFF;
		margin-bottom:0;
	}
	.main.viewx {
		margin-left:0;
	}
}
@media (max-width:570px) {
	#myPhotoUploader_mobile {
		display:block;
	}
	#mypu {
		display:none;
		position:absolute;
		left:-5000px;
	}
	#finddealer {
		display:none;
	}
}
@media (max-width:505px) {
	h1 {
		font-size:20px;
	}
	fieldset {

	}
	table {
		width:100%;
	}
	#fvw {
		display:block;
	}
	img.logo {
		height:auto;
		width:180px;
		margin-top:17px;
	}
	#ppMain {
		margin:0;
		margin-bottom: 20px;
		-webkit-border-radius:0;
		-moz-border-radius:0;
		border-radius:0;
	}
	#ppFoot {
		padding:19px 0;
	}
	#ppFoot p {
		margin:0;
		padding:5px 0;
	}
	#myName img.emi {
		display:none;
	}
}
@media (max-width:400px) {
	#lang-select {
		display:none;
	}
}
@media(max-width: 430px) {
	.ppNav li div, .ppNav li, .ppNav li a {
		font-size: 13px;
		position: relative;
	}
	.ppNav li li span {
		font-size: 18px;
	}
}
@media (max-width:388px) {
	img.logo {
		width: 120px;
	}
	ul#ppTopNav li {
		background: none !important;
	}
	.ppNav ul li {
		padding-right: 36px;
	}

	.ppNav li li span {
		position: absolute;
		right: -20px;
	}
}

.button {
	line-height: 1;
	padding: 12px 15px;
	width: auto;
	min-width: 155px;
	margin: 20px 0 0;
	background-color: #3a4044;
	color: #fff;
	font-weight: lighter;
	font-size: 21px;
	text-decoration: none;
	text-align: left;
	display: inline-block;
	border: 0 none;
	cursor: pointer;
	/*-moz-border-radius: 3px;*/
	/*-webkit-border-radius: 3px;*/
	/*-khtml-border-radius: 3px;*/
	/*border-radius: 3px;*/
	font-weight: 400;
	font-style: normal;
	box-sizing: content-box;
}
.button.style-1 {
	background-color: #ff971b
}
.button.style-2 {
	background-color: #19a77b
}
.button.style-3 {
	background-color: #9fc85d
}
.button.style-4 {
	background-color: #2a728c
}
.button.style-5,.button.style-hot-callout {
	background-color: #5d3282;
}
.button.style-5a,.button.style-warm-callout {
	background-color: #8562a7;
}
.button.style-6,.button.style-gray-background {
	background-color: #cfc9c4;
	color: #000
}
.button.style-7 {
	background-color: #4c5155;
}
.button.style-8 {
	background-color: rgb(220, 58, 58);
}
.button:hover,.button:active {
	background-color: #615ea6;
	color: #fff
}
.button.small,.button.smaller {
	font-size: 1em;
	padding: 8px;
	margin: 0;
	width: auto;
	min-width: 0
}
.button.smaller {
	font-size: 14px
}

button.background-slide {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	background: transparent;
	border: none;
	display: inline-block;
	font-family: inherit;
	line-height: 1;
	margin: 0;
	padding: 0;
}
button.background-slide.lg {
	font-size: 34px;
	padding: 14px 28px;
}
button.background-slide.md {
	font-size: 26px;
	padding: 6px 12px;
}
button.background-slide:focus, button.background-slide:active {
	outline: none;
}
button.background-slide {
	background-color: #2c2c2c;
	border: 2px solid #2c2c2c;
	color: rgba(255, 255, 255, 0.9);
	display: inline-block;
	font-family: 'Roboto', sans-serif;
	font-size: 13px;
	font-weight: bold;
	line-height: 28px;
	margin: 4px;
	padding: 0 12px;
	position: relative;
	text-align: center;
	text-decoration: none;
	transition: all 250ms ease-in-out;
	z-index: 1;
}
button.background-slide:hover {
	color: #181D1B;
}
button.background-slide::before {
	content: '';
	position: absolute;
	bottom: 0;
	right: 0;
	top: 0;
	left: 0;
	transition: all 250ms ease-in-out;
	background-color: rgba(255, 255, 255, 0.9);
	transform: scaleX(0);
	transform-origin: left;
	z-index: -1;
}
button.background-slide:hover::before {
	transform: scale(1);
}
button.background-slide.tblbuilder {
	background-color: transparent;
	color: #f9b103;
	border: none;
	font-weight: 500;
}
button.background-slide.tblbuilder::before {
	background-color: #f8f8f8;
	transform-origin: center;
	transform: scale(0);
}

button.background-slide.tblbuilder:hover::before {
	transform: scale(1);
}
button.background-slide.green {
	background-color: #013B27;
	border: 2px solid #51DF92;
	color: #fff;
}
button.background-slide.green::before {
	background-color: #51DF92;
}
button.background-slide.green:hover {
	color: #2c2c2c;
}
button.background-slide.blue {
	background-color: rgb(144, 179, 248);
	border: 2px solid #3875D7;
	color: #313F57;
}

button.background-slide.blue::before {
	background-color: #3875D7;
}
button.background-slide.blue:hover {
	color: #fff;
}

button.background-slide.orange {
	background-color: rgb(172, 98, 14);
	border: 2px solid rgb(246, 145, 30);
	color: #fff;
}
button.background-slide.orange::before {
	background-color: rgb(246, 145, 30);
}
button.background-slide.orange:hover {
	color: rgb(52, 52, 52);
}

button.background-slide.red {
	background-color: rgb(175, 29, 29);
	border: 2px solid rgb(239, 58, 58);
	color: #fff;
}

button.background-slide.red::before {
	background-color: rgb(239, 58, 58)
}

button.background-slide.red:hover {
	color: rgb(68, 47, 47);
}

button.background-slide.full {
	width: 100%;
}
button.background-slide.full {
	padding: 10px 24px;
	font-size: 20px;
}

div.footer, #ppFoot {
	padding: 0;
}
#footer {
	padding: 80px 27px;
	color:#FFF;
	text-align:left;
	height:auto;
	overflow:visible;
	position: relative;
}
#footer .external-link-icon {
	display: block;
	height: 16px;
	stroke: currentColor;
	width: 16px;
}
#footer .footer-link__external-icon {
	color: #51DF92;
	display: inline-block;
	margin-left: 8px;
}

img.foot-logo {
	height: 22px;
	width: 182px;
}

.pp-foot-nav {
	padding: 0 20px;
	display: flex;
	justify-content: space-between;
}

.foot-icons {
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 20px 0 23px 0;
}

.foot-icons img {
	padding: 0 1px 0 0;
}

.fvpFoot a:hover {
	color: #127858;
}

.pp-foot-nav-col a {
	padding: 0 0 2px 0;
	display: inline-block;
}

#footer .precision-text {
	height: 34px;
	width: 252px;
}
@media (max-width: 800px) {
	.pp-foot-nav {
		display: block;
	}

	#footer {
		padding-bottom: 120px;
	}
}
#cookie-banner {
	position: fixed;
	left: 0;
	right: 0;
	bottom: 0;
	color: white;
	background-color: #2c2c2c;
	padding: 1.5rem 4rem;
	width: 100%;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	z-index: 12999;
	font-size: 17px;
}
.cookie-banner-text p {
	font-size: 20px;
	font-weight: 400;
}
.cookie-banner-text a {
	text-decoration: underline;
	color: #51DF92;
}

.fvpFoot {
	max-width: 1320px;
	margin: 0 auto;
}
.fvpFootA,
.fvpFootB,
.fvpFootC {
	float:left;
	box-sizing: border-box;
}
.fvpFootA {
	width: 640px;
	padding-left: 35px;
	padding-right: 200px;
}
.fvpFootB {
	width: 320px;
	padding-right: 30px;
	padding-left: 20px;
}
.fvpFootC {
	width: 320px;
	padding-right: 30px;
	padding-left: 20px;
	text-align: right;
}#logo-link {
	line-height: 24px;
	display: block;
}
.fvpP {
	font-size:15px;
	font-weight:400;
	font-style:normal;
	color:#cfc9c4;
	line-height:22.5px;
}
ul.fvpFootSocial {
	list-style:none;
	padding:0;
	margin:25px 0 0 0;
}
ul.fvpFootSocial li {
	list-style:none;
	padding:0;
	float:left;
	margin:0 9px 0 0;
}
ul.fvpFootSocial a {
	font-size: 0;
	display: block;
}
.fvpFoot a {
	font-size: 16px;
	font-weight: 500;
	color: #ffffff;
	text-decoration: none;
}
.fvpFootTerms {
	margin:2px 0 22px 0;
	font-size:12px;
	font-weight:400;
	font-style:normal;
	line-height:18px;
	color: #fff;
	border-top:1px solid #FFF;
	padding:4px 20px 0 20px;
	position: absolute;
	left: 10px;
	right: 10px;
	bottom: 12px;
}
.fvpFootTerms a {
	color: #cfc9c4;
	text-decoration:none;
	display:inline-block;
	padding:0 13px;
}
.fvpFootNav {
	float: right;
}
div.fvpH {
	color:#FFF;
	font-size: 16px;
	font-weight: 500;
	line-height: 1;
	margin-bottom: 12px;
}
.fvpFootNav ul {
	list-style:none;
	padding:0;
	margin: 0 0 12px;
}
.fvpFootNav ul:last-child {
	margin-bottom: 0;
}
.fvpFootNav li {
	list-style:none;
	padding:0;
	margin:0;
	color:rgba(255, 255, 255, 0.6);
	font-size:16px;
	font-weight:400;
	font-style:normal;
	line-height:24px;
}
.fvpFootNav li a {
	color:rgba(255, 255, 255, 0.6);
	text-decoration:none;
}
.fvpSpc {
	margin-top:32px;
}
.fvpBtnGroup {
	margin-top: -16px;
}




.tl_keys {
	background-color:#EEE;
	padding:20px;
}
.tl_keys ul {
	list-style:none;
	padding:0;
	margin:0;
}
.tl_keys li {
	list-style:none;
	padding:5px 10px;
	margin:0 10px 10px 0;
	float:left;
	text-align:center;
	border:1px solid #DDD;
	/*-webkit-border-radius: 5px;*/
	/*-moz-border-radius: 5px;*/
	/*border-radius: 5px;*/
	background-color:#FFF;
	cursor:pointer;
}
.tl_keys li:hover {
	background-color:#3875D7;
	color:#FFF;
}

ul.list {
	list-style:none;
	padding:0;
	margin:0;
}
ul.list li {
	list-style:none;
	padding:2px 5px;
	margin:2px 0;
	border:1px solid #CCC;
	background-color:#FFF;
	font-size:11px;
	cursor:pointer;
	color:#000;
}
ul.list li:hover {
	color:#006600;
	border:1px solid #006600;
}

#ppMainPad button img {
	height:14px;
	width:14px;
	vertical-align:sub;
}


#user_id_search {
	display: none;
	width: 100%;
	height: 180px;
	overflow-x: hidden;
	overflow-y: auto;
	margin-top: 10px;
	padding: 5px;
	border: 1px solid #ccc;
	/*border-radius: 4px;*/
	background-color: #fff;
	cursor: pointer;
}
#user_id_search > li {
	list-style: none;
	padding: 2px 5px 2px 5px;
	margin: 0;
	color: #000;
	cursor: pointer;
}
#user_id_search > li.alt {
	background-color: #eee;
}
#user_id_search > li.close_uid_search {
	background-color: #ccc;
	font-size: 10px;
	font-weight: bold;
	text-align: right;
}
#user_id_search > li:hover {
	background-color: #2b5dce;
	color: #fff;
}
#user_id_search > li.close_uid_search:hover {
	background-color: #ccc !important;
	color: #000 !important;
}
#user_id_search > li.loading_uids:hover {
	background-color: #fff !important;
	color: #000 !important;
}

/* Absolute Center Spinner */
.loading {
  position: fixed;
  z-index: 999;
  height: 2em;
  width: 2em;
  overflow: show;
  margin: auto;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
  display:none;
}

/* Transparent Overlay */
.loading:before {
  content: '';
  display: block;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0,0,0,0.3);
}

/* :not(:required) hides these rules from IE9 and below */
.loading:not(:required) {
  /* hide "loading..." text */
  font: 0/0 a;
  color: transparent;
  text-shadow: none;
  background-color: transparent;
  border: 0;
}

.loading:not(:required):after {
  content: '';
  display: block;
  font-size: 10px;
  width: 1em;
  height: 1em;
  margin-top: -0.5em;
  -webkit-animation: spinner 1500ms infinite linear;
  -moz-animation: spinner 1500ms infinite linear;
  -ms-animation: spinner 1500ms infinite linear;
  -o-animation: spinner 1500ms infinite linear;
  animation: spinner 1500ms infinite linear;
  border-radius: 0.5em;
  -webkit-box-shadow: rgba(255,255,255, 0.75) 1.5em 0 0 0, rgba(255,255,255, 0.75) 1.1em 1.1em 0 0, rgba(255,255,255, 0.75) 0 1.5em 0 0, rgba(255,255,255, 0.75) -1.1em 1.1em 0 0, rgba(255,255,255, 0.5) -1.5em 0 0 0, rgba(255,255,255, 0.5) -1.1em -1.1em 0 0, rgba(255,255,255, 0.75) 0 -1.5em 0 0, rgba(255,255,255, 0.75) 1.1em -1.1em 0 0;
  box-shadow: rgba(255,255,255, 0.75) 1.5em 0 0 0, rgba(255,255,255, 0.75) 1.1em 1.1em 0 0, rgba(255,255,255, 0.75) 0 1.5em 0 0, rgba(255,255,255, 0.75) -1.1em 1.1em 0 0, rgba(255,255,255, 0.75) -1.5em 0 0 0, rgba(255,255,255, 0.75) -1.1em -1.1em 0 0, rgba(255,255,255, 0.75) 0 -1.5em 0 0, rgba(255,255,255, 0.75) 1.1em -1.1em 0 0;
}

/* Animation */

@-webkit-keyframes spinner {
  0% {
    -webkit-transform: rotate(0deg);
    -moz-transform: rotate(0deg);
    -ms-transform: rotate(0deg);
    -o-transform: rotate(0deg);
    transform: rotate(0deg);
  }
  100% {
    -webkit-transform: rotate(360deg);
    -moz-transform: rotate(360deg);
    -ms-transform: rotate(360deg);
    -o-transform: rotate(360deg);
    transform: rotate(360deg);
  }
}
@-moz-keyframes spinner {
  0% {
    -webkit-transform: rotate(0deg);
    -moz-transform: rotate(0deg);
    -ms-transform: rotate(0deg);
    -o-transform: rotate(0deg);
    transform: rotate(0deg);
  }
  100% {
    -webkit-transform: rotate(360deg);
    -moz-transform: rotate(360deg);
    -ms-transform: rotate(360deg);
    -o-transform: rotate(360deg);
    transform: rotate(360deg);
  }
}
@-o-keyframes spinner {
  0% {
    -webkit-transform: rotate(0deg);
    -moz-transform: rotate(0deg);
    -ms-transform: rotate(0deg);
    -o-transform: rotate(0deg);
    transform: rotate(0deg);
  }
  100% {
    -webkit-transform: rotate(360deg);
    -moz-transform: rotate(360deg);
    -ms-transform: rotate(360deg);
    -o-transform: rotate(360deg);
    transform: rotate(360deg);
  }
}
@keyframes spinner {
  0% {
    -webkit-transform: rotate(0deg);
    -moz-transform: rotate(0deg);
    -ms-transform: rotate(0deg);
    -o-transform: rotate(0deg);
    transform: rotate(0deg);
  }
  100% {
    -webkit-transform: rotate(360deg);
    -moz-transform: rotate(360deg);
    -ms-transform: rotate(360deg);
    -o-transform: rotate(360deg);
    transform: rotate(360deg);
  }
}

._hidden {
	display:none;
}
.btn-float-right {
	float:right;
}
.btn-float-right button {
	margin-left:5px;
}
@media (max-width:800px) {
	.btn-float-right {
		float:none;
	}
}
.pill-grp {
	margin-top:25px;
	padding:20px;
	box-sizing:border-box;
	background-color:#FFF;
	/*-webkit-border-radius: 3px;*/
	/*-moz-border-radius: 3px;*/
	/*border-radius: 3px;*/
}
.btn-input-grp {
	max-width:600px;
	margin:0 auto;
}
input.btn-input-group-form-input,
button.btn-input-group-form-btn {
	float:left;
	border:1px solid #CCC;
	-webkit-border-radius:0;
	-moz-border-radius:0;
	border-radius:0;
	box-sizing:border-box;
	margin:0;
	font-size:22px;
	line-height:19px;
}
input.btn-input-group-form-input {
	width:70%;
	/*-webkit-border-top-left-radius: 3px;*/
	/*-webkit-border-bottom-left-radius: 3px;*/
	/*-moz-border-radius-topleft: 3px;*/
	/*-moz-border-radius-bottomleft: 3px;*/
	/*border-top-left-radius: 3px;*/
	/*border-bottom-left-radius: 3px;*/
	padding:15px 15px 14px 15px;
}
button.btn-input-group-form-btn {
	width:30%;
	/*-webkit-border-top-right-radius: 3px;*/
	/*-webkit-border-bottom-right-radius: 3px;*/
	/*-moz-border-radius-topright: 3px;*/
	/*-moz-border-radius-bottomright: 3px;*/
	/*border-top-right-radius: 3px;*/
	/*border-bottom-right-radius: 3px;*/
	border:1px solid #19a77b;
	border-left:none;
	background-color:#19a77b;
	color:#FFF;
	padding-left:0;
	padding-right:0;
	padding:20px;
}
button.btn-input-group-form-btn:hover {
	background-color:#127858;
	border:1px solid #127858;
	border-left:none;
}

@media (max-width:600px) {
	body.modal .mPad ._rspHide {
		display:none;
	}
	body.modal .mPad #DFQuery {
		width:75%;
		margin-bottom:4px;
		display:inline-block;
	}
	body.modal .mPad .df_sbox {
		float:none;
	}
	body.modal .mPad .pagination {
		clear:both;
		line-height:20px;
	}
}

select.input-lg {
	/* i have no idea why this override is needed*/
	line-height: initial !important;
}
select.input-sm {
	line-height: initial !important;
}

.d-flex {
	display: flex !important;
}
.flex-center {
	justify-content: center;
	align-items: center;
}
.align-items-start {
	align-items: flex-start;
}
.align-items-end {
	align-items: flex-end;
}
.align-items-center {
	align-items: center;
}
.justify-content-center {
	justify-content: center;
}
.justify-content-around {
	justify-content: space-around;
}
.justify-content-event {
	justify-content: space-evenly;
}
.justify-content-between {
	justify-content: space-between;
}