:root {
  --primary-accent: rgb(100, 151, 196);
  --span-header-background: rgb(43, 43, 43);
}

/* Reset */

*,
*::before,
*::after {
  box-sizing: border-box;
}

body {
  margin: 0;
  font-family: "Roboto", "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-size: 0.875rem;
  line-height: 1.42857;
  color: #333;
}

a {
  color: var(--primary-accent);
  text-decoration: none;
}

a:hover {
  text-decoration: underline;
}

h1, h2, h3, h4, h5, h6 {
  margin-top: 1.25rem;
  margin-bottom: 1.25rem;
}

h1 {
  font-size: 2.25rem;
}

h3 {
  font-size: 1.5rem;
}

ul {
  margin: 0;
  padding: 0;
}

pre {
  display: block;
  padding: 0.594rem;
  margin: 0 0 0.625rem;
  font-size: 0.8125rem;
  line-height: 1.42857143;
  color: #333;
  word-break: break-all;
  word-wrap: break-word;
  white-space: pre-wrap;
  background-color: #f5f5f5;
  border: 1px solid #ccc;
  border-radius: 4px;
}

/* Layout */

.container {
  max-width: 1170px;
  margin: 0 auto;
  padding: 0 0.9375rem;
}

.row {
  display: flex;
  flex-wrap: wrap;
  margin: 0 -0.9375rem;
}

.col-md-6,
.col-md-12 {
  padding: 0 0.9375rem;
}

.col-md-12 {
  width: 100%;
}

@media (min-width: 992px) {
  .col-md-6 {
    width: 50%;
  }
}

@media (max-width: 991px) {
  .col-md-6 {
    width: 100%;
  }
}

/* Utilities */

.pull-left {
  float: left;
}

.pull-right {
  float: right;
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  border: 0;
}

/* Responsive visibility */

.visible-xs,
.visible-sm {
  display: none !important;
}

@media (max-width: 767px) {
  .hidden-xs { display: none !important; }
  .visible-xs { display: inline-block !important; }
}

@media (min-width: 768px) and (max-width: 991px) {
  .hidden-sm { display: none !important; }
  .visible-sm { display: inline-block !important; }
}

/* Navbar */

.navbar-affixed-top {
  top: 0;
  z-index: 1000;
  width: 100%;
}

@supports (position: sticky) {
  .navbar-affixed-top {
    position: sticky;
  }
}

.navbar {
  border: none;
  position: relative;
  min-height: 62px;
  margin-bottom: 0;
  border-bottom: 1px solid transparent;
}

.navbar-default {
  background-color: var(--span-header-background);
  height: 85px;
}

.navbar-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

@media (min-width: 768px) {
  .navbar-header {
    float: left;
  }
}

.navbar-brand {
  padding: 0.9375rem;
  height: 85px;
  display: flex;
  align-items: center;
  margin-left: -0.9375rem;
}

.navbar-brand img {
  max-height: 54.25px;
}

.navbar .navbar-buttons {
  position: absolute;
  right: 0;
  top: 0;
  z-index: 1000;
}

.navbar-toggle {
  display: none;
  padding: 0.5625rem 0.625rem;
  margin-top: 1.25rem;
  margin-right: 0.9375rem;
  background: transparent;
  border: 1px solid #ddd;
  border-radius: 4px;
  cursor: pointer;
}

@media (max-width: 767px) {
  .navbar-toggle {
    display: block;
  }
}

.navbar-toggle:hover,
.navbar-toggle:focus {
  background-color: var(--primary-accent);
}

.navbar-collapse {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  height: 85px;
}

.navbar-collapse.collapse {
  display: flex;
}

@media (max-width: 767px) {
  .navbar-default {
    height: auto;
  }

  .navbar-collapse.collapse {
    display: none;
  }

  .navbar-collapse.collapse.in {
    display: block;
    position: absolute;
    top: 85px;
    left: 0;
    right: 0;
    width: 100vw;
    background-color: var(--span-header-background);
    padding: 0.625rem 0;
    z-index: 999;
    height: fit-content;
  }
}

.nav {
  list-style: none;
}

.navbar-nav {
  display: flex;
  list-style: none;
}

@media (max-width: 767px) {
  .navbar-nav {
    flex-direction: column;
  }
}

.navbar-nav > li > a {
  text-transform: none;
  text-decoration: none;
  font-weight: normal;
  letter-spacing: 0.07rem;
  color: #fff;
  padding: 2rem 0.9375rem;
  display: block;
}

@media (max-width: 767px) {
  .navbar-nav > li > a {
    padding: 0.625rem 0.9375rem;
  }
}

.navbar-nav > li > a:hover,
.navbar-nav > li > a:focus {
  color: var(--primary-accent);
  background-color: var(--span-header-background);
  text-decoration: none;
}

.dropdown {
  list-style: none;
}

/* Button */

.btn-template-main {
  color: var(--primary-accent);
  background-color: transparent;
  border-color: var(--primary-accent);
}

.btn-template-main:hover,
.btn-template-main:focus,
.btn-template-main:active,
.btn-template-main.active {
  color: var(--primary-accent);
  background-color: #e6e6e6;
  border-color: var(--span-header-background);
}

/* Homepage feature cards */

.bar {
  position: relative;
  padding: 3.75rem 0;
}

.bar.background-white {
  background: #fff;
}

.box-simple {
  text-align: center;
  margin-bottom: 2.5rem;
}

.box-simple h3 {
  font-size: 1.125rem;
  line-height: 1.5;
  color: #555555;
  font-weight: 800;
  letter-spacing: 0.08em;
}

.box-simple h3 a {
  color: #555555;
}

.box-simple p {
  color: #999999;
}

/* Footer */

#copyright {
  background: #333;
  color: #ccc;
  padding: 3.125rem 0;
  font-size: 0.75rem;
}

#copyright p {
  margin: 0;
}

@media (max-width: 991px) {
  #copyright p {
    float: none !important;
    text-align: center;
    margin-bottom: 0.625rem;
  }
}
