/*
	Theme Name: HTML5 Blank
	Theme URI: http://html5blank.com
	Description: HTML5 Blank WordPress Theme
	Version: 1.4.3
	Author: Todd Motto (@toddmotto)
	Author URI: http://toddmotto.com
	Tags: Blank, HTML5, CSS3

	License: MIT
	License URI: http://opensource.org/licenses/mit-license.php
*/
/*------------------------------------*\
    MAIN
\*------------------------------------*/
/* global box-sizing */
*, *:after, *:before {
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  -webkit-font-smoothing: antialiased;
  font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
/* html element 62.5% font-size for REM use */
html {
  font-size: 62.5%;
  font-size: 13px;
  background-color: #444;
}
body {
  font: 300 11px/1.4 "NimbusSansProRegularExtended", Helvetica, Arial, sans-serif;
  color: #444;
  background-color: whitesmoke;
}
/* clear */
.clear:before, .clear:after {
  content: " ";
  display: table;
}
.clear:after {
  clear: both;
}
.clear {
  *zoom: 1;
}
img {
  max-width: 100%;
  vertical-align: bottom;
}
a {
  color: #444;
  text-decoration: none;
}
a:hover {
  color: #444;
}
a:focus {
  outline: 0;
}
a:hover, a:active {
  outline: 0;
}
input:focus {
  outline: 0;
  border: 1px solid #04A4CC;
}
/*------------------------------------*\
    STRUCTURE
\*------------------------------------*/
/* wrapper */
.wrapper {
  max-width: 1280px;
  width: 95%;
  margin: 0 auto;
  position: relative;
}
/* header */
/* logo */
/* nav */
/* sidebar */
/* footer */
/*------------------------------------*\
    PAGES
\*------------------------------------*/
/*------------------------------------*\
    IMAGES
\*------------------------------------*/
/*------------------------------------*\
	TYPOGRAPHY
\*------------------------------------*/
/*
@font-face {
	font-family:'Font-Name';
	src:url('fonts/font-name.eot');
	src:url('fonts/font-name.eot?#iefix') format('embedded-opentype'),
		url('fonts/font-name.woff') format('woff'),
		url('fonts/font-name.ttf') format('truetype'),
		url('fonts/font-name.svg#font-name') format('svg');
    font-weight:normal;
    font-style:normal;
}
*/
@font-face {
  font-family: "NimbusSansProRegularExtended";
  src: url("fonts/NimbusSansProRegularExtended/font.woff2") format("woff2"), url("fonts/NimbusSansProRegularExtended/font.woff") format("woff");
}
/*------------------------------------*\
    RESPONSIVE
\*------------------------------------*/
.mobile-visible {
  display: none;
}
.desktop-visible {
  display: none;
}
@media only screen and (min-width: 769px) {
  .desktop-visible {
    display: block;
  }
}
@media only screen and (max-width: 768px) {
  .mobile-visible {
    display: block;
  }
}
/*------------------------------------*\
    MISC
\*------------------------------------*/
::selection {
  background: #04A4CC;
  color: #FFF;
  text-shadow: none;
}
::-webkit-selection {
  background: #04A4CC;
  color: #FFF;
  text-shadow: none;
}
::-moz-selection {
  background: #04A4CC;
  color: #FFF;
  text-shadow: none;
}
/*------------------------------------*\
    WORDPRESS CORE
\*------------------------------------*/
.alignnone {
  margin: 5px 20px 20px 0;
}
.aligncenter, div.aligncenter {
  display: block;
  margin: 5px auto 5px auto;
}
.alignright {
  float: right;
  margin: 5px 0 20px 20px;
}
.alignleft {
  float: left;
  margin: 5px 20px 20px 0;
}
a img.alignright {
  float: right;
  margin: 5px 0 20px 20px;
}
a img.alignnone {
  margin: 5px 20px 20px 0;
}
a img.alignleft {
  float: left;
  margin: 5px 20px 20px 0;
}
a img.aligncenter {
  display: block;
  margin-left: auto;
  margin-right: auto;
}
.wp-caption {
  background: #FFF;
  border: 1px solid #F0F0F0;
  max-width: 96%;
  padding: 5px 3px 10px;
  text-align: center;
}
.wp-caption.alignnone {
  margin: 5px 20px 20px 0;
}
.wp-caption.alignleft {
  margin: 5px 20px 20px 0;
}
.wp-caption.alignright {
  margin: 5px 0 20px 20px;
}
.wp-caption img {
  border: 0 none;
  height: auto;
  margin: 0;
  max-width: 98.5%;
  padding: 0;
  width: auto;
}
.wp-caption .wp-caption-text, .gallery-caption {
  font-size: 11px;
  line-height: 17px;
  margin: 0;
  padding: 0 4px 5px;
}
/*------------------------------------*\
    PRINT
\*------------------------------------*/
@media print {
  * {
    background: transparent !important;
    color: #000 !important;
    box-shadow: none !important;
    text-shadow: none !important;
  }
  a, a:visited {
    text-decoration: underline;
  }
  a[href]:after {
    content: " (" attr(href) ")";
  }
  abbr[title]:after {
    content: " (" attr(title) ")";
  }
  .ir a:after, a[href^="javascript:"]:after, a[href^="#"]:after {
    content: "";
  }
  pre, blockquote {
    border: 1px solid #999;
    page-break-inside: avoid;
  }
  thead {
    display: table-header-group;
  }
  tr, img {
    page-break-inside: avoid;
  }
  img {
    max-width: 100% !important;
  }
  @page {
    margin: 0.5cm;
  }
  p, h2, h3 {
    orphans: 3;
    widows: 3;
  }
  h2, h3 {
    page-break-after: avoid;
  }
}
/* Preloader styles */
#preloader {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: whitesmoke;
  /* Background color for preloader */
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 9999;
  /* Ensure it covers everything */
}
.spinner {
  width: 50px;
  height: 50px;
  border: 1px solid whitesmoke;
  border-top: 1px solid black;
  /* Color for the spinner */
  border-radius: 50%;
  animation: spin 1s linear infinite;
}
/* Keyframes for spinner animation */
@keyframes spin {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
.page-template-page-home .wrapper {
  max-width: unset !important;
  width: unset !important;
}
/* Container for the slider */
.slider-container {
  position: relative;
  width: calc((var(--vw, 1vw) * 100));
  height: calc((var(--vh, 1vh) * 100));
  overflow: hidden;
}
/* Video styling */
.bg-video {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 1;
  transition: opacity 1s ease;
  opacity: 0;
}
/* Image backgrounds (hidden by default) */
.bg-image-container {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  background-size: cover;
  background-position: center bottom;
  opacity: 0;
  transition: opacity 1s ease;
  z-index: 1;
}
.bg-image {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  background-size: cover;
  background-position: center bottom;
  transition: opacity 1s ease;
  z-index: 1;
}
/* Fixed text layer */
.text-layer {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 11;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: space-between;
  pointer-events: none;
  /* Ensure that mouse clicks pass through to slider */
}
.logo {
  pointer-events: auto;
  /* Allow clicks */
  cursor: pointer;
  font-size: 2em;
  font-weight: bold;
  margin-top: 33px;
  text-align: center;
  z-index: 11;
  position: relative;
}
@media (min-width: 768px) {
  .logo {
    margin-top: 30px;
  }
}
.logo span.logo-img, .logo h1 {
  margin: 0;
  padding: 0;
  text-align: center;
  margin-left: auto;
  margin-right: auto;
  font-size: 1em;
  line-height: 1em;
  max-width: 90%;
}
@media (max-width: 768px) {
  .logo span.logo-img, .logo h1 {
    max-width: 90%;
  }
}
.logo h2 {
  text-align: center;
  margin: 0;
  padding: 0;
  margin-top: 13px;
}
@media (min-width: 768px) {
  .logo h2 {
    margin-top: 24px;
  }
}
.logo h2 img {
  margin-left: auto;
  margin-right: auto;
}
a:hover, a:focus {
  text-decoration: underline;
}
.list-inline {
  list-style: none;
}
.list-inline li {
  display: inline-block;
}
.contact-info {
  pointer-events: auto;
  /* Allow clicks */
  color: white;
  font-size: 13px;
  text-transform: uppercase;
  margin-top: auto;
  margin-bottom: 30px;
  text-align: center;
}
.contact-info a {
  color: white;
}
.contact-info h4 {
  font-weight: normal;
  margin: 0;
  padding: 0;
  margin-bottom: 10px;
}
@media (min-width: 768px) {
  .contact-info h4 {
    margin-bottom: 13px;
  }
}
.contact-info .phone_no {
  margin-bottom: 21px;
}
@media (min-width: 768px) {
  .contact-info .phone_no {
    margin-bottom: 9px;
  }
}
.contact-info .emails {
  padding: 0;
  margin: 0;
  margin-bottom: 34px;
}
@media (min-width: 768px) {
  .contact-info .emails {
    margin-bottom: 29px;
  }
}
.contact-info .emails .email1 {
  padding-right: 13px;
}
@media (max-width: 768px) {
  .contact-info .emails .email1 {
    border-right: 1px solid white;
  }
}
@media (min-width: 768px) {
  .contact-info .emails .email1 {
    padding-right: 9px;
  }
}
.contact-info .emails .email2 {
  padding-left: 13px;
}
@media (min-width: 768px) {
  .contact-info .emails .email2 {
    padding-left: 9px;
  }
}
.contact-info .company_name {
  font-size: 11px;
}
@media (min-width: 768px) {
  .contact-info .company_name {
    font-size: 10px;
  }
}
/* Active image style */
.bg-video.active {
  opacity: 1;
}
.bg-image-container.active {
  opacity: 1;
}
.bg-image-container img {
  opacity: 0.8;
}
/* Navigation buttons */
.nav-button {
  position: absolute;
  top: 0;
  width: 50%;
  height: 100%;
  z-index: 3;
  cursor: pointer;
}
/* Left and right side specific styling */
.left-nav {
  left: 0;
}
.right-nav {
  right: 0;
}
/* Optional: Add hover effect for feedback */
