/* CSS Document */
html, body {
  padding: 0;
  margin: 0;
   font-weight:300;
   font-size:15px;
}
* {
  font-family: 'Montserrat', sans-serif;
  scrollbar-width: thin;
  scrollbar-color: var(--scroll-bar-color) var(--scroll-bar-bg-color);
}
.skipper {
  position: fixed;
  top: -100px;
  left: 10px;
  background: #000;
  padding: 3px 10px;
  color: #fff !important;
  z-index: 10000;
}
.skipper:active, .skipper:focus {
  top: 10px;
}
.skipper.accessibility{left:140px;}
a {
  text-decoration: none;
  transition: all .4s;
}
img {
  max-width: 100%;
}
/* HEADER */
header {
  height: 145px;
  background: #1f2445;
  transition: all 1s;
  position: relative;
  text-align: center;
  padding: 0 20px;
}
/* HEADER ANIMATION */
header #navHolderHolder {
  display: block;
  padding-top: 3px;
  vertical-align: top;
  margin: auto;
  text-align: center;
}
header #navHolder {
  display: flex;
  justify-content: center;
  /* max-width: 0; */
  transition: max-width .6s;
  overflow: hidden;
  margin: auto;
}
header.navOpen #navHolder, header:focus-within #navHolder {
  max-width: 380px;
}
.home header.navOpen #navHolder {
  max-width: 0 !important;
}
.home #logo {
  cursor: default;
}
header nav {
  display: inline-block;
  font-weight: 600;
  white-space: nowrap;
  text-align: center;
}
/* end header animation block */
header nav a {
  color: #9f9c9c;
  border-right: 1px solid #8f8c8c;
  padding: 0 6px;
  font-size: 12px;
}
header nav a.currentPage {
  color: #1f2445;
}
header nav a:first-child {
  padding-left: 0;
}
header nav a:last-child {
  border-right: none;
  padding-right: 0;
}
header #logoHolder {
  position: relative;
  width: 260px;
  height: 145px;
  display: inline-block;
}
#logo {
  width: 90%;
  max-width: 220px;
  position: absolute;
  left: 50%;
  top: 45px;
  transform: translateX(-50%);
  cursor: pointer;
}
main {
  width: 90%;
  min-height: 300px;
  max-width: 900px;
  text-align: center;
  color: #3d403e; /* 6e7270 */
  margin: 70px auto;
  line-height: 1.5;
}
.cycle-slideshow {
  position: absolute;
  top: 0px;
  left: 0px;
  width: calc(100% - 385px);
  height: 100%;
  padding-bottom: 0px;
  box-sizing: border-box;
  pointer-events: none;
  z-index: 2;
}
h1 {
  color: #3d403e;
  font-weight: 600;
  font-style: italic;
  font-size: 15px;
}
.projects h1 {
  font-style: normal;
  text-transform: uppercase;
   margin-bottom: 16px;
}
.project-detail h1{font-style: normal;font-weight:500;}
body.projects main{max-width:750px;}
strong{font-weight: 600;}
body.projects .project a{font-weight:600;color:#1f2445;}
h2 {
  font-weight: 500;
  margin-top: 15px;
  font-size: 15px;
  margin-bottom: 0;
}
p, main a {
  font-size: 15px;
  font-weight: 300;
  letter-spacing: .01em;
  color: #3d403e;
}
a:hover {
  opacity: .5;
}
.project-image a:hover{opacity:1;}
a.maplink {
  color: #1f2445;
  font-weight: 600;
}
.home .cycle-slideshow {
  position: absolute;
  top: 0px;
  left: 0px;
  width: 100%;
  height: 100vh;
  height: 100svh;
  padding-bottom: 0px;
  box-sizing: border-box;
  pointer-events: none;
  z-index: 2;
}
.slide-wrapper {
  position: relative;
  width: 100%;
  top: 0px;
  left: 0px;
  height: 100%;
  box-sizing: border-box;
  transition: height 1s;
}
.home #background::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  height: 40vh;
  width: 100%;
  background: rgb(0, 0, 0);
  background: linear-gradient(0deg, rgba(0, 0, 0, 0) 0%, #000000 100%);
  mix-blend-mode: multiply;
  z-index: 999998;
  transition: background 1s;
}
footer {
  text-align: center;
  z-index: 10;
  position: relative;
  font-size: 12px;
  color: #5a5959;
  padding-bottom: 100px;
}
footer .logo {
  max-width: 70px;
  margin: 50px auto 25px auto;
}
footer a, footer span {
  line-height: 1;
  padding: 0 6px;
  margin: 0;
  border-right: 1px solid #3d403e;
  color: #3d403e;
}
footer a:hover {
  opacity: .7;
}
footer nav a {
  font-weight: 600;
}
footer nav a.currentPage {
  color: #1f2445;
   font-weight: 700;
}
footer #copyright {
  font-size: 11px;
}
footer #copyright a:last-child {
  display: block;
}
/* HOME */
.home header {
  background-color: transparent;
  height: 280px;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 10;
  padding: 0;
}
.home #blueBar {
  background: #1f2445;
  position: absolute;
  top: 0;
  left: 0;
  height: 8px;
  width: 100%;
  z-index: 11;
}
.home header nav {
  display: none;
}
.home header #logoHolder {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  background: #00000055;
  width: 280px;
  height: 198px;
}
.home header #logoHolder #logo {
  top: 80px;
}
.home footer {
  position: absolute;
  width: 100%;
  bottom: 0;
  left: 0;
  height: auto;
  color: #fff;
  background: #000;
  box-sizing: border-box;
  padding: 10px 10px 15px 10px;
  text-align: center;
  line-height: 1.8;
}
.home footer .logo {
  display: none;
}
.home footer a {
  font-weight: 600;
  border-color: #fff;
  color: #fff;
  display: inline-block;
}
.home footer #copyright a, .home footer #copyright span {
  color: #ffffff88;
  border-color: #ffffff88;
  font-weight: 300;
}
footer nav a:last-child, footer #copyright a:last-child, footer #copyright a:nth-child(2) {
  border-color: transparent;
}
.home footer nav a:first-child {
  display: none;
}
.home footer #copyright {
  font-size: 10px;
  color: #ffffff88;
  padding-top: 2px;
}
.home footer #copyright a {
  font-size: 10px;
  color: #ffffff88;
}
.home footer #copyright a:hover, .home footer #copyright a:active, .home footer #copyright a:focus {
  color: #ffffff;
}
/* PROJECTS */
.project {
  max-width: 1100px;
  margin: 0 auto 60px auto;
}
.project p {
  margin-top: 20px;
  line-height: 180%;
  letter-spacing: 1px;
}
.project-image {
  padding-bottom: 62.5%;
  position: relative;
}
.project-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  position: absolute;
  left: 0;
  top: 0;
}
.project-detail h2 {
  letter-spacing: 1px;
  font-size: 15px;
  margin-top: -15px;
}
.project-detail main {
  width: 100%;
  max-width: 100%;
}
@media screen and (min-width:600px) {
  footer #copyright a:nth-child(2) {
    border-color: #00000088;
  }
  .home footer #copyright a:nth-child(2) {
    border-color: #ffffff88;
  }
  footer #copyright a:last-child {
    display: inline-block;
  }
  footer a, footer span {
    padding: 0 12px;
  }
   footer #copyright a, footer #copyright span{padding:0 7px;}
}
@media screen and (min-width:700px) {
  /* HEADER ANIMATION */
  header nav a {
    font-size: 12px;
    padding: 0 10px;
  }
  header nav a.currentPage {
    color: #ffffff;
  }
   header #logoHolder{
   margin-left:-60px;
   }
  header #navHolderHolder {
    display: inline-block;
    padding-top: 57px;
    vertical-align: top;
    margin: 0 0 0 -60px;
    text-align: right;
  }
  header #navHolder {
    display: flex;
    justify-content: flex-end;
    max-width: 0;
    transition: max-width .6s;
    overflow: hidden;
  }
  header.navOpen #navHolder, header:focus-within #navHolder {
    max-width: 400px;
  }
  .home header.navOpen #navHolder {
    max-width: 0 !important;
  }
  .home #logo {
    cursor: default;
  }
   .home header #logoHolder{
      margin:0;
   }
  header nav {
    display: inline-block;
    font-weight: 600;
    white-space: nowrap;
    text-align: right;
    padding-left: 60px;
  }
  /* end header animation block */
}
@media screen and (min-width:900px) {
  .home footer {
    height: 35px;
    text-align: inherit;
    line-height: 1;
    padding: 10px 50px;
  }
  .home footer nav {
    float: left;
    font-weight: 600;
  }
  .home footer #copyright {
    float: right;
    font-weight: 300;
  }
  .home footer a {
    display: inline-block;
  }
}