@font-face {
   font-family: 'trilogyicons';
   src:    url('https://s3.amazonaws.com/icomoon.io/31537/Trilogy/Trilogy-Icons.eot?qu7a6n');     src:    url('https://s3.amazonaws.com/icomoon.io/31537/Trilogy/Trilogy-Icons.eot?qu7a6n#iefix') format('embedded-opentype'),         url('https://s3.amazonaws.com/icomoon.io/31537/Trilogy/Trilogy-Icons.woff2?qu7a6n') format('woff2'),         url('https://s3.amazonaws.com/icomoon.io/31537/Trilogy/Trilogy-Icons.ttf?qu7a6n') format('truetype'),         url('https://s3.amazonaws.com/icomoon.io/31537/Trilogy/Trilogy-Icons.woff?qu7a6n') format('woff'),         url('https://s3.amazonaws.com/icomoon.io/31537/Trilogy/Trilogy-Icons.svg?qu7a6n#Trilogy-Icons') format('svg');}

.icons {
  font-family: 'trilogyicons';
  content: attr(data-icon);
  speak: none;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale; }
  

@media only screen and (min-width: 800px) {
   body#interior {
       margin-top: 145px;
   }
}
  
/* ----------- Header ----------- */
  
header { 
  width: 100%;
   text-align: center;
	position: fixed;
   top: 0;
   left: 0;
	z-index: 10000; 
  font-size: 14px;
  -moz-transition:    all 0.3s ease-in-out;
  -o-transition:      all 0.3s ease-in-out;
  -webkit-transition: all 0.3s ease-in-out;
  transition:         all 0.3s ease-in-out;     
} 

header.fixed { 
  background: #fff;
  position: fixed;
  top: 0;
  left: 0;
  height: 80px;
} 
header .top {
  display: block; 
  position: relative;
  padding: .2em;
  z-index: 1;
}
header .logo {
  width: 9em;
  display: block;
  padding: .6em; 
  -moz-transition:    all .5s cubic-bezier(0.75, -0.25, 0.25, 0.75);
  -o-transition:      all .5s cubic-bezier(0.75, -0.25, 0.25, 0.75);
  -webkit-transition: all .5s cubic-bezier(0.75, -0.25, 0.25, 0.75);
  transition:         all .5s cubic-bezier(0.75, -0.25, 0.25, 0.75); 
}	
header .logo:hover {
  -moz-transform:    scale(1.03);
  -ms-transform:     scale(1.03);
  -webkit-transform: scale(1.03);
  transform:         scale(1.03);
}
header .logo img,
header .logo svg { 
  width: 100%;
  display: block;
  height: 55px;
  -moz-transition:    all 0.3s ease-in-out;
  -o-transition:      all 0.3s ease-in-out;
  -webkit-transition: all 0.3s ease-in-out;
  transition:         all 0.3s ease-in-out; 
}
header .logo .mark {
  fill: #0033A0; 
}
header .logo .text {
  fill: #00953A; 
}
header.fixed .logo img, header.fixed .logo svg {
   height: 50px;
}

@media only screen and (min-width: 740px) {  
  header .logo {
    width: 9em;
  }  
}

@media only screen and (min-width: 1360px) {
   body {
      background: #e1e1e1;
   }
  .wrap { 
     width: 1360px; 
  }
  #hero {
     margin-top: 145px;
  }
   body#interior #hero { margin-top: 0; }
  header .top {
    max-width: 1360px;
    position: relative;
  }  
  header .top {
    display: block;
    padding: .6em;
  }
  header.fixed .top {
    display: block;
  }     
  .now-index header .top {
    padding: .8em;
  }  
  .now-index header .logo {
    width: 19em;
  }  
  header .logo, header.fixed .logo {
    width: 13em;
  }    
}  

/* --- Menu Trigger --- */

header .utility {
  display: block;
  -moz-transform:    translateY(-50%);
  -ms-transform:     translateY(-50%);
  -webkit-transform: translateY(-50%);
  transform:         translateY(-50%);     
}

header .utility.left {
  position: absolute;
}

@media only screen and (max-width: 1000px)  {
header .utility.left {
  top: 50%;
  left: 25%;
} 
header .utility.right,
header .search-trigger {
  display: none;
}
}

@media only screen and (min-width: 1000px)  {
  header .utility {
    display: table;
    position: absolute;
    top: 50%;
    width: auto;  
    font-size: 16px;    
    -moz-transition:    all 0.3s ease-in-out;
    -o-transition:      all 0.3s ease-in-out;
    -webkit-transition: all 0.3s ease-in-out;
    transition:         all 0.3s ease-in-out;       
  }  
  header.fixed .utility  {
    top: 50%;  
  }  
  
  header .left {
    left: .25em;
    text-align: left;      
  }
  header .right {
    display: inline-block;
    right: .25em;
    text-align: right;
  }  
  
  header .utility strong {
    text-transform: uppercase;
    color: #bbb;
    display: inline-block;
    vertical-align: middle;
    font-weight: 400;
  }
  header.fixed .utility strong {
    color: #7a7a7a;
  }
  header .now-connect .icons { 
    display: inline-block;
    vertical-align: middle;    
    padding-left: 1em;
  }
  header .now-connect a { 
    color: #bbb;
    padding: 0 .2em;
    font-size: 20px;
  	display: inline-block;
    vertical-align: middle;
  	-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); 
  } 
  header.fixed .now-connect a {
    color: #7a7a7a;
  }

  header .now-connect a:first-child { 
    font-size: 1.35em;
  }  
  header .now-connect a:hover { 
  	-moz-transform:    scale(1.1);
  	-ms-transform:     scale(1.1);
  	-webkit-transform: scale(1.1);
  	transform:         scale(1.1); 
  	color: #008cff;
  }
}

/* --- Tags --- */

.tags {
  width: 100%;
  display: none;
  position: absolute;
  bottom: 0;
  left: 50%;  
  -moz-transform:    translateX(-50%);
  -ms-transform:     translateX(-50%);
  -webkit-transform: translateX(-50%);
  transform:         translateX(-50%);  
  -moz-transition:    all 0.3s ease-in-out;
  -o-transition:      all 0.3s ease-in-out;
  -webkit-transition: all 0.3s ease-in-out;
  transition:         all 0.3s ease-in-out;    
}

   .tags:before {
      content: " ";
      position: absolute;
      z-index: -1;
      top: 0;
      left: 25%;
      width: 50%;
      border-top: 2px solid #ddd;   
   }
  .tags {
    display: block;
    max-width: 1400px;
  }
  header.fixed .tags { 
    opacity: 0;
    visibility: hidden;
  } 
  .tags ul {
    list-style: none;
  }
  .tags li {
    display: inline-block;
  }
  .tags li a {
    text-transform: none;
    display: block;
    font-size: 1em;
    font-weight: 400;
    color: #333;
    padding: 1em 1.25em;
    -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);   
  }
  .tags li a:hover {
    color: white;
    background: #333;
  }
@media only screen and (min-width: 1100px)  {
   .tags li a { font-size: 1.25em; }
}


/* Submenu
------------------------------------ */

.tags ol { 
    border-top: 3px solid #fdba31;
    background: white;
    list-style: none;
    width: 200px;
    margin: 0;
    padding: 3px;
    display: none;
    position: absolute; 
    left: initial;
    top: initial;
    z-index: 1;
    -moz-box-shadow:    0 1px 2px rgba(0,0,0,.15);
    -webkit-box-shadow: 0 1px 2px rgba(0,0,0,.15);
    box-shadow:         0 1px 2px rgba(0,0,0,.15); 
    -webkit-transition: all .35s ease-in-out;
    -moz-transition:    all .35s ease-in-out;
    -o-transition:      all .35s ease-in-out;
    -ms-transition:     all .35s ease-in-out;
    transition:         all .35s ease-in-out; 
    }
    
.tags .split ol { 
    width: 370px;  
    left: initial; 
    }   
  
.tags .nav-members ol { left: -59px; }
        
    @media (min-width : 1200px) { 
        .tags ol { left: initial; }
        .tags .split ol { left: initial; } 
        .tags .nav-join ol { left: -30px; }
        .tags .nav-districts ol { width: 257px; }
        .tags .nav-members ol { left: -51px; }
        } 

.tags li:hover ol,
.tags li.over ol { display: block; }

.tags ol li {
    background-image: none;
    padding: 2px !important;
    text-align: left; 
    float: none;
    display: block; 
    }

.tags ol li a {
    color: #004881; 
    width: auto;
    height: auto;
    padding: 7px 6px !important;
    display: block;
    float: none;   
    font-size: 13px;
    line-height: 1.1;
    text-indent: 0;
    text-transform: none;
    -webkit-transition: all .35s ease-in-out;
    -moz-transition:    all .35s ease-in-out;
    -o-transition:      all .35s ease-in-out;
    -ms-transition:     all .35s ease-in-out;
    transition:         all .35s ease-in-out; 
    }
    
    .tags .nav-districts ol li a { padding: 4px 6px !important; }
    
    .tags ol li a:hover  { background-color: #eeeeee !important; color: #0066ba; }
    .tags ol li a:active { background-color: #d9d9d9 !important; color: #0066ba; }

.tags ol li a small {
    display: block;
    color: #00192c;
    font-size: 10px; 
    }

.tags .split ol > li { 
    width: 181px;
    float: left; 
    }
  
.tags .split strong a { 
    font-weight: 300;
    font-family: "Arimo",helvetica,arial,sanserif; 
    }
  
.tags .split ol > li p { 
    display: block;
    margin: 0 !important; 
    }
  
.tags .split ol > li p a { 
    font-size: 12px;
    padding: 5px 6px 5px 15px !important;
    position: relative;
    color: #0066ba !important; 
    }
  
.tags .split ol > li p:hover a { color: #003158 !important; }

.tags .split ol > li p a:before { 
    background: #999999;
    content: " ";
    width: 4px;
    height: 4px; 
    display: block;
    position: absolute;
    left: 7px;
    top: 9px;
    -webkit-transition: all .35s ease-in-out;
    -moz-transition:    all .35s ease-in-out;
    -o-transition:      all .35s ease-in-out;
    -ms-transition:     all .35s ease-in-out;
    transition:         all .35s ease-in-out; 
    }



/* --- Menu Trigger --- */

.primary-buttons {
	display: inline-block; 
	font-size: 18px;	
	font-size: 1rem;
}
.primary-buttons .line {
  background: rgba(0,0,0,.3);
  width: 1px;
  height: 1.5em;
  margin: 0 .5em 0 2em;
  display: none;  
  vertical-align: middle; 
  -moz-transition:    all 0.3s ease-in-out;
  -o-transition:      all 0.3s ease-in-out;
  -webkit-transition: all 0.3s ease-in-out;
  transition:         all 0.3s ease-in-out;    
}

.primary-buttons button {
  background: transparent;
  color: #008cff;
  border: 0;
  padding: 0;
  display: table-cell;
  position: relative;
  vertical-align: middle;
  cursor: pointer;
  -moz-transition:    all 0.3s ease-in-out;
  -o-transition:      all 0.3s ease-in-out;
  -webkit-transition: all 0.3s ease-in-out;
  transition:         all 0.3s ease-in-out;		
 }

.primary-buttons button span {
  display: table-cell;
  font-size: 16px;
  font-weight: 400;
  color: #7a7a7a;
  -moz-transition:    all 0.3s ease-in-out;
  -o-transition:      all 0.3s ease-in-out;
  -webkit-transition: all 0.3s ease-in-out;
  transition:         all 0.3s ease-in-out;  	  
}

.primary-buttons button span.icons {
   padding-left: 1em;
    font-size: 20px;
    vertical-align: middle;
}
.primary-buttons button span.canada.icons {
   background-image: url(/theme/img/icon-canada.png);
   height: 20px;
   width: 20px;
   background-repeat: no-repeat; 
   background-position: center right; }

.primary-buttons button:hover span.canada.icons {
   background-image: url(/theme/img/icon-canada-blue.png);
}

.fixed .primary-buttons button,
 .now-interior .primary-buttons button {
   color: #7a7a7a;
   vertical-align: middle;
 }
.primary-buttons button .label {
  text-transform: uppercase;
  padding-left: .2em;
  vertical-align: middle;
}

.primary-buttons button.menu-trigger .label {
   padding-left: .9em; }

@media screen and (-webkit-min-device-pixel-ratio: 0) {
  .primary-buttons button .label {
    padding-left: .2em;
    vertical-align: middle;
  }  
}

.primary-buttons button:hover span,
.expanded-menu .menu-trigger span,
.expanded-search .search-trigger span { color: #008cff; }

.search-trigger {
	color: #6f7d85;
	border-right: 1px solid #cdd2d5;
}
.search-trigger:hover { color: #008cff; }
.search-trigger:active { color: #008cff; }
.search-trigger .icons {
  position: relative;
}

.menu-trigger {
  background: transparent;  
  margin: 0 auto;
  padding-left: .8em !important;
}

.menu-trigger .hamburger,
.menu-trigger .hamburger:after,
.menu-trigger .hamburger:before {
    background: #7a7a7a;	
    width: 1.1em;
    height: 3px;
}

.fixed .menu-trigger .hamburger:after,
.fixed .menu-trigger .hamburger:before {
    background: rgba(122, 122, 122 , 1);
}

.menu-trigger:hover .hamburger,
.menu-trigger:hover .hamburger:after,
.menu-trigger:hover .hamburger:before,
.fixed .menu-trigger:hover .hamburger:after,  
.fixed .menu-trigger:hover .hamburger:before,
.now-interior .menu-trigger:hover .hamburger:after,  
.now-interior .menu-trigger:hover .hamburger:before {
    background: #008cff;
}
.menu-trigger .hamburger {
    background: rgba(122, 122, 122 , 1);
    display: block;
    position: absolute;
    left: 0;
    top: 63%;
    -moz-transform: translateY(-.15em);
    -ms-transform: translateY(-.15em);
    -webkit-transform: translateY(-.15em);
    transform: translateY(-.3em);
    -moz-transition: all 0.25s ease-in-out;
    -o-transition: all 0.25s ease-in-out;
    -webkit-transition: all 0.25s ease-in-out;
    transition: all 0.25s ease-in-out;		
}
.expanded-menu .menu-trigger .hamburger {
	background: rgba(149, 149, 149, 0) !important; 
}

.menu-trigger .hamburger:before {
    content: "";
    position: absolute;
    left: 0;
    bottom: .3em;
    -moz-transition: bottom 300ms 300ms cubic-bezier(0.23, 1, 0.32, 1), transform 300ms cubic-bezier(0.23, 1, 0.32, 1);
    -o-transition: bottom 300ms 300ms cubic-bezier(0.23, 1, 0.32, 1), transform 300ms cubic-bezier(0.23, 1, 0.32, 1);
    -webkit-transition: bottom 300ms 300ms cubic-bezier(0.23, 1, 0.32, 1), transform 300ms cubic-bezier(0.23, 1, 0.32, 1);
    transition: bottom 300ms 300ms cubic-bezier(0.23, 1, 0.32, 1), transform 300ms cubic-bezier(0.23, 1, 0.32, 1);
}

.menu-trigger .hamburger:before {
    bottom: .35em;
}
.menu-trigger .hamburger:after {
    content: "";
    position: absolute;
    left: 0;
    top: .4em;
    -moz-transition: top 300ms 300ms cubic-bezier(0.23, 1, 0.32, 1), transform 300ms cubic-bezier(0.23, 1, 0.32, 1);
    -o-transition: top 300ms 300ms cubic-bezier(0.23, 1, 0.32, 1), transform 300ms cubic-bezier(0.23, 1, 0.32, 1);
    -webkit-transition: top 300ms 300ms cubic-bezier(0.23, 1, 0.32, 1), transform 300ms cubic-bezier(0.23, 1, 0.32, 1);
    transition: top 300ms 300ms cubic-bezier(0.23, 1, 0.32, 1), transform 300ms cubic-bezier(0.23, 1, 0.32, 1);
}


.expanded-menu .menu-trigger .hamburger:after {
    top: 0;
    -moz-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
    -moz-transition: top 300ms cubic-bezier(0.23, 1, 0.32, 1), transform 300ms 300ms cubic-bezier(0.23, 1, 0.32, 1);
    -o-transition: top 300ms cubic-bezier(0.23, 1, 0.32, 1), transform 300ms 300ms cubic-bezier(0.23, 1, 0.32, 1);
    -webkit-transition: top 300ms cubic-bezier(0.23, 1, 0.32, 1), transform 300ms 300ms cubic-bezier(0.23, 1, 0.32, 1);
    transition: top 300ms cubic-bezier(0.23, 1, 0.32, 1), transform 300ms 300ms cubic-bezier(0.23, 1, 0.32, 1);
}
.expanded-menu .menu-trigger .hamburger:before {
    bottom: 0;
    -moz-transform: rotate(-45deg);
    -ms-transform: rotate(-45deg);
    -webkit-transform: rotate(-45deg);
    transform: rotate(-45deg);
    -moz-transition:    bottom 300ms cubic-bezier(0.23, 1, 0.32, 1), transform 300ms 300ms cubic-bezier(0.23, 1, 0.32, 1);
    -o-transition:      bottom 300ms cubic-bezier(0.23, 1, 0.32, 1), transform 300ms 300ms cubic-bezier(0.23, 1, 0.32, 1);
    -webkit-transition: bottom 300ms cubic-bezier(0.23, 1, 0.32, 1), transform 300ms 300ms cubic-bezier(0.23, 1, 0.32, 1);
    transition:         bottom 300ms cubic-bezier(0.23, 1, 0.32, 1), transform 300ms 300ms cubic-bezier(0.23, 1, 0.32, 1);
}
  
.expanded-menu .menu-trigger .hamburger:after,  
.expanded-menu .menu-trigger .hamburger:before {
    background: #008cff !important;
}


@media only screen and (min-width: 1px) {
  .menu-trigger .hamburger,
  .menu-trigger .hamburger:after,
  .menu-trigger .hamburger:before {
      background: #bbb;  
  }
  .primary-buttons button span {
    color: #bbb;    
  }
  .fixed .primary-buttons button span {
    color: #7a7a7a;    
  }  
  
  .fixed .primary-buttons button span.canada.icons, .fixed .primary-buttons button:hover span.canada.icons {
      background-image: url(/theme/img/icon-canada-dkgray.png);
   }
  
  
  .now-interior .menu-trigger .hamburger,
  .now-interior .menu-trigger .hamburger:after,
  .now-interior .menu-trigger .hamburger:before {
      background: #7a7a7a;  
  }
  .now-interior .primary-buttons button span {
    color: #7a7a7a;    
  }
    
  

  .primary-buttons .line {
    display: none;
  }
  .primary-buttons button {
    color: #bbb; 
    display: none;
  }
  .primary-buttons button:first-child {
     display: inline-block; }
  .fixed .primary-buttons .line,
  .now-interior .primary-buttons .line {
    background: #bebebe;
    display: none;
  }
  .menu-trigger .hamburger {
      background: #bbb;
  }    
  .menu-trigger .hamburger:after,  
  .menu-trigger .hamburger:before {
      background: #bbb;
  }
  
  .fixed .menu-trigger .hamburger:after,  
  .fixed .menu-trigger .hamburger:before,
  .now-interior .menu-trigger .hamburger:after,  
  .now-interior .menu-trigger .hamburger:before {
      background: #7a7a7a;
  }  
  .fixed .menu-trigger .hamburger,
  .now-interior .menu-trigger .hamburger {
      background: rgba(122, 122, 122 , 1);
  }    
  .fixed .menu-trigger:hover .hamburger,
  .now-interior .menu-trigger:hover .hamburger {
      background: #008cff;
  }    
  
}

@media only screen and (min-width: 1200px) {
  .primary-buttons .line {
    display: inline-block;
  }
  .primary-buttons button {
    color: #bbb; 
    display: inline-block;
  }
  .fixed .primary-buttons .line,
  .now-interior .primary-buttons .line {
    background: #bebebe;
    display: inline-block;
  }
}

/* ----------- Search ----------- */

header .search {
  background: #444;
	width: 100%;
  max-width: 1400px;
	display: block;
	position: absolute;
	top: 100%;
	left: 50%;
  -moz-transform:    translateX(-50%);
  -ms-transform:     translateX(-50%);
  -webkit-transform: translateX(-50%);
  transform:         translateX(-50%);     
	visibility: hidden;
	opacity: 0;
	z-index: 0; 
  -webkit-transition: all .35s ease-in-out;
  -moz-transition:    all .35s ease-in-out;
  -o-transition:      all .35s ease-in-out;
  -ms-transition:     all .35s ease-in-out;
  transition:         all .35s ease-in-out;
}
	
header .search.visible {
	visibility: visible;
	opacity: 1;
	z-index: 10000; }
	
header .search form {
	width: 100%; 
	padding: .7em;
	position: relative;
  display: -webkit-box;
	display: -moz-box;
	display: -ms-flexbox;
	display: -webkit-flex;
	display: flex;   
}
.secondary .search form {
	padding: .35em;
}
header .search label {
	padding: .7em;
	font-size: 1em;
  font-weight: 700;
	color: #fff; 
	text-transform: uppercase;
	cursor: pointer; 
}

header .search label:hover { color: #008cff; }
 	
.cse-search-box input[type="text"] {
	width: 100%;
	background-color: #fff;
	padding: .7em;
	font-size: 1.3em;
	color: #999; 
  border: 0;
  cursor: pointer;
  -moz-transition:    all 0.3s ease-in-out;
  -o-transition:      all 0.3s ease-in-out;
  -webkit-transition: all 0.3s ease-in-out;
  transition:         all 0.3s ease-in-out;  	  
}
.cse-search-box input[type="text"]:hover {
	background: #999; 
  color: #fff;
}
.cse-search-box input[type="text"]:focus { 
  background: #fff;
  color: #999;   
  -moz-box-shadow: inset 0 -.1em 0 #999;
  -webkit-box-shadow:  inset 0 -.1em 0 #999;
  box-shadow:  inset 0 -.1em 0 #999;
}
.secondary .search input {
	padding: .4em;
	font-size: 1.15em;
}
.cse-search-box input[type="text"]:-moz-placeholder               { opacity: 1; }
.cse-search-box input[type="text"]::-moz-placeholder              { opacity: 1; }
.cse-search-box input[type="text"]:-ms-input-placeholder          { color: #999; }
.cse-search-box input[type="text"]::-webkit-input-placeholder     { color: #999; }

.cse-search-box input[type="text"]:hover:-ms-input-placeholder          { color: #fff; }
.cse-search-box input[type="text"]:hover::-webkit-input-placeholder     { color: #fff; }

.cse-search-box input[type="text"]:focus:-ms-input-placeholder          { color: #999; }
.cse-search-box input[type="text"]:focus::-webkit-input-placeholder     { color: #999; }

.cse-search-box input[type="submit"] {
	width: 2.7em;
	height: auto;
	border-left: 1px solid #fff;
	text-align: center;
	background: #ebedee;
	padding: .7em .7em .6em;
	font-size: 1.3em;
	color: #6f7d85; 
  cursor: pointer;  
  -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;     
}
.cse-search-box input[type="submit"]:hover {
  background: #008cff; 
  color: #fff;
}
.cse-search-box input[type="submit"]:active {
  background: #005dab; 
}
header .search .close {
  position: absolute;
  top: 50%;
  right: 1.4em; 
  color: #fff;
  font-size: 1.2em;
  font-weight: 700;
  display: none;
  cursor: pointer;
  -moz-transform:    translateY(-50%);
  -ms-transform:     translateY(-50%);
  -webkit-transform: translateY(-50%);
  transform:         translateY(-50%); 
  -moz-transition:    all .5s cubic-bezier(0.75, -0.25, 0.25, 0.75);
  -o-transition:      all .5s cubic-bezier(0.75, -0.25, 0.25, 0.75);
  -webkit-transition: all .5s cubic-bezier(0.75, -0.25, 0.25, 0.75);
  transition:         all .5s cubic-bezier(0.75, -0.25, 0.25, 0.75); }
header .search .close:hover { color: #008cff; }
header .search .close:active { color: #005dab; }


@media only screen and (min-width: 740px) { 
	header .search form {
		width: 60%; 
		padding: .6em;		
	}
	header .search label {
		padding: .6em .5em .3em 0;
		font-size: 1.7em; 
	}	
	header .search .close {
		display: inline-block;	
	}
}

/* ----------- Side Nav ----------- */
nav.side { 
	background: #fff;
	-moz-box-shadow:    0 0 .8em .8em rgba(0, 0, 0, 0.1);
	-webkit-box-shadow: 0 0 .8em .8em rgba(0, 0, 0, 0.1);
	box-shadow:         0 0 .8em .8em rgba(0, 0, 0, 0.1);
	width: 65%;
	height: 100%;
	min-height: 100vh;	
	position: fixed;
	left: -100%;
	top: 0;
	z-index: 100000; 
  -webkit-transition: all .6s ease-in-out;
  -moz-transition:    all .6s ease-in-out;
  -o-transition:      all .6s ease-in-out;
  -ms-transition:     all .6s ease-in-out;
  transition:         all .6s ease-in-out; 	
  font-size: 14px;
  text-align: left;
}

.expanded-menu nav.side { 
	left: 0; 
}

nav.side ul li.submenu { 
	position: relative;
}
	
@media only screen and (min-width: 740px) { 
	nav.side { 
		width: 14em;
	}
}

/* --- Updates -- */

nav.side .nav-updates {
  background: #f4f4f4;
  text-transform: uppercase;
  color: #8e8e8e;
  font-weight: 400;
  padding: 2em 1em;
  text-align: center;
  border-bottom: 1px solid #e1e4e5;
}
nav.side .nav-updates strong {
  display: block;
  text-align: center;
  font-weight: 500;
  margin-bottom: .4em;
}
nav.side .nav-updates .icons { 
  display: inline-block;
  vertical-align: middle;    
}
nav.side .nav-updates a { 
  background: transparent;
  color: #8e8e8e;
  padding: 0 .1em;
  font-size: 1.2em;
  display: inline-block;
  vertical-align: middle;
  -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); 
} 

nav.side .nav-updates a:first-child { 
  font-size: 1.45em;
}  
nav.side .nav-updates a:hover { 
  background: transparent;
  -moz-transform:    scale(1.1);
  -ms-transform:     scale(1.1);
  -webkit-transform: scale(1.1);
  transform:         scale(1.1); 
  color: #008cff;
}

/* --- Search -- */

nav.side form {
  width: 100%; 
  padding: 0;
	display: -webkit-box;
	display: -moz-box;
	display: -ms-flexbox;
	display: -webkit-flex;
	display: flex; 
	position: relative;
}

nav.side .cse-search-box label {
	font-size: 1em;
	color: #535353; 
	cursor: pointer; 
  position: absolute;
  left: 1em;
  top: 50%;
  display: inline-block;
  -moz-transform:    translateY(-50%);
  -ms-transform:     translateY(-50%);
  -webkit-transform: translateY(-50%);
  transform:         translateY(-50%);   
}

nav.side .cse-search-box label:hover { color: #008cff; }
 	
nav.side .cse-search-box input[type="text"] {
	width: 100%;
	background: transparent;
	padding: .7em .7em .7em 2em;
	font-size: 1.3em;
	color: #535353; 
  cursor: pointer;
  -moz-transition:    all 0.3s ease-in-out;
  -o-transition:      all 0.3s ease-in-out;
  -webkit-transition: all 0.3s ease-in-out;
  transition:         all 0.3s ease-in-out;  	  
}
nav.side .cse-search-box input[type="text"]:hover {
  background: #e9e9e9; 
  color: #535353;
}
nav.side .cse-search-box input[type="text"]:focus { 
  background: #dadada;
  -moz-box-shadow: inset 0 -.1em 0 #008cff;
  -webkit-box-shadow:  inset 0 -.1em 0 #008cff;
  box-shadow:  inset 0 -.1em 0 #008cff;
  color: #a2aaaf;
}

nav.side .cse-search-box input[type="text"]:-moz-placeholder               { opacity: 1; }
nav.side .cse-search-box input[type="text"]::-moz-placeholder              { opacity: 1; }
nav.side .cse-search-box input[type="text"]:-ms-input-placeholder          { color: #535353; }
nav.side .cse-search-box input[type="text"]::-webkit-input-placeholder     { color: #535353; }

nav.side .cse-search-box input[type="text"]:hover:-ms-input-placeholder          { color: #535353; }
nav.side .cse-search-box input[type="text"]:hover::-webkit-input-placeholder     { color: #535353; }

nav.side .cse-search-box input[type="text"]:focus:-ms-input-placeholder          { color: #a2aaaf; }
nav.side .cse-search-box input[type="text"]:focus::-webkit-input-placeholder     { color: #a2aaaf; }

@media only screen and (min-width: 740px) { 
	header .search label {
		font-size: 1.7em; 
	}	
}


/* --- Submenu -- */

nav.side ul li a { 
	font-size: 125%;
  color: #535353; 
  font-weight: 500;
	padding: .85em 1em;
	display: block;
  -webkit-transition: all .35s ease-in-out;
  -moz-transition:    all .35s ease-in-out;
  -o-transition:      all .35s ease-in-out;
  -ms-transition:     all .35s ease-in-out;
  transition:         all .35s ease-in-out;
}
nav.side ul li a:hover { 
	background: #e9e9e9; 
}

nav.side ol {  display: none; }

@media only screen and (min-width: 740px){
	nav.side ol { 
		background: #fff;
		width: 15em;
		border: 1px solid #ccd1d4;	
		font-size: 80%;	
		padding: 1em;
		list-style: none;
		visibility: hidden;
		display: block;
		opacity: 0;
		position: absolute;
		left: 90%;
		top: 50%;
		z-index: 200000;
		-moz-box-shadow:    0 0 .5em .5em rgba(0, 0, 0, 0.1);
		-webkit-box-shadow: 0 0 .5em .5em rgba(0, 0, 0, 0.1);
		box-shadow:         0 0 .5em .5em rgba(0, 0, 0, 0.1);	
		-moz-transform:    translateY(-50%);
		-ms-transform:     translateY(-50%);
		-webkit-transform: translateY(-50%);
		transform:         translateY(-50%); 
		-webkit-transition: all .35s ease-in-out;
		-moz-transition:    all .35s ease-in-out;
		-o-transition:      all .35s ease-in-out;
		-ms-transition:     all .35s ease-in-out;
		transition:         all .35s ease-in-out; 
  }
		
	nav.side ol:after, nav.side ol:before {
		right: 100%;
		top: 50%;
		border: solid transparent;
		content: " ";
		height: 0;
		width: 0;
		position: absolute;
		pointer-events: none;
	}
	nav.side ol:after, nav.side ol:before {
		right: 100%;
		top: 50%;
		border: solid transparent;
		content: " ";
		height: 0;
		width: 0;
		position: absolute;
		pointer-events: none;
	}
	
	nav.side ol:after {
		border-color: rgba(255, 255, 255, 0);
		border-right-color: #fff;
		border-width: 15px;
		margin-top: -15px;
	}
	nav.side ol:before {
		border-color: rgba(204, 209, 212, 0);
		border-right-color: #ccd1d4;
		border-width: 15px;
		margin-top: -15px;
	}
		
	nav.side li:hover ol {
		visibility: visible !important;
		opacity: 1 !important; 
	}   
	
	nav.side li ol a { 
		background: #fff !important;
		padding: .4em .7em;
		font-size: 150%;
		text-transform: none !important;
	} 		 
	nav.side li ol a:hover { 
  background: #e9e9e9 !important; 
	color: #636363; 
	} 
	nav.side li ol a:active { 
		background: #dbdbdb !important; 
	} 
}



