/*
=====================================================================
*   Ceevee v1.0 Layout Stylesheet
*   url: styleshout.com
*   03-18-2014
=====================================================================

   TOC:
   a. General Styles
   b. Header Styles
   c. About Section
   d. Resume Section
   e. Portfolio Section
   f. Call To Action Section
   g. Testimonials Section
   h. Contact Section
   i. Footer

===================================================================== */

/* ------------------------------------------------------------------ */
/* a. General Styles
/* ------------------------------------------------------------------ */

body { background: #0f0f0f; }

/* Accessible, system fonts and readable paragraphs */
body, h1, h2, h3, h4, h5, h6, p {
   font-family: 'Helvetica', 'Arial', sans-serif;
}

p {
   max-width: 70ch;
   line-height: 1.6;
}

/* ------------------------------------------------------------------ */
/* b. Header Styles
/* ------------------------------------------------------------------ */

header {
   position: relative;
   height: 100vh; /* Ensure the hero section fills the viewport on initial load */
   min-height: 500px;
   width: 100%;
   /* Dark overlay to maintain text readability */
   background: linear-gradient(rgba(0,0,0,0.6), rgba(0,0,0,0.6)), url(../images/webp/header-background.webp) no-repeat top center;
   background-size: cover !important;
        -webkit-background-size: cover !important;
   text-align: center;
   overflow: hidden;
}

/* vertically center banner section */
header:before {
   content: '';
   display: inline-block;
   vertical-align: middle;
   height: 100%;
}
header .banner {
   display: inline-block;
   vertical-align: middle;
   margin: 0 auto;
   width: 85%;
   padding-bottom: 30px;
   text-align: center;
}

header .banner-text { width: 100%; }
header .banner-text h1 {
   font: 90px/1.1em Helvetica, Arial, sans-serif;
   color: #fff;
   letter-spacing: -2px;
   margin: 0 auto 18px auto;
   text-shadow: 0px 1px 3px rgba(0, 0, 0, .8);
}

/* Responsive font sizing using CSS clamp() - replaces FitText jQuery plugin */
header .banner-text h1.responsive-headline {
   font-size: clamp(40px, 8vw, 90px);
}
header .banner-text h2 {
   font: 18px/1.9em Helvetica, Arial, sans-serif;
   color: #f0f0f0; /* Improve contrast on dark image */
   margin: 0 auto;
   width: 70%;
   text-shadow: 0px 1px 2px rgba(0, 0, 0, .5);
}
header .banner-text h2 span,
header .banner-text h2 a {
   color: #fff;
}
header .banner-text hr {
   width: 60%;
   margin: 18px auto 24px auto;
   border-color: #2F2D2E;
   border-color: rgba(150, 150, 150, .1);
}

/* header social links */
header .social {
   margin: 24px 0;
   padding: 0;
   font-size: 30px;
   text-shadow: 0px 1px 2px rgba(0, 0, 0, .8);
}
header .social li {
   display: inline-block;
   margin: 0 15px;
   padding: 0;
}
header .social li a { color: #fff; }
header .social li a:hover { color: #11ABB0; }

/* SVG icons styling (scale with font-size for better zoom behavior) */
header .social svg {
   width: 1.067em;   /* ~= 32px at 30px font-size */
   height: 1.067em;
   fill: currentColor;
   vertical-align: middle;
}

/* Slightly larger Medium icon */
header .social svg.medium-icon {
   width: 1.35em;   /* moderate size bump vs others */
   height: 1.35em;
}

/* scrolldown link */
header .scrolldown a {
   position: absolute;
   bottom: 30px;
   left: 50%;
   margin-left: -29px;
   color: #fff;
   display: block;
   height: 42px;
   width: 42px;
   font-size: 42px;
   line-height: 42px;
   color: #fff;
   border-radius: 100%;

   -webkit-transition: all .3s ease-in-out;
   -moz-transition: all .3s ease-in-out;
   -o-transition: all .3s ease-in-out;
   transition: all .3s ease-in-out;

   /* Bounce animation for scroll down icon */
   -webkit-animation: bounce 2s infinite;
   -moz-animation: bounce 2s infinite;
   animation: bounce 2s infinite;
}
header .scrolldown a:hover { 
   color: #11ABB0; 
   -webkit-animation-play-state: paused;
   -moz-animation-play-state: paused;
   animation-play-state: paused;
}

/* scrolldown arrow SVG */
header .scrolldown svg {
   fill: currentColor;
   width: 42px;
   height: 42px;
}

/* Bounce animation keyframes */
@-webkit-keyframes bounce {
   0%, 20%, 53%, 80%, 100% {
      -webkit-transition-timing-function: cubic-bezier(0.215, 0.610, 0.355, 1.000);
      -webkit-transform: translate3d(0,0,0);
   }
   40%, 43% {
      -webkit-transition-timing-function: cubic-bezier(0.755, 0.050, 0.855, 0.060);
      -webkit-transform: translate3d(0, -8px, 0);
   }
   70% {
      -webkit-transition-timing-function: cubic-bezier(0.755, 0.050, 0.855, 0.060);
      -webkit-transform: translate3d(0, -4px, 0);
   }
   90% {
      -webkit-transform: translate3d(0,-1px,0);
   }
}

@-moz-keyframes bounce {
   0%, 20%, 53%, 80%, 100% {
      -moz-transition-timing-function: cubic-bezier(0.215, 0.610, 0.355, 1.000);
      -moz-transform: translate3d(0,0,0);
   }
   40%, 43% {
      -moz-transition-timing-function: cubic-bezier(0.755, 0.050, 0.855, 0.060);
      -moz-transform: translate3d(0, -8px, 0);
   }
   70% {
      -moz-transition-timing-function: cubic-bezier(0.755, 0.050, 0.855, 0.060);
      -moz-transform: translate3d(0, -4px, 0);
   }
   90% {
      -moz-transform: translate3d(0,-1px,0);
   }
}

@keyframes bounce {
   0%, 20%, 53%, 80%, 100% {
      transition-timing-function: cubic-bezier(0.215, 0.610, 0.355, 1.000);
      transform: translate3d(0,0,0);
   }
   40%, 43% {
      transition-timing-function: cubic-bezier(0.755, 0.050, 0.855, 0.060);
      transform: translate3d(0, -8px, 0);
   }
   70% {
      transition-timing-function: cubic-bezier(0.755, 0.050, 0.855, 0.060);
      transform: translate3d(0, -4px, 0);
   }
   90% {
      transform: translate3d(0,-1px,0);
   }
}

/* primary navigation
--------------------------------------------------------------------- */
#nav-wrap ul, #nav-wrap li, #nav-wrap a {
	 margin: 0;
	 padding: 0;
	 border: none;
	 outline: none;
}

/* nav-wrap */
#nav-wrap {
   font: 12px Helvetica, Arial, sans-serif;
   width: 100%;
   text-transform: uppercase;
   letter-spacing: 2.5px;
   margin: 0 auto;
   z-index: 100;
   position: fixed;
   left: 0;
   top: 0;
}
.opaque { background-color: #333; }

/* hide toggle button */
#nav-wrap > .mobile-btn { display: none; }

ul#nav {
   min-height: 48px;
   width: auto;

   /* center align the menu */
   text-align: center;
}
ul#nav li {
   position: relative;
   list-style: none;
   height: 48px;
   display: inline-block;
}

/* Links */
ul#nav li a {

/* 8px padding top + 8px padding bottom + 32px line-height = 48px */

   display: inline-block;
   padding: 8px 13px;
   line-height: 32px;
	text-decoration: none;
   text-align: left;
   color: #fff;

	-webkit-transition: color .2s ease-in-out;
	-moz-transition: color .2s ease-in-out;
	-o-transition: color .2s ease-in-out;
	-ms-transition: color .2s ease-in-out;
	transition: color .2s ease-in-out;
}

ul#nav li a:active { background-color: transparent !important; }
ul#nav li.current a { color: #F06000; }


/* ------------------------------------------------------------------ */
/* c. About Section
/* ------------------------------------------------------------------ */

#about {
   background: #2B2B2B;
   padding-top: 96px;
   padding-bottom: 66px;
   overflow: hidden;
}

#about a, #about a:visited  { color: #fff; }
#about a:hover, #about a:focus { color: #11ABB0; }

#about h2 {
   font: 22px/30px Helvetica, Arial, sans-serif;
   color: #fff;
   margin-bottom: 12px;
}
#about p {
   line-height: 30px;
   color: #e0e0e0; /* Lighter text for contrast */
}
#about .profile-pic {
   position: relative;
   width: 120px;
   height: 120px;
   border-radius: 100%;
}
#about .contact-details { width: 41.66667%; }
#about .download {
   width: 58.33333%;
   padding-top: 6px;
}
#about .main-col { padding-right: 5%; }
#about .download .button {
   margin-top: 6px;
   background: #444;
}
#about .download .button:hover {
   background: #fff;
   color: #2B2B2B;
}
#about .download .button i {
   margin-right: 15px;
   font-size: 20px;
}


/* ------------------------------------------------------------------ */
/* d. Resume Section
/* ------------------------------------------------------------------ */

#resume {
   background: #fff;
   padding-top: 90px;
   padding-bottom: 72px;
   overflow: hidden;
}

#resume a, #resume a:visited  { color: #0D7377; }
#resume a:hover, #resume a:focus { color: #313131; }

#resume p {
   color: #333;
}

#resume h1 {
   font: 18px/24px Helvetica, Arial, sans-serif;
   text-transform: uppercase;
   letter-spacing: 1px;
}
#resume h1 span {
   border-bottom: 3px solid #11ABB0;
   padding-bottom: 6px;
}
#resume h3 {
   font: 25px/30px Helvetica, Arial, sans-serif;
}

#resume .header-col { padding-top: 9px; }
#resume .main-col { padding-right: 10%; }

#resume .info {
   font: 16px/24px Helvetica, Arial, sans-serif;
   color: #333; /* Dark text on light background */
   margin-bottom: 18px;
   margin-top: 9px;
}
#resume .tech {
    font: 16px/24px Helvetica, Arial, sans-serif;
    color: #333; /* Dark text on light background */
    margin-bottom: 18px;
    margin-top: 9px;
}
.education, .work, .certifications, .portfolio, .patents, .skill {
   margin-bottom: 60px; /* More white space between sections */
   padding-bottom: 30px;
   border-bottom: 1px solid #E8E8E8;
}
#resume .info span {
   margin-right: 5px;
   margin-left: 5px;
}
#resume .date {
   font: 15px/24px Helvetica, Arial, sans-serif;
   margin-top: 6px;
}
#resume .tech span {
    margin-right: 5px;
    margin-left: 5px;
}

/* Limit bullet point width for better readability */
#resume .work ul {
   max-width: 650px;
   margin: 0;
}

#resume .work ul li {
   margin-bottom: 18px;
   line-height: 1.6;
}

#resume .work ul li:last-child {
   margin-bottom: 0;
}

#resume .work ul li .tech {
   line-height: 1.6;
}

/* Work Entry Card Styling - Variation 1: Subtle Cards */
.work-entry {
   background: var(--bg-card, #fafafa);
   border: 1px solid var(--border-card, #e0e0e0);
   border-radius: 8px;
   padding: 25px;
   margin-bottom: 30px;
   box-shadow: 0 2px 4px var(--shadow-sm, rgba(0, 0, 0, 0.05));
}

.work-entry:last-child {
   margin-bottom: 0;
}

/* Career Progression "Titles held" Styling */
.work-title-progression {
   font-size: 16px;
   font-weight: 600;
   color: #666;
   margin: 10px 0 15px 0;
}

.work-title-progression span {
   margin: 0 8px 0 4px;
}

.work-title-progression .title-list {
   font-weight: 400;
   color: #555;
   font-style: normal;
}

/* ================================================================
   Resume Section Card Styles
   Applied to: Education, Certifications, Technologies, Patents, Portfolio
   ================================================================ */

/* Education Entry Card */
.education-entry {
   background: var(--bg-card, #fafafa);
   border: 1px solid var(--border-card, #e0e0e0);
   border-radius: 8px;
   padding: 25px;
   margin-bottom: 30px;
   box-shadow: 0 2px 4px var(--shadow-sm, rgba(0, 0, 0, 0.05));
}

.education-entry:last-child {
   margin-bottom: 0;
}

/* Certification Entry Card - Compact */
.certification-entry {
   background: var(--bg-card, #fafafa);
   border: 1px solid var(--border-card, #e0e0e0);
   border-radius: 8px;
   padding: 20px;
   margin-bottom: 20px;
   box-shadow: 0 2px 4px var(--shadow-sm, rgba(0, 0, 0, 0.05));
}

.certification-entry:last-child {
   margin-bottom: 0;
}

.certification-entry .cert-name {
   font-size: 18px;
   font-weight: 600;
   color: var(--text-heading, #313131);
   margin-bottom: 8px;
}

.certification-entry .cert-name a {
   color: var(--accent-primary, #0D7377);
   text-decoration: none;
}

.certification-entry .cert-name a:hover {
   color: var(--accent-hover, #11ABB0);
}

.certification-entry .cert-dates {
   font-size: 14px;
   color: var(--text-muted, #8B9798);
}

/* Technology Group Card */
.tech-group-card {
   background: var(--bg-card, #fafafa);
   border: 1px solid var(--border-card, #e0e0e0);
   border-radius: 8px;
   padding: 20px;
   margin-bottom: 20px;
   box-shadow: 0 2px 4px var(--shadow-sm, rgba(0, 0, 0, 0.05));
}

.tech-group-card:last-child {
   margin-bottom: 0;
}

.tech-group-card h5 {
   font-size: 16px;
   font-weight: 600;
   color: var(--accent-hover, #11ABB0);
   margin-bottom: 15px;
   padding-bottom: 10px;
   border-bottom: 1px solid var(--border-card, #e0e0e0);
}

.tech-group-card .tech-items {
   display: flex;
   flex-wrap: wrap;
   gap: 8px;
}

.tech-group-card .tech-item {
   background: var(--bg-primary, #fff);
   border: 1px solid var(--border-card, #e0e0e0);
   padding: 6px 12px;
   border-radius: 4px;
   font-size: 13px;
   color: var(--text-primary, #555);
   transition: all 0.2s ease;
}

.tech-group-card .tech-item:hover {
   border-color: var(--accent-hover, #11ABB0);
   color: var(--accent-hover, #11ABB0);
}

/* Patent Entry Card */
.patent-entry {
   background: var(--bg-card, #fafafa);
   border: 1px solid var(--border-card, #e0e0e0);
   border-radius: 8px;
   padding: 20px;
   margin-bottom: 20px;
   box-shadow: 0 2px 4px var(--shadow-sm, rgba(0, 0, 0, 0.05));
}

.patent-entry:last-child {
   margin-bottom: 0;
}

.patent-entry .patent-title {
   font-size: 16px;
   font-weight: 600;
   margin-bottom: 10px;
}

.patent-entry .patent-title a {
   color: var(--accent-primary, #0D7377);
   text-decoration: none;
}

.patent-entry .patent-title a:hover {
   color: var(--accent-hover, #11ABB0);
}

.patent-entry .patent-meta {
   font-size: 14px;
   color: var(--text-muted, #8B9798);
}

/* Portfolio Entry Card */
.portfolio-entry {
   background: var(--bg-card, #fafafa);
   border: 1px solid var(--border-card, #e0e0e0);
   border-radius: 8px;
   padding: 25px;
   margin-bottom: 30px;
   box-shadow: 0 2px 4px var(--shadow-sm, rgba(0, 0, 0, 0.05));
}

.portfolio-entry:last-child {
   margin-bottom: 0;
}

/* Core Strengths Styling */
.core-strengths-container {
   display: flex;
   flex-wrap: wrap;
   gap: 10px;
   margin-top: 10px;
}

.core-strength-badge {
   display: inline-block;
   padding: 8px 16px;
   background-color: #f8f9fa;
   border: 1px solid #11ABB0;
   border-radius: 20px;
   font-size: 14px;
   font-weight: 500;
   color: #313131;
   white-space: nowrap;
   transition: all 0.3s ease;
}

.core-strength-badge:hover {
   background-color: #11ABB0;
   color: white;
}

/* Portfolio tech stack tags */
.tech-stack-tags {
   display: flex;
   flex-wrap: wrap;
   gap: 8px;
   margin-top: 12px;
}

.tech-tag {
   display: inline-block;
   background-color: #f8f9fa;
   border: 1px solid #dee2e6;
   border-radius: 4px;
   padding: 4px 8px;
   font-size: 13px;
   color: #495057;
   font-weight: 500;
}

/*----------------------------------------------*/
/*	Skill Bars
/*----------------------------------------------*/

.bars {
	width: 95%;
	float: left;
	padding: 0;
	text-align: left;
}
.bars .skills {
  	margin-top: 36px;
   list-style: none;
}
.bars li {
   position: relative;
  	margin-bottom: 60px;
  	background: #ccc;
  	height: 42px;
  	border-radius: 3px;
}
.bars li em {
	font: 15px Helvetica, Arial, sans-serif;
   color: #313131;
	text-transform: uppercase;
   letter-spacing: 2px;
	font-weight: normal;
   position: relative;
	top: -36px;
}
.bar-expand {
   position: absolute;
   left: 0;
   top: 0;

   margin: 0;
   padding-right: 24px;
  	background: #313131;
   display: inline-block;
  	height: 42px;
   line-height: 42px;
   border-radius: 3px 0 0 3px;
}
/*
.git {
  	-moz-animation: git 2s ease;
  	-webkit-animation: git 2s ease;
}
.illustrator {
  	-moz-animation: illustrator 2s ease;
  	-webkit-animation: illustrator 2s ease;
}
.reactjs {
  	-moz-animation: reactjs 2s ease;
  	-webkit-animation: reactjs 2s ease;
}
.css {
  	-moz-animation: css 2s ease;
  	-webkit-animation: css 2s ease;
}
.html5 {
  	-moz-animation: html5 2s ease;
  	-webkit-animation: html5 2s ease;
}
.vuejs {
  	-moz-animation: vuejs 2s ease;
  	-webkit-animation: vuejs 2s ease;
}
.mongodb {
  	-moz-animation: mongodb 2s ease;
  	-webkit-animation: mongodb 2s ease;
}

@-moz-keyframes git {
  0%   { width: 0px;  }
  100% { width: 60%;  }
}
@-moz-keyframes illustrator {
  0%   { width: 0px;  }
  100% { width: 55%;  }
}
@-moz-keyframes reactjs {
  0%   { width: 0px;  }
  100% { width: 50%;  }
}
@-moz-keyframes css {
  0%   { width: 0px;  }
  100% { width: 90%;  }
}
@-moz-keyframes html5 {
  0%   { width: 0px;  }
  100% { width: 80%;  }
}
@-moz-keyframes vuejs {
  0%   { width: 0px;  }
  100% { width: 50%;  }
}
@-moz-keyframes mongodb {
  0%   { width: 0px;  }
  100% { width: 80%;  }
}

@-webkit-keyframes photoshop {
  0%   { width: 0px;  }
  100% { width: 60%;  }
}
@-webkit-keyframes illustrator {
  0%   { width: 0px;  }
  100% { width: 55%;  }
}
@-webkit-keyframes reactjs {
  0%   { width: 0px;  }
  100% { width: 50%;  }
}
@-webkit-keyframes css {
  0%   { width: 0px;  }
  100% { width: 90%;  }
}
@-webkit-keyframes html5 {
  0%   { width: 0px;  }
  100% { width: 80%;  }
}
@-webkit-keyframes vuejs {
  0%   { width: 0px;  }
  100% { width: 50%;  }
}
@-webkit-keyframes mongodb {
  0%   { width: 0px;  }
  100% { width: 80%;  }
}  */

/* ------------------------------------------------------------------ */
/* e. Portfolio Section
/* ------------------------------------------------------------------ */

#photos {
   background: #ebeeee;
   padding-top: 90px;
   padding-bottom: 60px;
}
#photos h1 {
   font: 15px/24px Helvetica, Arial, sans-serif;
   text-transform: uppercase;
   letter-spacing: 1px;
   text-align: center;
   margin-bottom: 48px;
   color: #333; /* Darker text for contrast */
}
#photos .header-col {
   display: none; /* Hide the sidebar on desktop for full-width grid */
}
#photos .main-col {
   width: 100%; /* Make main column full width */
   padding-right: 0; /* Remove default padding */
}

/* Portfolio Content */
.photo-grid {
   display: grid;
   grid-template-columns: repeat(3, 1fr);
   gap: 1rem;
   max-width: 1200px;
   margin: 0 auto;
}
.photos-item .item-wrap {
   background: #fff;
   overflow: hidden;
   position: relative;

   -webkit-transition: all 0.3s ease-in-out;
	-moz-transition: all 0.3s ease-in-out;
	-o-transition: all 0.3s ease-in-out;
	-ms-transition: all 0.3s ease-in-out;
	transition: all 0.3s ease-in-out;
}
.photos-item .item-wrap a {
   display: block;
   cursor: pointer;
}

/* overlay */
.photos-item .item-wrap .overlay {
   position: absolute;
   left: 0;
   top: 0;
   width: 100%;
   height: 100%;

	opacity: 0;
	-moz-opacity: 0;
	filter:alpha(opacity=0);

   -webkit-transition: opacity 0.3s ease-in-out;
	-moz-transition: opacity 0.3s ease-in-out;
	-o-transition: opacity 0.3s ease-in-out;
	transition: opacity 0.3s ease-in-out;

   background: url(../images/webp/overlay-bg.webp) repeat;
}
.photos-item .item-wrap .link-icon {
   display: block;
   color: #fff;
   height: 30px;
   width: 30px;
   font-size: 18px;
   line-height: 30px;
   text-align: center;

   opacity: 0;
	-moz-opacity: 0;
	filter:alpha(opacity=0);

   -webkit-transition: opacity 0.3s ease-in-out;
	-moz-transition: opacity 0.3s ease-in-out;
	-o-transition: opacity 0.3s ease-in-out;
	transition: opacity 0.3s ease-in-out;

   position: absolute;
   top: 50%;
   left: 50%;
   margin-left: -15px;
   margin-top: -15px;
}
.photos-item .item-wrap img {
   vertical-align: bottom;
   width: 100%;
}
.photos-item .portfolio-item-meta { padding: 18px }
.photos-item .portfolio-item-meta h5 {
   font: 14px/21px Helvetica, Arial, sans-serif;
   color: #fff;
}
.photos-item .portfolio-item-meta p {
   font: 12px/18px Helvetica, Arial, sans-serif;
   color: #c6c7c7;
   margin-bottom: 0;
}

/* on hover */
.photos-item:hover .overlay {
	opacity: 1;
	-moz-opacity: 1;
	filter:alpha(opacity=100);
}
.photos-item:hover .link-icon {
   opacity: 1;
	-moz-opacity: 1;
	filter:alpha(opacity=100);
}

/* popup modal */
.popup-modal {
	max-width: 550px;
	background: #fff;
	position: relative;
	margin: 0 auto;
}
.popup-modal .description-box { padding: 12px 36px 18px 36px; }
.popup-modal .description-box h4 {
   font: 15px/24px Helvetica, Arial, sans-serif;
	margin-bottom: 12px;
   color: #111;
}
.popup-modal .description-box p {
	font: 14px/24px Helvetica, Arial, sans-serif;
   color: #A1A1A1;
   margin-bottom: 12px;
}
.popup-modal .description-box .categories {
   font: 11px/21px Helvetica, Arial, sans-serif;
   color: #A1A1A1;
   text-transform: uppercase;
   letter-spacing: 2px;
   display: block;
   text-align: left;
}
.popup-modal .description-box .categories i {
   margin-right: 8px;
}
.popup-modal .link-box {
   padding: 18px 36px;
   background: #111;
   text-align: left;
}
.popup-modal .link-box a {
   color: #fff;
	font: 11px/21px Helvetica, Arial, sans-serif;
	text-transform: uppercase;
   letter-spacing: 3px;
   cursor: pointer;
}
.popup-modal a:hover {	color: #00CCCC; }
.popup-modal a.popup-modal-dismiss { margin-left: 24px; }


/* fadein/fadeout effect for modal popup
/* ------------------------------------------------------------------ */

/* content at start */
.mfp-fade.mfp-wrap .mfp-content .popup-modal {
   opacity: 0;
   -webkit-transition: all 200ms ease-in-out;
	-moz-transition: all 200ms ease-in-out;
	-o-transition: all 200ms ease-in-out;
	-ms-transition: all 200ms ease-in-out;
   transition: all 200ms ease-in-out;
}
/* content fadein */
.mfp-fade.mfp-wrap.mfp-ready .mfp-content .popup-modal {
   opacity: 1;
}
/* content fadeout */
.mfp-fade.mfp-wrap.mfp-removing .mfp-content .popup-modal {
   opacity: 0;
}

/* ------------------------------------------------------------------ */
/* f. Call To Action Section
/* ------------------------------------------------------------------ */

#call-to-action {
   background: #212121;
   padding-top: 66px;
   padding-bottom: 48px;
}
#call-to-action h1 {
   font: 18px/24px Helvetica, Arial, sans-serif;
   text-transform: uppercase;
   letter-spacing: 3px;
   color: #fff;
}
#call-to-action h1 span { display: none; }
/* FontAwesome icon removed - no longer needed */
   line-height: 72px;
   text-align: left;
   float: left;
   color: #fff;
}
#call-to-action .action {
   margin-top: 12px;
}
#call-to-action h2 {
   font: 28px/36px Helvetica, Arial, sans-serif;
   color: #EBEEEE;
   margin-bottom: 6px;
}
#call-to-action h2 a {
   color: inherit;
}
#call-to-action p {
   color: #636363;
   font-size: 17px;
}
/*#
call-to-action .button {
	color:#fff;
   background: #0D0D0D;
}
*/
#call-to-action .button:hover,
#call-to-action .button:active {
   background: #FFFFFF;
   color: #0D0D0D;
}
#call-to-action p span {
	font-family: Helvetica, Arial, sans-serif;
	color: #D8D8D8;
}

/* ------------------------------------------------------------------
/* g. Testimonials
/* ------------------------------------------------------------------ */

#testimonials {
   background: #1F1F1F url(../images/webp/testimonials-bg.webp) no-repeat center center;
   background-size: cover !important;
	-webkit-background-size: cover !important;
   background-attachment: fixed;

   position: relative;
   min-height: 200px;
   width: 100%;
   overflow: hidden;
}
#testimonials .text-container {
   padding-top: 96px;
   padding-bottom: 66px;
}
#testimonials h1 {
   font: 18px/24px Helvetica, Arial, sans-serif;
   text-transform: uppercase;
   letter-spacing: 3px;
   color: #fff;
}
#testimonials h1 span { display: none; }
#testimonials .header-col { padding-top: 9px; }
/* FontAwesome icon removed - no longer needed */
   line-height: 72px;
   text-align: left;
   float: left;
   color: #fff;
}

/*	Blockquotes */
#testimonials blockquote {
   margin: 0 0px 30px 0px;
   padding-left: 0;
   position: relative;
   text-shadow: 0px 1px 3px rgba(0, 0, 0, 1);
}
#testimonials blockquote:before { content: none; }
#testimonials blockquote p {
   font-family: Helvetica, Arial, sans-serif;
   padding: 0;
   font-size: 24px;
   line-height: 48px;
   color: #fff
}
#testimonials blockquote cite {
   display: block;
   font-size: 12px;
   font-style: normal;
   line-height: 18px;
   color: #fff;
}
#testimonials blockquote cite:before { content: "\2014 \0020"; }
#testimonials blockquote cite a,
#testimonials blockquote cite a:visited { color: #8B9798; border: none }

/* Flex Slider
/* ------------------------------------------------------------------ */

/* Reset */
.flexslider a:active,
.flexslider a:focus  { outline: none; }
.slides,
.flex-control-nav,
.flex-direction-nav { margin: 0; padding: 0; list-style: none; }
.slides li { margin: 0; padding: 0;}

/* Necessary Styles */
.flexslider {
   position: relative;
   zoom: 1;
   margin: 0;
   padding: 0;
}
.flexslider .slides { zoom: 1; }
.flexslider .slides > li { position: relative; }

/* Hide the slides before the JS is loaded. Avoids image jumping */
.flexslider .slides > li { display: none; -webkit-backface-visibility: hidden; }
/* Suggested container for slide animation setups. Can replace this with your own */
.flex-container { zoom: 1; position: relative; }

/* Clearfix for .slides */
.slides:before,
.slides:after {
   content: " ";
   display: table;
}
.slides:after {
   clear: both;
}

/* No JavaScript Fallback */
/* If you are not using another script, such as Modernizr, make sure you
 * include js that eliminates this class on page load */
.no-js .slides > li:first-child { display: block; }

/* Slider Styles */
.slides { zoom: 1; }
.slides > li {
   /*margin-right: 5px; */
   overflow: hidden;
}

/* Control Nav */
.flex-control-nav {
    width: 100%;
    position: absolute;
    bottom: -20px;
    text-align: left;
}
.flex-control-nav li {
    margin: 0 6px;
    display: inline-block;
    zoom: 1;
    *display: inline;
}
.flex-control-paging li a {
    width: 12px;
    height: 12px;
    display: block;
    background: #ddd;
    background: rgba(255, 255, 255, .3);
    cursor: pointer;
    text-indent: -9999px;
    -webkit-border-radius: 20px;
    -moz-border-radius: 20px;
    -o-border-radius: 20px;
    border-radius: 20px;
    box-shadow: inset 0 0 3px rgba(255, 255, 255, .3);
}
.flex-control-paging li a:hover {
    background: #CCC;
    background: rgba(255, 255, 255, .7);
}
.flex-control-paging li a.flex-active {
    background: #fff;
    background: rgba(255, 255, 255, .9);
    cursor: default;
}

/* ------------------------------------------------------------------ */
/* h. Contact Section
/* ------------------------------------------------------------------ */

#contact {
   background: #191919;
   padding-top: 96px;
   padding-bottom: 102px;
   color: #636363;
}
#contact .section-head { margin-bottom: 42px; }

#contact a, #contact a:visited  { color: #11ABB0; }
#contact a:hover, #contact a:focus { color: #fff; }

#contact h1 {
   font: 18px/24px Helvetica, Arial, sans-serif;
   text-transform: uppercase;
   letter-spacing: 3px;
   color: #EBEEEE;
   margin-bottom: 6px;
}
#contact h1 span { display: none; }
/* FontAwesome icon removed - no longer needed */
   line-height: 72px;
   text-align: left;
   float: left;
   color: #ebeeee;
}

#contact h4 {
   font: 16px/24px Helvetica, Arial, sans-serif;
   color: #EBEEEE;
   margin-bottom: 6px;
}
#contact p.lead {
   font: 18px/36px Helvetica, Arial, sans-serif;
   padding-right: 3%;
}
#contact .header-col { padding-top: 6px; }


/* contact form */
#contact form { margin-bottom: 30px; }
#contact label {
   font: 15px/24px Helvetica, Arial, sans-serif;
   margin: 12px 0;
   color: #EBEEEE;
	display: inline-block;
	float: left;
   width: 26%;
}
#contact input,
#contact textarea,
#contact select {
   padding: 18px 20px;
	color: #eee;
	background: #373233;
	margin-bottom: 42px;
	border: 0;
	outline: none;
   font-size: 15px;
   line-height: 24px;
   width: 65%;
}
#contact input:focus,
#contact textarea:focus,
#contact select:focus {
	color: #fff;
	background-color: #11ABB0;
}
#contact button.submit {
	text-transform: uppercase;
	letter-spacing: 3px;
	color:#fff;
   background: #0D0D0D;
	border: none;
   cursor: pointer;
   height: auto;
   display: inline-block;
	border-radius: 3px;
   margin-left: 26%;
}
#contact button.submit:hover {
	color: #0D0D0D;
	background: #fff;
}
#contact span.required {
	color: #11ABB0;
	font-size: 13px;
}
#message-warning, #message-success {
   display: none;
	background: #0F0F0F;
	padding: 24px 24px;
	margin-bottom: 36px;
   width: 65%;
   margin-left: 26%;
}
#message-warning { color: #D72828; }
#message-success { color: #11ABB0; }

#message-warning i,
#message-success i {
   margin-right: 10px;
}
#image-loader {
   display: none;
   position: relative;
   left: 18px;
   top: 17px;
}


/* Twitter Feed */
#twitter {
   margin-top: 12px;
   padding: 0;
}
#twitter li {
   margin: 6px 0px 12px 0;
   line-height: 30px;
}
#twitter li span {
   display: block;
}
#twitter li b a {
   font: 13px/36px Helvetica, Arial, sans-serif;
   color: #474747 !important;
   border: none;
}


/* ------------------------------------------------------------------ */
/* i. Footer
/* ------------------------------------------------------------------ */

footer {
   padding-top: 48px;
   margin-bottom: 48px;
   color: #303030;
   font-size: 14px;
   text-align: center;
   position: relative;
}

footer a, footer a:visited { color: #525252; }
footer a:hover, footer a:focus { color: #fff; }

/* copyright */
footer .copyright {
    margin: 0;
    padding: 0;
 }
footer .copyright li {
    display: inline-block;
    margin: 0;
    padding: 0;
    line-height: 24px;
    color: #cccccc;
}
.ie footer .copyright li {
   display: inline;
}
footer .copyright li:before {
    content: "\2022";
    padding-left: 10px;
    padding-right: 10px;
    color: #095153;
}
footer .copyright  li:first-child:before {
    display: none;
}

/* social links */
footer .social-links {
   margin: 18px 0 30px 0;
   padding: 0;
   font-size: 30px;
}
footer .social-links li {
    display: inline-block;
    margin: 0;
    padding: 0;
    margin-left: 42px;
    color: #F06000;
}

footer .social-links li:first-child { margin-left: 0; }

/* Footer SVG icons */
footer .social-links svg {
   width: 1.067em;  /* ~= 32px at 30px font-size */
   height: 1.067em;
   fill: currentColor;
   vertical-align: middle;
}

/* Slightly larger Medium icon (footer) */
footer .social-links svg.medium-icon {
   width: 1.35em;
   height: 1.35em;
}

/* Go To Top Button */
#go-top {
	position: absolute;
	top: -24px;
   left: 50%;
   margin-left: -30px;
}
#go-top a {
	text-decoration: none;
	border: 0 none;
	display: block;
	width: 60px;
	height: 60px;
	background-color: #525252;

	-webkit-transition: all 0.2s ease-in-out;
   -moz-transition: all 0.2s ease-in-out;
   -o-transition: all 0.2s ease-in-out;
   -ms-transition: all 0.2s ease-in-out;
   transition: all 0.2s ease-in-out;

   color: #fff;
   font-size: 21px;
   line-height: 60px;
 	border-radius: 100%;
}
#go-top a:hover { background-color: #0F9095; }
