:root {
    --main-bg-col: #ffffff;
    --second-bg-col: #ffffff;
    --primary-col: #030304;
    --accent-col-1: #0FB7FF;
    --accent-col-2: #F00FFF;
    --accent-col-3: #1b1b1b;
    --caption: #bbbbbb;
    --off-white: #f8f8f8;
    --main-font: soleil,sans-serif;
    --logo-font: font-family: apparat, sans-serif;
    --font-bold: 700;  
    --font-extra-bold: 900; 
    --font-regular: 400;
    --font-style: normal; 
    --body-ft-size: 0.8rem;
}
body {
    background: var(--main-bg-col);
}
body * {
  z-index: 1;
}
h1:hover, h2:hover, h3:hover, p:hover, span:hover {
  cursor: default;
}
.logo:hover, .logo span:hover {
  cursor: pointer;
  opacity: 0.8;
}
.logo .l-top {
    color: var(--accent-col-3);
    z-index: 3;
    font-family: var(--logo-font);
    font-weight: var(--font-extra-bold);
    font-style: var(--font-style);
    text-transform: uppercase;
}
nav * {
    font-family: var(--main-font);
    font-weight: var(--font-bold);
    font-style: var(--font-style);
}
.navbar {
  transition: background-color 0.5s ease;
}
.nav-link {
  color: black !important;
}
.nav-item {
  display: inline-block;
  position: relative;
}
.nav-item:after {
  content: '';
  position: absolute;
  width: 100%;
  transform: scaleX(0);
  height: 2px;
  bottom: 0;
  left: 0;
  background-color: var(--accent-col-3);
  transform-origin: bottom right;
  transition: transform 0.25s ease-out;
}
.nav-item:hover:after {
  transform: scaleX(1);
  transform-origin: bottom left;
}
.nav-item:hover a {
  color: var(--accent-col-3);
}
.navbar-toggler:focus {
  box-shadow: none !important;
}
.nav-item a:hover {
  cursor: pointer;
}
.text-blue {
    color: var(--primary-col);
}
.text-white {
  color: var(--off-white);
}
.txt-header {
    font-family: var(--main-font);
    font-weight: var(--font-bold);
    font-style: var(--font-style);
}
.wrk-cta {
    background-color: var(--accent-col-3);
    font-family: var(--main-font);
    font-weight: var(--font-regular);
    font-style: var(--font-style);
    font-size: var(--body-ft-size);
    outline: 0;
    grid-gap: 8px;
    align-items: center;
    background: 0 0;
    background-color: var(--accent-col-3);
    border: 1px solid var(--accent-col-3);
    border-radius: 4px;
    cursor: pointer;
    display: inline-flex;
    flex-shrink: 0;
    gap: 8px;
    justify-content: center;
    line-height: 1.5;
    overflow: hidden;
    padding: 12px 16px;
    text-decoration: none;
    text-overflow: ellipsis;
    transition: all .14s ease-out;
    white-space: nowrap;
    }
.wrk-cta:hover {
    box-shadow: 4px 4px 0 var(--accent-col-2);
    transform: translate(-4px,-4px);
    color: white;
    background-color: var(--accent-col-1);
    border: 1px solid var(--accent-col-1);
}
.wrk-cta:focus-visible{
    outline-offset: 1px;
}
.hero-txt {
    font-size: 4rem;
}
.h4-header {
    font-family: var(--main-font);
    font-weight: var(--font-bold);
    font-style: var(--font-style);
}
.sub-hero-txt {
  font-size: 3rem;
}
.caption {
  font-family: var(--main-font);
  font-weight: var(--font-regular);
  font-size: 0.75rem !important;
  color: var(--caption);
}
.desc-border {
  border-bottom: 1px solid #eeeeee;
}
.txt-body {
  font-family: var(--main-font);
  font-weight: var(--font-regular);
  font-style: var(--font-style);
  font-size: var(--body-ft-size);
}
.second-bg {
  background-color: var(--second-bg-col);
}
img.vertical-move {
  -webkit-animation: mover .5s infinite  alternate;
  animation: mover .5s infinite  alternate;
}
img.vertical-move {
  -webkit-animation: mover .5s infinite  alternate;
  animation: mover .5s infinite  alternate;
}
@-webkit-keyframes mover {
  0% { transform: translateY(0); }
  100% { transform: translateY(-10px); }
}
@keyframes mover {
  0% { transform: translateY(0); }
  100% { transform: translateY(-10px); }
}

.off-white {
    color: var(--off-white);
}
.bg-off-w {
    background: var(--off-white);
}
.work-icon-web {
    max-width: 50px;
}
.work-icon-mob {
    max-width: 24px;
}
.main-content {
    min-height: 55vh;
}
.sub-main-content {
  min-height: 35vh;
}
.scroll-down {
    width: 3rem;
}
.origin{
  text-decoration:none;
  font-size:45px;
}
.bidMob-desktop {
  margin-left: -10rem;
}
.py-6 {
  padding-top:6rem;
  padding-bottom:6rem;
}
#contactAlert {
  display: none;
  position: absolute;
  width: 300px;
  max-width: 90%;
  text-align: center;
  background-color: rgb(0 0 0 / 50%);
  border-radius: 10px;
  padding: 2px;
  font-size: 85%;
  font-style: italic;
  right: 5%;
  color: var(--second-bg-col);
}
.mock-ups img {
  max-height: 650px;
  max-width: 100%;
}
.cursor {
  position: fixed;
  border-radius: 50%;
  transform: translateX(-50%) translateY(-50%);
  pointer-events: none;
  left: -100px;
  top: 50%;
  /*mix-blend-mode: difference;*/
  background-color: var(--accent-col-3);
  z-index: 0 !important;
  height: 50px;
  width: 50px;
  transition: all 150ms ease-out;
  opacity: 0.2;
}
.hp-tile img {
  transition: opacity 1s ease-out;
}
.hp-tile:hover .work-desc {
  opacity: 1;
}
.morerk-hover:hover {
  opacity: 0.75;
}
.work-desc {
  top: 0;
  background: rgba(255, 255, 255, 0.9);
  height: 100%;
  width: 98%;
  opacity: 0;
  transition: opacity 0.5s ease-in;
}
.work-desc > div{
  height: 100%;
}
.footer {
  font-size: 0.8rem;
  color: var(--accent-col-3);
}
.reveal {
  position: relative;
  transform: translateY(150px);
  opacity: 0;
  transition: 1s all ease;
}
.reveal.active {
  transform: translateY(0);
  opacity: 1;
}
@media screen and (max-width: 576px) {
    .hero-txt {
        font-size: 3rem;
    }
    .scroll-down {
        width: 3rem;
    }
}