/* Reset default browser styles */
html,
body {
   margin: 0;
   padding: 0;
   --background-dark: hsl(240, 19%, 15%);
   --background-dark-transparent: hsla(240, 19%, 15%, 0.4);
   --background-dark-gray: #2d2d44;
   --light-text: #fff;
   --stoneit-color: #31e0ed;
   --stoneit-color-transparent: hsla(184, 84%, 56%, 0.1);
   --stoneit-color-light-transparent: hsla(184, 84%, 56%, 0);
   --stoneit-sapphire: #0f52ba;
}

html {
   font-size: 16px;
}
/*FONTS CONFIGURATIONS*/

pre.code,
pre[class*='language-'] {
   display: block;
   width: 66%;
   min-width: 725px;
   overflow: auto;
   box-sizing: border-box;
}
code.code {
   display: inline;
}

/* 
   <weight>: Use a value from 200 to 900 
*/
.code {
   font-family: 'Inconsolata', Consolas, monospace !important;
   font-optical-sizing: auto;
   font-weight: 300;
   font-style: normal;
   font-variation-settings: 'wdth' 100;
}

.protest-strike-regular {
   font-family: 'Protest Strike', sans-serif;
   font-weight: 400;
   font-style: normal;
}

/*   
   <uniquifier>: Use a unique and descriptive class name
   <weight>: Use a value from 200 to 1000
   <width>: Use a value from 75 to 125 
*/
.nunito-sans-regular {
   font-family: 'Nunito Sans', sans-serif;
   font-optical-sizing: auto;
   font-weight: 200;
   font-style: normal;
   font-variation-settings:
      'wdth' 100,
      'YTLC' 500;
}

.nunito-sans-bold {
   font-family: 'Nunito Sans', sans-serif;
   font-optical-sizing: auto;
   font-weight: bold;
   font-style: normal;
   font-variation-settings:
      'wdth' 100,
      'YTLC' 500;
}
/*END OF FONTS CONFIGURATIONS*/

/* Global styles */
body {
   font-family: 'Nunito Sans', Arial, sans-serif;
   background-color: var(--background-dark);
   color: var(--light-text);
}

.section-white {
   padding: 42px;
   box-shadow: 0px 0px 40px 10px hsla(0, 0%, 90%, 0.3);
   background-color: hsla(0, 0%, 98%, 1);
   color: hsla(0, 0%, 0%, 1);
}
.section-white h1 {
   color: var(--background-dark);
}
.section-white img.blogpost {
   width: 100%;
   height: auto;
   object-fit: cover;
}
.cards-container {
   display: flex;
   flex-wrap: wrap;
   width: 100%;
   flex-direction: row;
   justify-content: flex-start;
   align-items: stretch;
   box-sizing: border-box;
}
.cards-container .title {
   width: 100%;
}
.cards-container .card {
   width: 25%;
   box-sizing: border-box;
}
.cards-container .card a.card-link {
   text-decoration: none;
}
.cards-container .card img {
   width: 100%;
   height: 200px;
   object-fit: cover;
}

/* Header styles */
header {
   background-color: hsla(0, 0%, 0%, 0.24);
   padding: 15px 2vw;
   box-sizing: border-box;
   color: #fff;
   z-index: 1000;
   position: fixed;
   border-bottom: 1px solid white;
   width: 100%;
   transition: background-color 0.25s;
}

h2,
h3 {
   color: var(--stoneit-sapphire);
}

.heading-container {
   position: relative;
   height: 100vh;
   padding: 20px;
   box-sizing: border-box;
}

.video-container {
   position: absolute;
   width: 100%;
   height: 100%;
   z-index: 0;
   margin: -20px;
}
.video-container:before {
   content: '';
   position: absolute;
   background: rgba(0, 0, 0, 0.4);
   top: 0;
   right: 0;
   bottom: 0;
   left: 0;
}
.video-container video.heading-video {
   width: 100%;
   height: 100%;
   object-fit: cover;
   display: block;
   object-position: center;
}

.heading-container .heading-text {
   z-index: 1;
   text-align: center;
}

.container .heading-description {
   background-color: var(--light-text);
   padding: 20px 42px;
   margin: 0px;
}
.container .heading-container .video-text-container {
   display: flex;
}

.container .heading-container .video-text-container .video-description,
.container .heading-container .video-text-container .video-center,
.container .heading-container .video-text-container .video-right {
   width: 33%;
   min-width: 300px;
   bottom: 0px;
   max-height: 88vh;
   box-sizing: border-box;
   padding: 20px 0px;
   height: 88vh;
   z-index: 100;
   display: flex;
   flex-direction: column;
   flex-direction: column;
   justify-content: flex-end;
}

.container .heading-container h1.heading-text {
   font-size: 2em;
   text-align: left;
}
.heading-container h1.heading-text {
   z-index: 110;
   padding: 0px 0px 20px 0px;
}

.container .heading-container h2.heading-text {
   font-size: 1.2em;
   color: var(--light-text);
   font-weight: normal;
}
h3.heading-text {
   font-size: 1.1em;
}

h1 {
   color: var(--light-text);
   font-size: 2rem;
}
h2 {
   font-size: 1.7rem;
}
h3 {
   font-size: 1.3rem;
}

@media only screen and (max-width: 413px) {
   html body.blog {
      font-size: 13px;
   }
   div.contact-container {
      padding: 0px !important;
   }
   .margin {
      padding: 20px 20px !important;
   }
   .cards-container .card {
      width: 100% !important;
   }
}

@media only screen and (max-width: 950px) {
   .cards-container .card {
      width: 50%;
   }
   main {
      padding: 20px 0px !important;
   }
   nav ul {
      display: none !important;
   }
   nav .logo {
      width: 50% !important;
   }
   header nav div.head-cta {
      width: 50% !important;
   }
   button.outlined,
   a.outlined {
      font-size: 1em;
   }
   .logo {
      font-size: 3rem;
   }
   .heading-text {
      min-width: 200px;
   }
   h1 {
      color: var(--light-text);
      font-size: 1.2rem;
   }
   h2 {
      font-size: 1.1rem;
   }
   h3 {
      font-size: 1rem;
   }

   /**HEADING SECTION**/
   .container .heading-container h1.heading-text {
      font-size: 1.6em;
   }
   /**END OF HEADING SECTION**/

   div.services-container div.service-content {
      width: 100%;
   }
   /**SERVICE DEFINITION SECTION**/
   section#about-us div.about-us-content div.column-container {
      width: 100%;
      margin: 50px 10px;
   }
   section#about-us div.about-us-content div.column p {
      font-size: 1.2em;
      padding-top: 0px;
   }
   section#about-us div.about-us-content div.column {
      width: 100%;
      padding-bottom: 0px;
   }
   section#about-us div.about-us-content div.column h3 {
      font-size: 2em;
      margin-bottom: 0px;
   }
   section#about-us div.about-us-content div.column h3::after {
      content: '';
   }
   /**END OF SERVICE DEFINITION SECTION**/

   /**CONTACT US SECTION**/
   section#contact div.contact-container div.column .question {
      font-size: 2em;
   }
   section#contact div.contact-container div.column .cta {
      font-size: 1.5em;
   }
   section#contact div.contact-container div.column {
      width: 100%;
      margin: 0px;
   }
   /**END OF CONTACT US SECTION**/
   /**BLOG SECTION**/
   body.blog div.container {
      padding: calc(3rem + 15px + 40px) 20px !important;
   }
   img.wistia-embed {
      width: 100%;
      height: auto;
      max-width: 400px;
   }
   pre.code,
   pre[class*='language-'] {
      width: 100% !important;
      overflow-y: auto !important;
      min-width: inherit !important;
   }
   body.blog div.container img {
      width: 100%;
   }
   dt,
   dd {
      word-break: break-all;
   }
   /**END OF BLOG SECTION**/
}
header.white {
   background-color: #fff;
   color: #000 !important;
}
header.white ul li a {
   color: #000 !important;
}

dt {
   font-weight: bolder;
}

.logo {
   display: inline-block;
   height: 3rem;
   font-size: 2.5rem;
   line-height: 2.5rem;
   padding: 0px;
   margin: 0px;
   width: 20%;
   position: relative;
   overflow: hidden;
}
.logo img {
   height: 100%;
   width: auto;
   display: inline-block;
   margin: 0px;
   padding: 0px;
}

/* Navigation styles */
nav {
   display: flex;
   width: 100%;
   position: relative;
   box-sizing: border-box;
   align-items: center;
   justify-content: space-evenly;
   align-content: center;
   flex-direction: row;
   flex-wrap: wrap;
}

nav ul {
   list-style-type: none;
   height: 3rem;
   margin: 0px;
   padding: 0px;
   width: 60%;
   display: inline-block;
}

nav ul li {
   display: inline-block;
   margin-right: 10px;
   height: 2.5rem;
   line-height: 2.5rem;
   box-sizing: border-box;
   overflow: hidden;
   padding: 2px 10px;
   width: 80px;
   text-align: center;
   font-size: 1.1rem;
   font-weight: 600;
}

nav ul li a {
   color: #fff;
   text-decoration: none;
}
nav ul li:hover {
   background-color: hsla(0, 0%, 0%, 0.1);
}
nav ul li:hover a {
   font-weight: bold;
}
nav div.head-cta {
   width: 20%;
   text-align: end;
   height: 100%;
}

/* Main content styles */
main {
   padding: 0px;
}

body.blog div.container {
   padding: calc(3rem + 15px + 40px) 60px;
}
div.container {
   padding: 0vh 0vw;
}
/* Footer styles */
footer {
   background-color: var(--background-dark-gray);
   padding: 0.3em;
   color: #fff;
   text-align: center;
   position: relative;
   bottom: 0px;
   display: block;
   width: 100%;
   box-sizing: border-box;
}

a.button {
   text-decoration: none;
}
header.white button.outlined,
.section-white button.outlined,
.section-white a.outlined,
header.white a.outlined {
   color: var(--background-dark-gray) !important;
   border: solid 1px var(--background-dark-gray) !important;
}
button.outlined,
a.outlined {
   background-color: transparent;
   padding: 15px;
   color: var(--light-text);

   border: solid 1px var(--light-text);
   border-radius: 15px;
   font-size: 1.1em;
}
button.outlined:hover,
a.outlined:hover {
   /* background-color: hsla(240, 19%, 100%, 0.1); */
   background-color: var(--stoneit-color-transparent);
}
button.outlined:active,
a.outlined:active {
   background-color: hsla(240, 19%, 0%, 0.3);
}

/**SERVICES SECTIONS**/
div.services-container {
   display: flex;
   flex-wrap: wrap;
   justify-content: space-around;
   padding: 20px 2px;
}
div.services-container div.title {
   width: 100%;
   padding: 0px 20px;
}

div.services-container div.service-content {
   width: calc(25% - 10px);
   box-sizing: border-box;
   min-width: 300px;
   padding: 20px 20px;
   margin: 5px;
   background-color: hsla(0, 0%, 98%, 1);
   color: black;
   /* border-radius: 10px; */
   /* box-shadow: 0px 0px 20px 0px hsla(0, 0%, 90%, 0.9); */
   /* transition: background-color 0.25s; */
   /* border: 2px solid hsla(303, 100%, 10%, 0.1); */
}

div.services-container div.service-content:hover {
   box-shadow: 0px 0px 5px 0px var(--stoneit-color-transparent);
   background-color: var(--stoneit-color-light-transparent);
}
div.services-container div.service-content:hover div.service-icon,
div.service-content div.service-icon:hover {
   background-color: var(--stoneit-color-transparent);
   box-shadow: 0px 0px 10px 20px var(--stoneit-color-transparent);
}
div.service-content div.service-icon {
   margin-bottom: 30px;
}
div.service-content div.service-icon img {
   opacity: 80%;
   width: 50%;
   display: block;
   margin-left: auto;
   margin-right: auto;
}
/** END OF SERVICES SECTION**/

/**ABOUT US SECTION**/
div.about-us-content {
   display: flex;
   flex-wrap: wrap;
   justify-content: center;
   padding: 20px 42px;
   /* box-shadow: 0px 0px 40px 10px hsla(0, 0%, 90%, 0.3); */
   /* background-color: hsla(0, 0%, 8%, 1); */
   margin: 20px 0px;
}

div.about-us-content h2 {
   color: var(--light-text);
   font-size: 2.5em;
   font-weight: bold;
}

div.about-us-content div.full-width {
   width: 100%;
   padding: 0px 20px;
}
.quote {
   font-family: 'Inconsolata', Consolas, monospace !important;
   font-size: 1.2em;
}
.quote-title {
   font-size: 1.5em;
   font-weight: bold;
}
div.about-us-content div.column-container {
   display: flex;
   flex-wrap: wrap;
   justify-content: center;
   align-items: center;
   width: 75%;
   margin: 0px 20%;
   box-shadow: 0px 0px 40px 1px hsla(0, 0%, 90%, 0.1);
   background-color: hsla(0, 0%, 8%, 0.2);
   margin: 50px;
}
div.about-us-content div.column {
   width: calc(50% - 4px);
   padding: 10px 20px;
   box-sizing: border-box;
}
div.about-us-content h3 {
   color: var(--light-text);
}
div.about-us-content p {
   font-size: 1.4em;
}
div.about-us-content div.column h3 {
   font-size: 3em;
   font-family: 'Protest Strike', sans-serif;
   /* letter-spacing: 1px; */
   font-weight: lighter;
}
div.about-us-content div.column h3::after {
   content: '➡ ';
   display: inline-block;
   margin: 0px 10px;
   color: var(--stoneit-color);
}
/**END OF ABOUT US SECTION**/

/**CONTACT US SECTION**/
div.contact-container {
   display: flex;
   flex-wrap: wrap;
   justify-content: center;
   padding: 42px;
   margin: 20px 0px;
   /* background-color: red; */
}
div.contact-container div.full-width {
   width: 100%;
}
div.contact-container div.column {
   width: calc(40% - 40px);
   margin: 0px 20px;
   box-shadow: 0px 0px 40px 1px hsla(0, 0%, 90%, 0.1);
   /* background-color: blue; */
}
div.contact-container div.column .question {
   font-weight: bold;
   font-size: 3.2em;
}
div.contact-container div.column .cta {
   font-weight: lighter;
   font-size: 2em;
}

.contact-source {
   margin: 10px;
}
.contact-source:hover a,
.contact-source:hover a svg {
   filter: invert(69%) sepia(97%) saturate(383%) hue-rotate(137deg) brightness(95%) contrast(96%);
}
.contact-source img {
   width: 1em;
}
/**END OF CONTACT US SECTION**/
