@charset "UTF-8";

body { padding-top: 60px; background-color: #171C28;}

* { box-sizing: border-box; letter-spacing: 0.08em; }

*::selection { background-color: #3169ea; color: #dedede; }

a, p, h1, h2, h3, h4, h5, footer { font-family: 'Nunito', Arial, sans-serif;; color: #dedede; }

a { color: #dedede; font-size: inherit; }

a:hover { color: #ffffff80; }

abbr[title], acronym[title] { border-bottom: none; cursor: text; }

img { pointer-events: none; }

.project-cta { margin-top: 30px; }

u.underline { text-decoration-line: underline; text-decoration-color: #3169ea; }

.circle {
  position: absolute;
  border: solid 2px #ffffff30;
  width: 48px;
  aspect-ratio: 1;
  border-radius: 50%;
  pointer-events: none; }

.nda-locked { cursor: not-allowed; }

h2 { font-weight: 200; font-size: 56px; line-height: 64px; }

h2.introduction {
  font-family: 'Zilla Slab', courier, serif;
  font-size: 48px;
  font-weight: 600;
  line-height: 56px;
  padding: 40px 0 72px; }

h2 strong { font-weight: 700; }

.intro {
  height: 20px;
  width: 100%;
  display: inline-block;
  margin-bottom: 25px;
  border: 0;
  padding: 20px 0; }

h1.logo a {
  color: #fff;
  text-align: left;
  font-weight: 600;
  float: left;
  font-size: 16px;
  padding: 4px 0 8px; }

footer { padding-top: 24px; }

.footer-bottom { padding: 24px 0; }

footer p { font-size: 16px; }

footer ul { list-style: none; margin: 0; }

footer ul li { margin-left: 0; }

footer ul li a {
  display: inline-block;
  width: 100%;
  padding: 12px 0; }

.wide-container { position: relative; display: block; }

.work-narrative { margin: 30px 0; }

.space-reducer { margin: 0; }

.space-xxl { padding-top: 48px; padding-bottom: 48px; }

.case-study-intro { font-size: 24px; text-align: center; font-weight: 200; }

.about-pic { width: 100%; margin-bottom: 24px; }

figure.portrait { border-radius: 4px; }

figure.showcase { padding-bottom: 24px; }

.about-text a { font-size: 16px; font-weight: 600; }

a.work-preview { float: left; display: inline-block; }

h2.work-desc {
  font-family: 'Zilla Slab', courier, serif;;
  font-weight: 600;
  text-align: left;
  white-space: nowrap; 
  overflow: hidden;
  text-overflow: ellipsis;
  font-size: 24px; }

.case-study-title { font-weight: 800; font-size: 24px; }

ol { list-style-type: number; color: #cecece; }

ol li { margin-left: 16px; }

ul { color: #cecece; }

ul li { margin-left: 16px; }

ul li p { margin: 0; }

.by-the-numbers { font-size: 56px; font-weight: 200; }

h3.section-intro {
  font-family: 'Zilla Slab', courier, serif;
  font-size: 24px;
  font-weight: 600;
  line-height: 48px; }

h3.bottom-cta { font-weight: 200; font-size: 40px; }

.section-callout-2 {
  background-color: #3169EA; /* For browsers that do not support gradients */
  background-image: linear-gradient(72deg, #153B92, #3169EA);
  border-radius: 8px;
  padding: 24px;
  margin: 16px; }

.section-callout-1 {
  background-color: #31333F;
  border-radius: 8px;
  padding: 24px;
  margin: 16px; }

.figure-spacer { margin-bottom: 24px; }

a.contact-email-cta { font-size: 24px; }

p.duration { font-weight: 400; text-align: left; font-size: 32px; }

.career-step { margin-top: 48px; }

hr.divider { margin-bottom: 24px; }

.material-icons-outlined.md-42 { font-size: 42px; vertical-align: middle; padding-bottom: 8px; }
.material-icons-outlined.md-16 { font-size: 16px; vertical-align: middle; }
.material-icons-outlined.md-20 { font-size: 20px; vertical-align: middle; padding-bottom: 4px; }
.material-icons-outlined.md-12 { font-size: 12px; vertical-align: middle; }

.material-icons.md-36 { font-size: 36px; vertical-align: middle; }
.material-icons.md-21 { font-size: 21px; vertical-align: middle; }
.material-icons.md-18 { font-size: 18px; vertical-align: middle; }
.material-icons.md-16 { font-size: 16px; vertical-align: middle; }
.material-icons.md-12 { font-size: 12px; vertical-align: middle; }

figure p { text-align: center; margin: 10px 0 20px; }

figure img { border-radius: 5px; }

img.port-img {
  display: block;
  margin-left: auto;
  margin-right: auto;
  width: 100%; }

img.nodesc { margin-bottom: 24px; }

.project-meta { padding: 48px 0; }

p.project-descriptor {
  padding-bottom: 8px;
  line-height: 1;
  margin: 0 0 8px; }

.project-tags ul {
  display: flex;
  flex-flow: row wrap;
  list-style: none;
  padding-left: 0;
  margin-left: 0; }

.project-tags li { margin: 4px 4px 4px 0; }

.project-tags p {
  border: 1px solid #dedede40;
  border-radius: 4px;
  font-size: 12px;
  height: 20px;
  line-height: 1rem;
  letter-spacing: 1px;
  padding: 2px 4px;
  text-align: center;
  text-transform: uppercase;
  white-space: nowrap;
  width: auto; }

header.global-nav {
  height: 55px;
  width: 100%;
  margin-bottom: 15px;
  background-color: rgb(23 28 40 / 70%);  /* Semi-transparent background */
  backdrop-filter: blur(10px);  /* Apply blur effect */
  z-index: 9999;
  position: fixed;
  top: 0; }

header.global-nav .nav-header { display: inline; }

header.global-nav .nav-header .logo {
  display: inline-block;
  padding: 12px 10px 10px 0; }

header.global-nav .nav-btn { display: none; }

header.global-nav ul.nav-links {
  margin-left: 16px;
  display: inline;
  float: right; }

header.global-nav ul.nav-links a {
  display: inline-block;
  padding: 16px 0 10px 16px;
  text-decoration: none;
  color: #fff;
  font-size: 16px;
  font-weight: 600; }

header.global-nav ul.nav-links a:hover { color: #ffffff80; font-weight: 900; }

strong.resume {
  display: block;
  padding: 5px 10px;
  border-radius: 4px;
  line-height: 14px;
  color: #fff;
  background-image: linear-gradient(60deg, #171C28, #3169EA); }

header.global-nav ul.nav-links .current { color: #ffffff80; cursor: default; }

header.global-nav ul.nav-links a .current {
  display: inline-block;
  padding: 13px 10px;
  text-decoration: none;
  color: #ffffff80;
  font-size: 16px; }

header.global-nav #nav-check { display: none; }

header.global-nav ul { list-style-type: none; overflow: hidden; }

header.global-nav ul li { float: left; }

header.global-nav .dropdown-content {
  display: none;
  position: absolute;
  background-color: #f9f9f9;
  min-width: 160px;
  box-shadow: 0 8px 16px 0 rgb(0 0 0 / 20%);
  z-index: 1; }

header.global-nav .dropdown:hover .dropdown-content { display: block; right: 0; }


@media (width <=1023px) {
  h2.introduction {
    font-size: 36px;
    line-height: 42px;
    padding: 30px 0; }
  .project-meta { padding: 8px 0 33px;} }


@media (width <=639px) {
  header.global-nav .dropdown:hover .dropdown-content { left: 0; }
  header.global-nav ul li { float: none; }

  header.global-nav .nav-btn {
    display: inline-block;
    position: absolute;
    right: 0;
    top: 5px; }

  header.global-nav .nav-btn label {
    display: inline-block;
    width: 45px;
    height: 45px;
    padding: 11px; }

  header.global-nav .nav-btn label:hover {
    background-color: rgb(0 0 0 / 30%); }

  header.global-nav .nav-btn label span {
    display: block;
    width: 25px;
    height: 10px;
    border-top: 2px solid #999; }

  header.global-nav ul.nav-links {
    position: absolute;
    display: block;
    width: 100%;
    background-color: #fff;
    height: 0;
    transition: all 0.3s ease-in;
    overflow-y: hidden;
    top: 55px;
    left: 0;
    margin: 0; }

  .nav-links li {
    margin: 0; }

  header.global-nav ul.nav-links a {
    display: block;
    color: #3169EA;
    width: 100%;
    padding-right: 24px; }

  header.global-nav ul.nav-links a.current {
    color: #797979; }

  header.global-nav ul.nav-links a:hover {
    color: #000;
    background-color: #f5f5f5; }

  header.global-nav #nav-check:checked + ul.nav-links {
    height: calc(100vh - 50px);
    overflow-y: auto; }
  
  .wide-container { margin-bottom: none; }
  
  h2.footer-sub { line-height: 30px; }

  h2 {
    font-size: 32px;
    line-height: 40px;
    font-weight: 400; }

  h2.introduction {
    font-size: 32px;
    line-height: 40px;
    padding-top: 16px;
    padding-bottom: 24px; }

  .project-meta {
    padding-top: 8px;
    padding-bottom: 32px; }

  h3.bottom-cta {
    font-weight: 400;
    font-size: 28px; }

  h3.section-intro {
    font-size: 24px;
    font-weight: 700; }

  h2.work-desc {
    font-size: 24px;
    padding-top: 12px; }

  a.see-more-cta {
    font-size: 24px;
    float:left; }
  
  a.work-preview img { margin-top:24px; }
  
  img.sm-port-image { margin-top:24px; }
}


.mySlides { display: none; }

img.sliderimage { vertical-align: middle; }

/* Slideshow container */
.slideshow-container {
  /* max-width: 1000px; */
  position: relative;
  margin: auto;
  float: left; }

/* Next & previous buttons */
.prev, .next {
  cursor: pointer;
  position: absolute;
  top: 50%;
  width: auto;
  padding: 16px;
  margin-top: -22px;
  color: white;
  font-weight: bold;
  font-size: 18px;
  transition: 0.6s ease;
  border-radius: 0 3px 3px 0;
  user-select: none;
  background-color: rgb(0 0 0 / 80%); }

/* Position the "next button" to the right */
.next { right: 0; border-radius: 3px 0 0 3px; }

/* On hover, add a black background color with a little bit see-through */
.prev:hover, .next:hover { background-color: rgb(0 0 0 / 80%); }

/* Caption text */
.text {
  color: #171C28;
  font-size: 15px;
  padding: 8px 12px;
  position: absolute;
  bottom: 8px;
  width: 100%;
  text-align: center; }

/* Number text (1/3 etc) */
.numbertext {
  color: #171C28;
  font-size: 12px;
  padding: 8px 12px;
  position: absolute;
  top: 0; }

/* Fading animation */
.fade {
  animation-name: fade;
  animation-duration: 1.5s; }

@keyframes fade {
  from {opacity: .4} 
  to {opacity: 1} }

@keyframes fade {
  from {opacity: .4} 
  to {opacity: 1} }

/* On smaller screens, decrease text size */
@media only screen and (width <= 300px) {
  .prev, .next,.text {font-size: 11px} }

/* ticker tape styles */
.ticker-container {
    width: 100%;
    background-color: 0;
    padding: 8px 0;
    overflow: hidden; }

.ticker {
    display: flex;
    width: 100%;
    justify-content: flex-start;
    align-items: center;
    animation: ticker 20s linear infinite; }

.ticker-content {
    display: flex;
    white-space: nowrap;
    flex-shrink: 0; /* Prevent shrinking */
    font-size: 1rem;
    color: #ffffff80;
    padding-right: 8px; /* Spacing between repeated content */
    font-family: Nunito, Arial, sans-serif; }

@keyframes ticker {
    0% { transform: translateX(0); }

    100% { transform: translateX(-100%); } }

/* float in */
/* The initial state of the content */
.float-in {
    opacity: 0;              /* Start invisible */
    transform: translateY(50px);  /* Start 50px lower */
    animation: floatIn 1s ease-out forwards; /* Apply the animation */ }

/* Keyframes for floating effect */
@keyframes floatIn {
    0% {
        opacity: 0;
        transform: translateY(50px); /* Start off the screen */ }

    100% {
        opacity: 1;
        transform: translateY(0);  /* End in the correct position */ }
}