@import url('https://fonts.googleapis.com/css2?family=Open+Sans:wght@400;600;700&family=Poppins:wght@400;500;600&family=JetBrains+Mono&display=swap');

body {
  color: #221f1f;
  font-family: 'Open Sans', sans-serif;
}

h1 {
 font-size: 2.2em;
}

h2 {
 font-size: 1.5em;
}

h3 {
 font-size: 1.2em;
}

h4 {
 font-size: 1.0em;
}

h5 {
 font-size: 0.9em;
}


.nav {
 font-family: 'Poppins', sans-serif;
}

.header-style, h1, h2, h3, h4, h5, h6 {
    font-family: 'Poppins', sans-serif;
    font-weight: 500;
}


.bd-toc .tocsection {
    padding: 4.0rem 0 .5rem 1rem !important; /* Right-side bar top padding to align with the main content title. */
}


#main-content {
    margin-top: 1rem !important; /* Main content pushed down to align with the site title below logo on the left-side bar. If you change this you must change the .bd-toc .tocsection padding from 7.8rem. */
}


.admonition.note .admonition-title {
    background-color: #fff0ec;
    letter-spacing: 0.045rem;
}

nav.bd-links li.toctree-l1 {
    line-height: 1.45;
}

.card {
  box-shadow: 0 .5rem 1rem rgba(0,0,0,.15)!important;
  transition: all 0.3s ease-in-out!important;
}

.card-title {
    margin-bottom: 0.75rem;
    margin-top: 0.05rem;
}

.card-footer {
    background-image: url("images/test-card-footer.png");
}

@media (min-width: 576px) {
  .card-deck .card {
    margin-bottom: 15px;
    transition: all 0.3s ease-in-out!important;
  }
}

@media (min-width: 1200px) {
  .container, .container-lg, .container-md, .container sm, .container-xl {
      max-width: 1400px;
  }
}

nav.bd-links p.caption {
    letter-spacing: 0.1em;
    font-family: 'Poppins', sans-serif;
}

toc-h1, .toc-h2, .toc-h3, .toc-h4 {
    line-height: 1.45;
    margin-bottom: 0.5em;
}

@media only screen and (min-width: 768px) {
       #navbar-toggler {
           display: none;
       }
}

div.navbar_extra_footer {
    display: none;
}

div.dropdown-buttons-trigger {
  display: none;
}

a.full-screen-button {
    display: none;
}

pre {
    line-height: 150%;
    background-color: #f1f3f4; /* #ffc1070d; */
    padding: 22px;
    color: #37474f;
    font-size: 95%;
    border: none;
    box-shadow: none;
    /* font-family: 'JetBrains Mono', sans-serif; JetBrains messes up code syntax and directory structure */
}

.header-style, h1, h2, h3, h4, h5, h6 {
    line-height: 1.35;
}

nav.bd-links li.toctree-l1, nav.bd-links li.toctree-l2, nav.bd-links li.toctree-l3, nav.bd-links li.toctree-l4, nav.bd-links li.toctree-l5 {
    margin-bottom: 0.35em;
    position: relative;
}

.bd-sidebar nav ul.nav a:hover, .bd-sidebar nav ul.nav li.active>a, .bd-sidebar nav ul.nav li.active>a:hover {
    color: #221f1f;
}

.bd-sidebar nav ul.nav li.active>a {
    font-weight: 600;
}

.prev-next-bottom {
    height: 3em;
    font-family: 'Poppins', sans-serif;
    font-weight: 500;
}

blockquote {
    margin: 1rem 0 1rem;
    border-left: 0px solid #ccc;
    padding: .1em .1em;
}

main.bd-content #main-content div.section ul p, main.bd-content #main-content div.section ol p {
    margin-bottom: .5rem;
}

table td, .table th {
    padding: .75rem;
    vertical-align: top;
    border-top: 1px solid #dee2e6;
    border-bottom: 1px solid #dee2e6;
    border-right: 1px solid #dee2e6;
    border-left: 1px solid #dee2e6;
}

.admonition .admonition-title {
 font-family: 'Poppins', sans-serif;
}

.footer {
    font-size: .8em;
}

/* timeline stuff */

/* Timeline Container */
.timeline {
  background: var(--primary-color);
  margin: 20px auto;
  padding: 20px;
}

/* Outer Layer with the timeline border */
.timeline-outer {
  border-left: 2px solid #333;
}

/* Card container */
.timeline-card {
  position: relative;
  margin: 0 0 20px 20px;
  padding: 10px;
  /* background: #333; */
  color: gray;
  border-radius: 8px;
  /* max-width: 400px; */
}

/* Information about the timeline */
.timeline-info {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

/* Title of the card */
.timeline-title {
  color: #f05a29;
  position: relative;
}

/* Timeline dot  */
.timeline-title::before {
  content: "";
  position: absolute;
  width: 10px;
  /* height: 10px; */
  background: white;
  border-radius: 999px;
  left: -39px;
  border: 8px solid #f05a29;
}

timeline-h3:before {
    display: block;
    content: "";
    height: 80px;
    /* margin: -80px 0 0; */
}

timeline-h3 {
    font-size: 1.2em;
    font-family: 'Poppins', sans-serif;
    font-weight: 500;
}

/* -------------------------------------------------------------------------
  VERTICAL STEPPERS
-------------------------------------------------------------------------- */

/* Steps */
.step {
  position: relative;
  min-height: 1em;
  /* color: orangered; */
}
.step + .step {
  margin-top: 1.5em
}
.step > div:first-child {
  position: static;
  height: 0;
}
.step > div:not(:first-child) {
  margin-left: 1.5em;
  padding-left: 1em;
}
.step.step-active {
  color: #4285f4
}
.step.step-active .circle {
  background-color: #4285f4;
}

/* Circle */
.circle {
  background: #f05a29;
  position: relative;
  width: 1.5em;
  height: 1.5em;
  line-height: 1.5em;
  border-radius: 100%;
  color: #fff;
  text-align: center;
  box-shadow: 0 0 0 3px #fff;
}

/* Vertical Line */
.circle:after {
  content: ' ';
  position: absolute;
  display: block;
  top: 1px;
  right: 50%;
  bottom: 1px;
  left: 50%;
  height: 100%;
  width: 1px;
  transform: scale(1, 2);
  transform-origin: 50% -100%;
  background-color: rgba(0, 0, 0, 0.25);
  z-index: -1;
}
.step:last-child .circle:after {
  display: none
}

/* Stepper Titles */
.step-title {
  line-height: 1.5em;
  /* font-size: 1.2em; */
  font-family: 'Poppins', sans-serif;
  font-weight: 500;
}
.step-caption {
  font-size: 0.9em;
  font-family: 'Open Sans', sans-serif;
}

nav.bd-links p.caption {
    color: rgba(255, 90, 49, 1); /* left sidebar caption color */
}
