@charset "UTF-8";
/*
Theme Name: trcc-2026
*/
/* Suisse Intl */
@font-face {
  font-family: "SuisseIntl";
  src: url("./fonts/SuisseIntl-Regular-WebXL.woff2") format("woff2");
  font-weight: normal;
  font-style: normal;
}
@font-face {
  font-family: "SuisseIntl";
  src: url("./fonts/SuisseIntl-RegularItalic-WebS.woff2") format("woff2");
  font-weight: normal;
  font-style: italic;
}
@font-face {
  font-family: "PlexMono";
  src: url("./fonts/ibmPlexMono.woff") format("woff");
  font-weight: normal;
}
body {
  background: #f1f1f1;
  color: #000;
  overflow-x: hidden;
}

img {
  margin: 0;
  padding: 0;
  width: 100%;
}

* {
  font-family: "SuisseIntl", helvetica, arial, sans-serif;
}

a {
  cursor: pointer;
}

img {
  height: auto;
}

.bg-paper {
  background-color: var(--paper);
}

.color-primary {
  color: #f00;
}

.margin-section {
  margin-top: 150px;
  margin-bottom: 150px;
}

/* ========================================= containers ========================================= */
.container-wide {
  width: 100%;
  max-width: 1400px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
}

.container-normal {
  width: 100%;
  max-width: 1200px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
}

@media (max-width: 1600px) {
  .container-normal {
    max-width: 1200px;
  }
}
@media (max-width: 1400px) {
  .container-normal {
    max-width: 1100px;
  }
}
.container-fluid,
.container {
  background-color: transparent;
}

.container-narrow {
  width: 100%;
  max-width: 750px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
}

/* ========================================= Typo ========================================= */
body,
html {
  margin: 0;
  padding: 0;
  font-size: 18px;
  line-height: 1.3;
  letter-spacing: -0.015em;
}

.light {
  font-weight: normal;
}

.text-meta {
  font-size: 13px !important;
  line-height: 1.2;
}

b {
  font-weight: normal;
}

p {
  margin-top: 0px;
  margin-bottom: 20px;
  color: #000;
}

h1,
h2 {
  line-height: 100%;
}

h1,
h2,
h3,
h4,
h5 {
  margin-top: 0px;
  margin-bottom: 20px;
  color: #000;
  font-weight: normal;
}

#postTitle {
  line-height: 105%;
  cursor: pointer;
}

@media (min-width: 1200px) {
  #postTitle {
    font-size: 80px;
  }
}
.wp-block-quote cite {
  line-height: 105% !important;
}

/* ========================================= Blog ========================================= */
#blog-ui-left {
  flex-basis: 66.666%;
}

.blog-catlist {
  display: flex;
  flex-wrap: wrap;
  list-style: none;
  margin-bottom: 100px;
  flex-wrap: wrap;
  width: 100%;
  padding: 0;
}

.blogpost {
  position: relative;
}

.blogpost .excerpt {
  color: #aaa;
  transition: all 0.4s ease;
  font-size: 14px;
  margin-bottom: 10px;
}

.blogpost:hover .excerpt {
  color: #000;
}

.blogpost .title {
  font-size: calc(16px + 0.4vw);
  line-height: 115%;
  margin-bottom: 10px;
  color: black;
  margin-top: 10px;
  display: block;
  font-weight: normal;
}

.blogpost .excerpt {
  line-height: 115%;
}

.blogpost .categories {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  color: #000;
}

.blogpost .categories li a {
  background: #f1f1f1;
  transition: all 0.4s ease;
  padding: 3px 8px;
  margin-right: 10px;
  color: #aaaaaa;
  border-radius: 12px;
  font-size: 14px;
}

.blogpost .categories li a:hover {
  background: #aaa;
  color: black;
}

.blogpost .thumb {
  position: relative;
  overflow: hidden;
  display: block;
}

.blogpost .thumb img {
  transition: all 0.4s ease;
}

.blogpost .thumb .overlay {
  transition: all 0.4s ease;
  display: none;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.blogpost .thumb:hover img.thumbnail {
  transform: scale(1.1);
}

.blogpost .thumb:hover .overlay {
  opacity: 0;
}

.blog {
  display: flex;
  flex-wrap: wrap;
  margin: 15px;
}

.excerpt p {
  line-height: 120%;
}

.blog-ui {
  display: flex;
}

.blog-ui div {
  flex-basis: 50%;
}

.catlist {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
}

@media (max-width: 600px) {
  .catlist {
    padding-top: 50px;
    padding-bottom: 50px;
  }
}
@media (min-width: 600px) {
  .catlist {
    padding-top: 75px;
    padding-bottom: 100px;
  }
}
.catlist .cat {
  display: block;
  padding: 5px;
  margin: 10px;
}

.current-category {
  color: #f54123;
}

.userPortrait {
  width: 100px;
  border-radius: 100%;
}

/* ========================================= Borlabs ========================================= */
._brlbs-caption p {
  color: #f1f1f1;
}

._brlbs-embed {
  width: 100%;
}

/* ========================================= Pills ========================================= */
.pill {
  color: #000;
  display: inline-block;
  border: none;
  padding: 5px 15px;
  border-radius: 30px;
  margin-right: 10px;
  margin-bottom: 10px;
  background: #f1f1f1;
}

@media (max-width: 768px) {
  .pill {
    padding: 2px 10px;
    margin-right: 10px;
    margin-bottom: 10px;
  }
}
.pill * {
  list-style: none;
}

.pill:hover {
  color: #000;
  background: #aaa;
}

.pill:hover.active {
  color: #f1f1f1 !important;
  background: #000;
}

.pill.active {
  font-weight: normal;
  color: #f1f1f1 !important;
  background: #000;
}

.scrollOnClick {
  cursor: pointer;
}

/* ========================================= resources ========================================= */
#resources a {
  color: #000;
}

.resource-single:hover {
  color: #f00;
}

.resource-single:hover .resource-separator {
  border-bottom: 1px solid #000;
}

.resource-separator {
  border-bottom: 1px solid #000;
  padding: 5px 0;
}

.term-separator {
  border-bottom: 1px solid #000;
}

.resourceDetails {
  display: none;
}

.resource-single.active .resourceDetails {
  display: block;
}

.resourceHasContent {
  cursor: pointer;
}

.termNav {
  display: flex;
  flex-wrap: wrap;
}

.termNav a {
  padding: 5px 15px 5px 15px !important;
  margin: 0 0 5px 5px;
  border-radius: 25px;
  color: #000;
  background: #f1f1f1;
}

.termNav a:hover {
  color: #000;
}

/*========================================== Footer ========================================== */
footer div {
  text-align: center;
}

footer div * {
  width: auto;
}

footer div button {
  cursor: pointer;
}

footer {
  line-height: 1.7;
}

#colophon {
  border-top: 1px solid #000;
  background: #000;
}

#colophon a::after {
  content: "";
}

#colophon * {
  color: #f1f1f1;
  text-align: left !important;
  list-style: none;
}

#colophon a:hover {
  color: yellow;
}

#colophon li,
#colophon a {
  padding: 0;
}

#colophon ul,
#colophon h2 {
  padding: 0;
}

#colophon h2 {
  margin-bottom: 10px;
  font-weight: normal;
}

/* ========================================= Video Player ========================================= */
.player {
  position: relative;
  overflow: hidden;
}

.player,
.player * {
  border: 0;
}

/* This css is only applied when fullscreen is active. */
.player:fullscreen {
  max-width: none;
  width: 100%;
}

.player:-webkit-full-screen {
  max-width: none;
  width: 100%;
}

.player__video {
  width: 100%;
}

.player__button {
  top: 0;
  left: 0;
  position: absolute;
  background: none;
  border: 0 !important;
  width: 100%;
  height: 100%;
  font-size: 90px;
  line-height: 1;
  color: #f1f1f1;
  cursor: pointer;
  outline: 0;
}

.player__button:hover {
  background: transparent;
  border: 0 !important;
}

.player__button:focus {
  border: 0;
}

.player__slider {
  width: 10px;
  height: 30px;
}

.player__controls {
  display: flex;
  position: absolute;
  bottom: 0;
  width: 100%;
  transform: translateY(100%) translateY(-5px);
  flex-wrap: wrap;
  background: rgba(0, 0, 0, 0.1);
}

.player:hover .player__controls {
  transform: translateY(0);
}

.player:hover .progress {
  height: 30px;
}

.player__controls > * {
  flex: 1;
}

.progress {
  margin: 0;
  position: relative;
  display: flex;
  flex-basis: 100%;
  height: 0px;
  background: rgba(0, 0, 0, 0.5);
  cursor: ew-resize;
}

.progress__filled {
  width: 0;
  background: #000;
  flex: 0;
  flex-basis: 0%;
}

.video-player {
  display: grid;
  grid-template-columns: 2fr 1fr;
}

.toc {
  padding: 15px;
}

video {
  width: 100%;
}

/* ========================================= Video Header ========================================= */
#videoHeader {
  position: relative;
  background-color: #000;
  height: 90vh;
  min-height: 25rem;
  width: 100%;
  overflow: hidden;
}

@media (max-width: 786px) {
  #videoHeader {
    height: 60vh;
  }
}
#videoHeader video {
  position: absolute;
  top: 50%;
  left: 50%;
  min-width: 100%;
  min-height: 100%;
  width: auto;
  height: auto;
  z-index: 0;
  -ms-transform: translateX(-50%) translateY(-50%);
  -moz-transform: translateX(-50%) translateY(-50%);
  -webkit-transform: translateX(-50%) translateY(-50%);
  transform: translateX(-50%) translateY(-50%);
}

#videoHeader .container {
  position: relative;
  z-index: 2;
}

#videoHeader .overlay {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  background-color: #000;
  opacity: 0;
  z-index: 1;
}

@media (pointer: coarse) and (hover: none) {
  #videoHeader {
    background: black no-repeat center center scroll;
  }
  #videoHeader video {
    display: none;
  }
}
body {
  background: #ffffff;
}

#load-more {
  cursor: pointer;
}

#hello {
  border-bottom: 1px solid #000;
}

.post-edit-link {
  color: #f00;
}

.wp-block-image img {
  height: auto;
}

.bgimage {
  width: 100%;
  display: flex;
  align-items: center;
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  background-attachment: fixed;
}

.bgimage h1 {
  padding: 15px;
  font-size: calc(16px + 3vw);
  line-height: 100%;
  width: 100%;
  text-align: center;
  color: #f1f1f1;
}

.sectionhead {
  font-size: calc(16px + 3vw);
  text-align: center;
  margin: 50px 0;
}

figcaption {
  text-align: center;
}

.work-in-progress-banner {
  background: rgba(0, 0, 0, 0.6);
  width: 100%;
  height: 100vh;
  padding: 15px;
  display: flex;
  justify-content: center;
  align-items: center;
  position: fixed;
  top: 0;
  z-index: 9999999;
  left: 0;
  cursor: pointer;
}

.work-in-progress-banner p {
  max-width: 600px;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  background: #ff0;
  padding: 0;
  margin: 0;
  color: black;
  padding: 30px;
  margin: 15px;
}

.table th,
.table td {
  border: 1px solid #000 !important;
}

.border-1 img {
  border: 1px solid #000;
}

.pagination ul {
  padding: 0;
  display: flex;
  list-style: none;
  flex-wrap: wrap;
}

.pagination ul li {
  padding-right: 25px;
  display: block;
}

.pagination ul li .inactive {
  color: #bbb;
}

.pagination ul li .current {
  color: #f00;
}

.pagination ul li a:hover {
  color: #00f;
}

#meetup-grid .meetup-row {
  display: grid;
  grid-template-columns: 3fr 1fr 1fr;
  border-bottom: 1px solid #bbb;
}

#meetup-grid .meetup-past * {
  color: #bbb;
}

h4 {
  margin: 0;
}

.patreon-valid-patron-message {
  display: none;
}

.comments-area hr {
  background: #bbb;
}

#reply-title {
  margin-top: 0;
}

textarea#comment {
  border: 0;
  background: #f1f1f1;
  resize: none;
  width: 100%;
}

#block-how-it-works {
  display: grid;
  grid-template-columns: 1fr 1fr;
}

@media (max-width: 1200px) {
  #block-how-it-works {
    grid-template-columns: 1fr;
  }
}
#block-how-it-works #block-how-it-works-left {
  padding: 30px;
  background: #f00;
}

#block-how-it-works #block-how-it-works-left p {
  color: #f1f1f1;
}

#block-how-it-works #block-how-it-works-left .how-it-works-link {
  color: #000;
}

#block-how-it-works #block-how-it-works-left .how-it-works-link::before {
  color: #000;
}

#block-how-it-works #block-how-it-works-right {
  background: #000;
}

#meetups-overvue a,
#meetups-overvue-past a {
  color: #000;
}

main {
  min-height: 90vh;
}

.copyBtn {
  position: absolute;
  top: 10px;
  right: 10px;
  padding: 0px 10px;
  background: #000;
  color: #f1f1f1;
  cursor: pointer;
}

.wp-block-code {
  position: relative;
}

::-moz-selection {
  text-shadow: none;
  color: #000;
  background: #ff0;
}

::selection {
  text-shadow: none;
  color: #000;
  background: #ff0;
}

.trcc-pill {
  background: #ff0;
  color: #000 !important;
  padding: 5px 10px;
  border-radius: 15px;
  font-size: 12px;
  display: inline-block;
}

.has-yellow-background-color {
  background: yellow;
}

.woocommerce .col-1,
.woocommerce .col-2 {
  max-width: none;
}

.woocommerce-billing-fields .form-row,
.woocommerce-shipping-fields .form-row,
.woocommerce form .form-row {
  display: block;
}

.woocommerce .col2-set .col-1,
.woocommerce-page .col2-set .col-1,
.woocommerce .col2-set .col-2,
.woocommerce-page .col2-set .col-2 {
  max-width: unset;
}

h5.blogpost-meta a {
  color: #aaa;
}

.headline-start {
  margin-top: 0;
  font-size: calc(30px + 1vw);
}

.button-small {
  font-size: 14px;
  padding: 4px 10px;
  background: #ddd;
  color: #000;
  transition: all 0.4s ease;
}

.button-small:hover {
  background: #000;
  color: #f1f1f1;
}

.text-manuskript {
  font-family: "PlexMono", courier, monospace;
  text-transform: none;
  font-size: 16px !important;
}

.course-locked a {
  pointer-events: none;
}

.list-lessons {
  margin: 0;
  padding: 0;
  list-style: none;
}

.list-lessons li {
  width: 100%;
  display: block;
}

.list-lessons li a {
  color: #aaa;
  display: block;
  border-bottom: 1px dotted #aaa;
  width: 100%;
}

.list-lessons li a:hover {
  color: black;
  border-bottom: 1px dotted black;
}

.list-lessons .active a {
  color: red;
}

.wp-block-code.language-javascript {
  border: 1px solid red !important;
}

.wp-block-code.language-processing {
  border: 1px solid blue !important;
}

.assignment {
  background: #ff0;
  padding: 15px;
}

.assignment h2 {
  margin-top: 0;
}

a.trcc-linkbar {
  width: 100%;
  border: 1px solid black;
  padding: 10px;
  cursor: pointer;
  color: black;
  display: block;
  margin-bottom: 10px;
}

a.trcc-linkbar:hover {
  background: #f1f1f1;
}

#thecontent {
  overflow-x: hidden;
  width: 100%;
}

.wp-block-code {
  background: #f1f1f1 !important;
}

#blogLatest {
  background: #ddd;
}

#faq {
  margin-bottom: 100px;
}

.faq_acc {
  margin-bottom: 15px;
  background: #ddd;
}

.faq_acc h4 {
  color: black;
}

.faq_acc_header {
  cursor: pointer;
  padding: 15px;
}

.faq_acc_header p {
  margin: 0;
}

.faq_acc_header:hover,
.faq_acc.active .faq_acc_header {
  background: #ff0;
}

.faq_acc .faq_acc_content {
  display: none;
}

.faq_acc.active .faq_acc_content {
  display: block;
  background: white;
  padding: 10px;
}

#loginform .login-username,
#loginform .login-password {
  display: grid;
  grid-template-columns: 1fr 3fr;
}

#snippet-archive {
  display: grid;
  grid-template-columns: 400px 1fr;
}

#snippet-archive .nav {
  background: #f1f1f1;
  padding: 75px 15px 15px 15px;
  min-height: 100vh;
}

/* ========================================= Scrollbar ========================================= */
/* width */
::-webkit-scrollbar {
  width: 8px;
  height: 3px;
  background: transparent;
  /* background: #cccccc;
  */
}

/* Track */
::-webkit-scrollbar-track {
  background: #eee;
}

/* Handle */
::-webkit-scrollbar-thumb {
  z-index: 10 !important;
  background: #f00;
  cursor: pointer;
}

/* Handle on hover */
::-webkit-scrollbar-thumb:hover {
  background: #f00;
}

.ctaSection {
  height: 100vh;
  max-height: 400px;
  width: 100%;
  padding: 15px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.ctaSection * {
  display: block;
}

.ctaSection .arrowWrapper {
  display: flex;
}

.ctaSection .arrowWrapper .arrow {
  padding-left: 10px;
}

.ctaSection:hover {
  background: #000 !important;
}

.ctaSection:hover .arrow {
  padding-left: 30px;
}

.ctaSection:hover * {
  color: #f1f1f1;
}

.ctaSection.bg-1 {
  background: var(--bg1);
}

.ctaSection.bg-2 {
  background: var(--bg2);
}

.ctaSection.bg-3 {
  background: var(--bg3);
}

.cta {
  margin: 25px 0;
  display: inline-block;
  background: #00f;
  color: var(--white);
  padding: 15px 25px;
  min-width: 400px;
  text-align: center;
  color: var(--white);
}

.cta:hover {
  background: #000;
  color: #f1f1f1;
}

.cta.primary {
  background: #f00;
}

hr {
  height: 1px;
  width: 100%;
  border: 0;
  background: black;
  opacity: 1;
}

.arrow-right::after {
  content: "→";
  padding-left: 10px;
  transition: 0.4s ease;
}

.arrow-right:hover::after {
  padding-left: 50px;
}

h2 a {
  color: black;
}

h2 a:hover {
  color: blue;
}

.blogpostThumbnail:hover img {
  transform: scale(1.2);
}

.p-ksawery {
  line-height: 140% !important;
}

.p-ksawery.has-background {
  padding: 30px;
}

.p-ksawery mark {
  padding: 0.07em 0.3em;
}

mark,
.mark {
  padding: 0 5px !important;
}

.button-nostyle:hover {
  background: transparent !important;
  color: blue !important;
}

.button-nostyle {
  display: inline !important;
  min-width: 0px;
  padding: 0;
  width: auto;
  color: black;
  background: transparent;
}

figure.wp-block-image {
  width: 100%;
}

figure.wp-block-image.aligncenter img {
  display: block;
  margin: 0 auto;
}

.categories li {
  white-space: nowrap;
  margin-bottom: 10px;
  font-size: 13px;
}

.categories {
  flex-wrap: wrap;
}

.pixelate {
  image-rendering: pixelated;
}

.pixelate * {
  image-rendering: pixelated;
}

#testimonials {
  background: white;
}

.img-wrapper {
  overflow: hidden;
}

table th {
  font-weight: normal;
  color: blue;
  border-color: black;
}

.wp-block-table thead {
  border-bottom: 1px solid black !important;
}

.challenge {
  background: #f1f1f1;
  aspect-ratio: 1/1;
  display: block;
  padding: 15px;
}

.challenge:hover {
  background: yellow;
}

input {
  width: 100%;
}

.patreon-valid-patron-message {
  font-size: 13px;
}

.gutenberg-inner input {
  width: 300px;
}

.btn-large {
  padding: 10px 40px;
  border-radius: 40px;
  display: inline-block;
  text-align: center;
  background: blue;
  color: white;
  width: auto;
  margin: 0 auto;
}

.btn-large:hover {
  background: black;
  color: white;
}

.btn-large.btn-red {
  background: red;
}

.btn-large.btn-red:hover {
  background: black;
}

.button:hover {
  background: black;
}

#videoHeader .overlay {
  background-color: rgba(0, 0, 0, 0.4) !important;
  opacity: 1 !important;
}

/*
=========================================
Utilities
=========================================
*/
/* ========================================= Reset ========================================= */
a:not(#thecontent a),
a:not(#thecontent a):hover,
a:not(#thecontent a):active,
a:not(#thecontent a):visited,
a:not(#thecontent a):focus {
  text-decoration: none !important;
}

* {
  font-variant-ligatures: normal;
}

button:active,
button:focus,
button:active:focus {
  box-shadow: none !important;
  outline: none !important;
  outline-style: hidden !important;
  outline-color: transparent !important;
}

img {
  vertical-align: top;
}

/* ========================================= Layout ========================================= */
.parent {
  position: relative;
  width: 100%;
}

.child {
  position: absolute;
  width: 100%;
}

/* ========================================= Flexbox ========================================= */
.flex-center {
  display: flex;
  align-items: center;
  justify-content: center;
}

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

/* ========================================= Video Embeds ========================================= */
.video-16-9,
.video-1-1,
.video-4-3 {
  position: relative;
  padding-top: 15px;
  height: 0;
  overflow: hidden;
}
.video-16-9 iframe,
.video-1-1 iframe,
.video-4-3 iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.video-16-9 {
  padding-bottom: 55%;
}

.video-1-1 {
  padding-bottom: 98%;
}

.video-4-3 {
  padding-bottom: 73%;
}

.video-selfhosted-wrapper video {
  width: 100%;
}

video {
  cursor: pointer;
}

/* ========================================= Spacing Utilities ========================================= */
.m-top-0 {
  margin-top: 0px;
}

.m-bot-0 {
  margin-bottom: 0px;
}

.p-top-0 {
  padding-top: 0px;
}

.p-bot-0 {
  padding-bottom: 0px;
}

.m-top-10 {
  margin-top: 10px;
}

.m-bot-10 {
  margin-bottom: 10px;
}

.p-top-10 {
  padding-top: 10px;
}

.p-bot-10 {
  padding-bottom: 10px;
}

.m-top-15 {
  margin-top: 15px;
}

.m-bot-15 {
  margin-bottom: 15px;
}

.p-top-15 {
  padding-top: 15px;
}

.p-bot-15 {
  padding-bottom: 15px;
}

.m-top-20 {
  margin-top: 20px;
}

.m-bot-20 {
  margin-bottom: 20px;
}

.p-top-20 {
  padding-top: 20px;
}

.p-bot-20 {
  padding-bottom: 20px;
}

.m-top-25 {
  margin-top: 25px;
}

.m-bot-25 {
  margin-bottom: 25px;
}

.p-top-25 {
  padding-top: 25px;
}

.p-bot-25 {
  padding-bottom: 25px;
}

.m-top-30 {
  margin-top: 30px;
}

.m-bot-30 {
  margin-bottom: 30px;
}

.p-top-30 {
  padding-top: 30px;
}

.p-bot-30 {
  padding-bottom: 30px;
}

.m-top-50 {
  margin-top: 50px;
}

.m-bot-50 {
  margin-bottom: 50px;
}

.p-top-50 {
  padding-top: 50px;
}

.p-bot-50 {
  padding-bottom: 50px;
}

.m-top-75 {
  margin-top: 75px;
}

.m-bot-75 {
  margin-bottom: 75px;
}

.p-top-75 {
  padding-top: 75px;
}

.p-bot-75 {
  padding-bottom: 75px;
}

.m-top-100 {
  margin-top: 100px;
}

.m-bot-100 {
  margin-bottom: 100px;
}

.p-top-100 {
  padding-top: 100px;
}

.p-bot-100 {
  padding-bottom: 100px;
}

.m-top-125 {
  margin-top: 125px;
}

.m-bot-125 {
  margin-bottom: 125px;
}

.p-top-125 {
  padding-top: 125px;
}

.p-bot-125 {
  padding-bottom: 125px;
}

.m-top-150 {
  margin-top: 150px;
}

.m-bot-150 {
  margin-bottom: 150px;
}

.p-top-150 {
  padding-top: 150px;
}

.p-bot-150 {
  padding-bottom: 150px;
}

.m-top-200 {
  margin-top: 200px;
}

.m-bot-200 {
  margin-bottom: 200px;
}

.p-top-200 {
  padding-top: 200px;
}

.p-bot-200 {
  padding-bottom: 200px;
}

.m-top-200, .p-top-200 {
  margin-top: 200px;
  padding-top: 200px;
}

.m-bot-200, .p-bot-200 {
  margin-bottom: 200px;
  padding-bottom: 200px;
}

@media (min-width: 480px) {
  .m-top-xs-0 {
    margin-top: 0px;
  }
  .m-bot-xs-0 {
    margin-bottom: 0px;
  }
  .p-top-xs-0 {
    padding-top: 0px;
  }
  .p-bot-xs-0 {
    padding-bottom: 0px;
  }
  .m-top-xs-10 {
    margin-top: 10px;
  }
  .m-bot-xs-10 {
    margin-bottom: 10px;
  }
  .p-top-xs-10 {
    padding-top: 10px;
  }
  .p-bot-xs-10 {
    padding-bottom: 10px;
  }
  .m-top-xs-15 {
    margin-top: 15px;
  }
  .m-bot-xs-15 {
    margin-bottom: 15px;
  }
  .p-top-xs-15 {
    padding-top: 15px;
  }
  .p-bot-xs-15 {
    padding-bottom: 15px;
  }
  .m-top-xs-20 {
    margin-top: 20px;
  }
  .m-bot-xs-20 {
    margin-bottom: 20px;
  }
  .p-top-xs-20 {
    padding-top: 20px;
  }
  .p-bot-xs-20 {
    padding-bottom: 20px;
  }
  .m-top-xs-25 {
    margin-top: 25px;
  }
  .m-bot-xs-25 {
    margin-bottom: 25px;
  }
  .p-top-xs-25 {
    padding-top: 25px;
  }
  .p-bot-xs-25 {
    padding-bottom: 25px;
  }
  .m-top-xs-30 {
    margin-top: 30px;
  }
  .m-bot-xs-30 {
    margin-bottom: 30px;
  }
  .p-top-xs-30 {
    padding-top: 30px;
  }
  .p-bot-xs-30 {
    padding-bottom: 30px;
  }
  .m-top-xs-50 {
    margin-top: 50px;
  }
  .m-bot-xs-50 {
    margin-bottom: 50px;
  }
  .p-top-xs-50 {
    padding-top: 50px;
  }
  .p-bot-xs-50 {
    padding-bottom: 50px;
  }
  .m-top-xs-75 {
    margin-top: 75px;
  }
  .m-bot-xs-75 {
    margin-bottom: 75px;
  }
  .p-top-xs-75 {
    padding-top: 75px;
  }
  .p-bot-xs-75 {
    padding-bottom: 75px;
  }
  .m-top-xs-100 {
    margin-top: 100px;
  }
  .m-bot-xs-100 {
    margin-bottom: 100px;
  }
  .p-top-xs-100 {
    padding-top: 100px;
  }
  .p-bot-xs-100 {
    padding-bottom: 100px;
  }
  .m-top-xs-125 {
    margin-top: 125px;
  }
  .m-bot-xs-125 {
    margin-bottom: 125px;
  }
  .p-top-xs-125 {
    padding-top: 125px;
  }
  .p-bot-xs-125 {
    padding-bottom: 125px;
  }
  .m-top-xs-150 {
    margin-top: 150px;
  }
  .m-bot-xs-150 {
    margin-bottom: 150px;
  }
  .p-top-xs-150 {
    padding-top: 150px;
  }
  .p-bot-xs-150 {
    padding-bottom: 150px;
  }
}
@media (min-width: 768px) {
  .m-top-sm-0 {
    margin-top: 0px;
  }
  .m-bot-sm-0 {
    margin-bottom: 0px;
  }
  .p-top-sm-0 {
    padding-top: 0px;
  }
  .p-bot-sm-0 {
    padding-bottom: 0px;
  }
  .m-top-sm-10 {
    margin-top: 10px;
  }
  .m-bot-sm-10 {
    margin-bottom: 10px;
  }
  .p-top-sm-10 {
    padding-top: 10px;
  }
  .p-bot-sm-10 {
    padding-bottom: 10px;
  }
  .m-top-sm-15 {
    margin-top: 15px;
  }
  .m-bot-sm-15 {
    margin-bottom: 15px;
  }
  .p-top-sm-15 {
    padding-top: 15px;
  }
  .p-bot-sm-15 {
    padding-bottom: 15px;
  }
  .m-top-sm-20 {
    margin-top: 20px;
  }
  .m-bot-sm-20 {
    margin-bottom: 20px;
  }
  .p-top-sm-20 {
    padding-top: 20px;
  }
  .p-bot-sm-20 {
    padding-bottom: 20px;
  }
  .m-top-sm-25 {
    margin-top: 25px;
  }
  .m-bot-sm-25 {
    margin-bottom: 25px;
  }
  .p-top-sm-25 {
    padding-top: 25px;
  }
  .p-bot-sm-25 {
    padding-bottom: 25px;
  }
  .m-top-sm-30 {
    margin-top: 30px;
  }
  .m-bot-sm-30 {
    margin-bottom: 30px;
  }
  .p-top-sm-30 {
    padding-top: 30px;
  }
  .p-bot-sm-30 {
    padding-bottom: 30px;
  }
  .m-top-sm-50 {
    margin-top: 50px;
  }
  .m-bot-sm-50 {
    margin-bottom: 50px;
  }
  .p-top-sm-50 {
    padding-top: 50px;
  }
  .p-bot-sm-50 {
    padding-bottom: 50px;
  }
  .m-top-sm-75 {
    margin-top: 75px;
  }
  .m-bot-sm-75 {
    margin-bottom: 75px;
  }
  .p-top-sm-75 {
    padding-top: 75px;
  }
  .p-bot-sm-75 {
    padding-bottom: 75px;
  }
  .m-top-sm-100 {
    margin-top: 100px;
  }
  .m-bot-sm-100 {
    margin-bottom: 100px;
  }
  .p-top-sm-100 {
    padding-top: 100px;
  }
  .p-bot-sm-100 {
    padding-bottom: 100px;
  }
  .m-top-sm-125 {
    margin-top: 125px;
  }
  .m-bot-sm-125 {
    margin-bottom: 125px;
  }
  .p-top-sm-125 {
    padding-top: 125px;
  }
  .p-bot-sm-125 {
    padding-bottom: 125px;
  }
  .m-top-sm-150 {
    margin-top: 150px;
  }
  .m-bot-sm-150 {
    margin-bottom: 150px;
  }
  .p-top-sm-150 {
    padding-top: 150px;
  }
  .p-bot-sm-150 {
    padding-bottom: 150px;
  }
}
@media (min-width: 992px) {
  .m-top-md-0 {
    margin-top: 0px;
  }
  .m-bot-md-0 {
    margin-bottom: 0px;
  }
  .p-top-md-0 {
    padding-top: 0px;
  }
  .p-bot-md-0 {
    padding-bottom: 0px;
  }
  .m-top-md-10 {
    margin-top: 10px;
  }
  .m-bot-md-10 {
    margin-bottom: 10px;
  }
  .p-top-md-10 {
    padding-top: 10px;
  }
  .p-bot-md-10 {
    padding-bottom: 10px;
  }
  .m-top-md-15 {
    margin-top: 15px;
  }
  .m-bot-md-15 {
    margin-bottom: 15px;
  }
  .p-top-md-15 {
    padding-top: 15px;
  }
  .p-bot-md-15 {
    padding-bottom: 15px;
  }
  .m-top-md-20 {
    margin-top: 20px;
  }
  .m-bot-md-20 {
    margin-bottom: 20px;
  }
  .p-top-md-20 {
    padding-top: 20px;
  }
  .p-bot-md-20 {
    padding-bottom: 20px;
  }
  .m-top-md-25 {
    margin-top: 25px;
  }
  .m-bot-md-25 {
    margin-bottom: 25px;
  }
  .p-top-md-25 {
    padding-top: 25px;
  }
  .p-bot-md-25 {
    padding-bottom: 25px;
  }
  .m-top-md-30 {
    margin-top: 30px;
  }
  .m-bot-md-30 {
    margin-bottom: 30px;
  }
  .p-top-md-30 {
    padding-top: 30px;
  }
  .p-bot-md-30 {
    padding-bottom: 30px;
  }
  .m-top-md-50 {
    margin-top: 50px;
  }
  .m-bot-md-50 {
    margin-bottom: 50px;
  }
  .p-top-md-50 {
    padding-top: 50px;
  }
  .p-bot-md-50 {
    padding-bottom: 50px;
  }
  .m-top-md-75 {
    margin-top: 75px;
  }
  .m-bot-md-75 {
    margin-bottom: 75px;
  }
  .p-top-md-75 {
    padding-top: 75px;
  }
  .p-bot-md-75 {
    padding-bottom: 75px;
  }
  .m-top-md-100 {
    margin-top: 100px;
  }
  .m-bot-md-100 {
    margin-bottom: 100px;
  }
  .p-top-md-100 {
    padding-top: 100px;
  }
  .p-bot-md-100 {
    padding-bottom: 100px;
  }
  .m-top-md-125 {
    margin-top: 125px;
  }
  .m-bot-md-125 {
    margin-bottom: 125px;
  }
  .p-top-md-125 {
    padding-top: 125px;
  }
  .p-bot-md-125 {
    padding-bottom: 125px;
  }
  .m-top-md-150 {
    margin-top: 150px;
  }
  .m-bot-md-150 {
    margin-bottom: 150px;
  }
  .p-top-md-150 {
    padding-top: 150px;
  }
  .p-bot-md-150 {
    padding-bottom: 150px;
  }
}
@media (min-width: 1200px) {
  .m-top-lg-0 {
    margin-top: 0px;
  }
  .m-bot-lg-0 {
    margin-bottom: 0px;
  }
  .p-top-lg-0 {
    padding-top: 0px;
  }
  .p-bot-lg-0 {
    padding-bottom: 0px;
  }
  .m-top-lg-10 {
    margin-top: 10px;
  }
  .m-bot-lg-10 {
    margin-bottom: 10px;
  }
  .p-top-lg-10 {
    padding-top: 10px;
  }
  .p-bot-lg-10 {
    padding-bottom: 10px;
  }
  .m-top-lg-15 {
    margin-top: 15px;
  }
  .m-bot-lg-15 {
    margin-bottom: 15px;
  }
  .p-top-lg-15 {
    padding-top: 15px;
  }
  .p-bot-lg-15 {
    padding-bottom: 15px;
  }
  .m-top-lg-20 {
    margin-top: 20px;
  }
  .m-bot-lg-20 {
    margin-bottom: 20px;
  }
  .p-top-lg-20 {
    padding-top: 20px;
  }
  .p-bot-lg-20 {
    padding-bottom: 20px;
  }
  .m-top-lg-25 {
    margin-top: 25px;
  }
  .m-bot-lg-25 {
    margin-bottom: 25px;
  }
  .p-top-lg-25 {
    padding-top: 25px;
  }
  .p-bot-lg-25 {
    padding-bottom: 25px;
  }
  .m-top-lg-30 {
    margin-top: 30px;
  }
  .m-bot-lg-30 {
    margin-bottom: 30px;
  }
  .p-top-lg-30 {
    padding-top: 30px;
  }
  .p-bot-lg-30 {
    padding-bottom: 30px;
  }
  .m-top-lg-50 {
    margin-top: 50px;
  }
  .m-bot-lg-50 {
    margin-bottom: 50px;
  }
  .p-top-lg-50 {
    padding-top: 50px;
  }
  .p-bot-lg-50 {
    padding-bottom: 50px;
  }
  .m-top-lg-75 {
    margin-top: 75px;
  }
  .m-bot-lg-75 {
    margin-bottom: 75px;
  }
  .p-top-lg-75 {
    padding-top: 75px;
  }
  .p-bot-lg-75 {
    padding-bottom: 75px;
  }
  .m-top-lg-100 {
    margin-top: 100px;
  }
  .m-bot-lg-100 {
    margin-bottom: 100px;
  }
  .p-top-lg-100 {
    padding-top: 100px;
  }
  .p-bot-lg-100 {
    padding-bottom: 100px;
  }
  .m-top-lg-125 {
    margin-top: 125px;
  }
  .m-bot-lg-125 {
    margin-bottom: 125px;
  }
  .p-top-lg-125 {
    padding-top: 125px;
  }
  .p-bot-lg-125 {
    padding-bottom: 125px;
  }
  .m-top-lg-150 {
    margin-top: 150px;
  }
  .m-bot-lg-150 {
    margin-bottom: 150px;
  }
  .p-top-lg-150 {
    padding-top: 150px;
  }
  .p-bot-lg-150 {
    padding-bottom: 150px;
  }
  .m-top-lg-200 {
    margin-top: 200px;
  }
  .m-bot-lg-200 {
    margin-bottom: 200px;
  }
  .p-top-lg-200 {
    padding-top: 200px;
  }
  .p-bot-lg-200 {
    padding-bottom: 200px;
  }
}
/* ========================================= Height Utilities ========================================= */
.h-75vh {
  height: 75vh;
}

@media (min-width: 480px) {
  .h-xs-75vh {
    height: 75vh;
  }
}
@media (min-width: 768px) {
  .h-sm-75vh {
    height: 75vh;
  }
}
@media (min-width: 992px) {
  .h-md-75vh {
    height: 75vh;
  }
}
@media (min-width: 1200px) {
  .h-lg-75vh {
    height: 75vh;
  }
}
.h-95vh {
  height: 95vh;
}

@media (min-width: 480px) {
  .h-xs-95vh {
    height: 95vh;
  }
}
@media (min-width: 768px) {
  .h-sm-95vh {
    height: 95vh;
  }
}
@media (min-width: 992px) {
  .h-md-95vh {
    height: 95vh;
  }
}
@media (min-width: 1200px) {
  .h-lg-95vh {
    height: 95vh;
  }
}
.h-100vh {
  height: 100vh;
}

@media (min-width: 480px) {
  .h-xs-100vh {
    height: 100vh;
  }
}
@media (min-width: 768px) {
  .h-sm-100vh {
    height: 100vh;
  }
}
@media (min-width: 992px) {
  .h-md-100vh {
    height: 100vh;
  }
}
@media (min-width: 1200px) {
  .h-lg-100vh {
    height: 100vh;
  }
}
/* ========================================= Display Utilities ========================================= */
.d-mobile {
  display: block;
}

.d-desktop,
.d-desktop-inline {
  display: none;
}

.d-block {
  display: block;
}

@media (min-width: 768px) {
  .d-mobile {
    display: none;
  }
  .d-desktop {
    display: block;
  }
  .d-desktop-inline {
    display: inline;
  }
}
@media (max-width: 992px) {
  .off-on-mobile,
  .offonsmallscreens {
    display: none !important;
  }
}
/* ========================================= Text Utilities ========================================= */
.uppercase {
  text-transform: uppercase;
}

.lowercase {
  text-transform: lowercase;
}

.noselect {
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}

/* ========================================= Misc Utilities ========================================= */
.pointer {
  cursor: pointer;
}

.fullpage {
  width: 100%;
  height: 100vh;
}

.p-15 {
  padding: 15px;
}

.p-30 {
  padding: 30px !important;
}

/*
 =========================================
 font-sizes werden jetzt über theme.json kontrolliert
 =========================================
*/
/*
 =========================================
 line-heights
 =========================================
*/
body {
  line-height: 1.3;
}

h2 {
  line-height: 1.3;
}

h3 {
  line-height: 1.3;
}

.has-medium-font-size {
  line-height: 1.3;
  font-size: clamp(16px, 1rem + (1vw - 3.2px) * 1.765, 28px);
}

.has-large-font-size {
  line-height: 1.3;
  font-size: clamp(22px, 1.375rem + (1vw - 3.2px) * 1.618, 33px);
}

.has-x-large-font-size {
  font-size: clamp(25.014px, 1.563rem + (1vw - 3.2px) * 2.498, 42px);
}

.headline-xl {
  font-size: calc(16px + 3vw);
  line-height: 1;
}

/*
 =========================================
 font-sizes responsive
 =========================================
*/
@media (max-width: 992px) {
  .headline-xl {
    line-height: 1.1;
  }
}
h1,
h2,
h3,
h4 {
  line-height: 110%;
  margin-top: 0;
}

/*
 =========================================
 font styles
 =========================================
*/
.text-mono,
.text-mono *,
figcaption {
  font-size: 12px !important;
}

.text-serif {
  font-family: SuisseWorks, times, serif;
  font-weight: 500 !important;
}
.text-serif p {
  font-family: SuisseWorks, times, serif;
}

.text-mono li {
  list-style: none;
  padding: 0;
  margin: 0 0 5px 0% !important;
  font-size: 12px;
}

/*
 =========================================
 single typo hacks
 =========================================
*/
.gutenberg-inner h2 {
  font-size: clamp(18px, 4vw, 28px);
}

.gutenberg-inner h3 {
  font-size: clamp(18px, 2.5vw, 24px);
}

.gutenberg-inner h4 {
  font-size: 18px;
}

.text-normal {
  font-weight: normal;
}

/* ========================================= Links ========================================= */
a {
  color: blue;
  text-decoration: none;
}

a:hover {
  color: purple;
  text-decoration: none;
}

p a {
  color: blue;
  text-decoration: none;
}

p a[target=_blank]::after {
  color: blue;
  text-decoration: none;
  content: " ↗";
}

p a[target=_blank]:hover::after {
  color: purple;
  text-decoration: none;
  content: " ↗";
}

ul a {
  color: blue;
  text-decoration: none;
}

ul a[target=_blank]::after {
  color: blue;
  content: " ↗";
}

h3 a[target=_blank]::after {
  color: blue;
  content: " ↗";
}

.pagination a::after {
  content: none !important;
}

.course-toc li a::after {
  content: none !important;
}

a.has-blue-color:hover {
  color: blue;
}

table a {
  color: blue;
}

.arrow-northeast::before {
  content: "↗ ";
}

.arrow-east::before {
  content: "→ ";
}

nav a {
  color: #aaaaaa;
}
nav a:hover {
  color: blue;
}
nav a[target=_blank]::after {
  display: none !important;
}
nav .current-menu-item a {
  color: black;
}

#main-navigation {
  background: white;
  position: fixed;
  top: 0;
  left: 0;
  padding: 10px;
  width: 100%;
  z-index: 999999;
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  z-index: 99999999999999;
}
#main-navigation-left {
  display: flex;
  align-items: center;
  justify-content: flex-start;
}
#main-navigation-left-logo {
  fill: red;
  width: 80px;
}
#main-navigation-left-logo:hover {
  fill: blue;
}
#main-navigation .menu-primary-container {
  display: flex;
  align-items: center;
  justify-content: center;
}
#main-navigation .menu-secondary-container {
  display: flex;
  align-items: center;
  justify-content: flex-end;
}
#main-navigation .accent a {
  color: blue;
}
#main-navigation .accent a:hover {
  color: red;
}
#main-navigation-mobile, #main-navigation-mobile-overlay {
  display: none;
}

#menu-primary {
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  align-items: center;
  font-size: clamp(19px, 1.5vw, 22px);
}
#menu-primary li {
  padding: 0 5px;
}
#menu-primary-mobile {
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
  padding: 30px;
}
#menu-primary-mobile li {
  padding: 10px;
}

#menu-secondary {
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  align-items: center;
}
#menu-secondary li {
  padding-left: 10px;
}
#menu-secondary-mobile {
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  width: 100%;
}
#menu-secondary-mobile li {
  padding: 10px;
}

#main-navigation-mobile {
  background: white;
  position: fixed;
  top: 0;
  left: 0;
  padding: 10px;
  width: 100%;
  z-index: 999999;
  display: none;
  justify-content: space-between;
}
#main-navigation-mobile-left-logo {
  width: 60px;
  fill: red;
}
#main-navigation-mobile-overlay {
  display: flex;
  flex-direction: column;
  justify-content: center;
  position: fixed;
  left: 0;
  bottom: -100vh;
  background: white;
  width: 100%;
  height: 80vh;
  z-index: 999999;
  padding: 10px;
  transition: bottom 0.4s ease;
}
#main-navigation-mobile-overlay-trigger {
  color: black;
  background: #f1f1f1;
  padding: 2px 8px;
  border-radius: 20px;
}
#main-navigation-mobile-overlay-trigger:hover {
  background: black;
  color: white;
}

#nav-silk {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  background: #000;
  opacity: 0;
  transition: all 0.5s ease;
  pointer-events: none;
  z-index: 9999;
}

.link-red,
.link-red a {
  color: red;
}

body.main-navigation-mobile-overlay-visible #main-navigation-mobile-overlay {
  bottom: 0;
}
body.main-navigation-mobile-overlay-visible #nav-silk {
  opacity: 0.6 !important;
  pointer-events: all !important;
  cursor: pointer !important;
  z-index: 9999;
}
body.logged-in #menu-secondary .accent,
body.logged-in #menu-secondary-mobile .accent {
  display: none;
}
body.logged-in .nav-link-dashboard {
  display: block;
}
body.logged-in .nav-link-dashboard a {
  color: blue !important;
}
body.logged-in .nav-link-dashboard a:hover {
  color: black !important;
}
body.logged-in .nav-link-join {
  display: none;
}
body .nav-link-dashboard {
  display: none;
}
body .nav-link-join {
  display: block;
}
body .nav-link-red a {
  color: red !important;
}
body .nav-link-red a:hover {
  color: black !important;
}
body.single-post .menu-item-blog a, body.category .menu-item-blog a, body.tag .menu-item-blog a, body.single-courses .menu-item-courses a, body.single-challenges .menu-item-challenges a {
  color: black;
}
body.darkmode nav a {
  color: #666666;
}
body.darkmode nav a:hover {
  color: #ffff00;
}
body.darkmode nav .current-menu-item a {
  color: white;
}
body.darkmode #main-navigation {
  background: #111111;
}
body.darkmode #main-navigation-left-logo {
  fill: #ffff00;
}
body.darkmode #main-navigation-left-logo:hover {
  fill: #ff0000;
}
body.darkmode #main-navigation .accent a {
  color: #ffff00;
}
body.darkmode #main-navigation .accent a:hover {
  color: #ff0000;
}
body.darkmode #main-navigation-mobile {
  background: #111111;
}
body.darkmode #main-navigation-mobile-left-logo {
  fill: #ffff00;
}
body.darkmode #main-navigation-mobile-overlay {
  background: #111111;
}
body.darkmode #main-navigation-mobile-overlay-trigger {
  color: white;
  background: #333333;
}
body.darkmode #main-navigation-mobile-overlay-trigger:hover {
  background: white;
  color: black;
}
body.darkmode #nav-silk {
  background: #ffffff;
}
body.darkmode.main-navigation-mobile-overlay-visible #nav-silk {
  opacity: 0.4 !important;
}
body.darkmode .link-red,
body.darkmode .link-red a {
  color: #ff0000;
}
body.darkmode.single-post .menu-item-blog a, body.darkmode.category .menu-item-blog a, body.darkmode.tag .menu-item-blog a, body.darkmode.single-courses .menu-item-courses a, body.darkmode.single-challenges .menu-item-challenges a {
  color: white;
}
body.darkmode.logged-in .nav-link-dashboard a {
  color: #ffff00 !important;
}
body.darkmode.logged-in .nav-link-dashboard a:hover {
  color: white !important;
}
body.darkmode .nav-link-red a {
  color: #ff0000 !important;
}
body.darkmode .nav-link-red a:hover {
  color: white !important;
}

@media (max-width: 992px) {
  #main-navigation {
    display: none;
  }
  #main-navigation-mobile {
    display: flex;
  }
}
/* ========================================= Buttons ========================================= */
button,
.add_to_cart_button,
.button,
.wp-block-button__link,
#mc-embedded-subscribe,
input#submit {
  display: inline-block;
  cursor: pointer;
  background: #00f;
  box-shadow: none;
  padding: 8px 20px;
  border-radius: 30px;
  text-align: center;
  margin-bottom: 20px;
  margin-right: 20px;
  border: 0;
  color: #f1f1f1;
  font-weight: normal !important;
}
button:hover,
.add_to_cart_button:hover,
.button:hover,
.wp-block-button__link:hover,
#mc-embedded-subscribe:hover,
input#submit:hover {
  background: #00ff00 !important;
  color: black !important;
}
button.small,
.add_to_cart_button.small,
.button.small,
.wp-block-button__link.small,
#mc-embedded-subscribe.small,
input#submit.small {
  padding: 6px 10px;
}
button.grey,
.add_to_cart_button.grey,
.button.grey,
.wp-block-button__link.grey,
#mc-embedded-subscribe.grey,
input#submit.grey {
  background: #888 !important;
}
button.cta,
.add_to_cart_button.cta,
.button.cta,
.wp-block-button__link.cta,
#mc-embedded-subscribe.cta,
input#submit.cta {
  background: #00f !important;
}
button.locked,
.add_to_cart_button.locked,
.button.locked,
.wp-block-button__link.locked,
#mc-embedded-subscribe.locked,
input#submit.locked {
  background: #bbb !important;
  color: #333 !important;
}
button.locked:hover,
.add_to_cart_button.locked:hover,
.button.locked:hover,
.wp-block-button__link.locked:hover,
#mc-embedded-subscribe.locked:hover,
input#submit.locked:hover {
  background: transparent !important;
  color: #f00 !important;
}
@media (max-width: 700px) {
  button,
  .add_to_cart_button,
  .button,
  .wp-block-button__link,
  #mc-embedded-subscribe,
  input#submit {
    padding: 5px 15px;
    min-width: 10px;
  }
}

.btn-small {
  padding: 5px 10px !important;
}

.wp-block-button .has-red-background-color {
  background: #f00;
}
.wp-block-button .has-red-background-color:hover {
  background: #333 !important;
}

:root :where(.wp-element-button, .wp-block-button__link) {
  background: black !important;
}

/* ========================================= Courses ========================================= */
.trcc-breadcrumb .separator {
  color: #000;
}
.trcc-breadcrumb .inactive {
  color: #aaa;
}
.trcc-breadcrumb .inactive:hover {
  color: #000;
}

#breadcrumbs {
  display: none;
  padding: 5px;
  height: 50px;
  position: fixed;
  top: 0;
  right: 0;
  width: 50%;
  margin: 0;
  text-transform: lowercase;
  z-index: 9999;
}
#breadcrumbs * {
  background: transparent !important;
  color: #000;
}
@media (max-width: 900px) {
  #breadcrumbs {
    display: none;
  }
}

.breadcrumb {
  padding: 0 !important;
  margin: 0;
}

.btn-course-overview {
  width: 100%;
  background: #f1f1f1;
  color: #000;
  display: block;
  margin-top: 40px;
}

.course-cta {
  background: #00f;
  color: #f1f1f1;
  display: flex;
  justify-content: center;
  align-items: center;
  margin-bottom: 20px;
  width: 100%;
  padding: 40px 20px;
  font-size: 33px;
}
.course-cta:hover {
  background: #000;
  color: #f1f1f1;
}

.btn-navigate {
  display: block;
  color: #f00;
}

#course-intro {
  width: 100%;
  background: #000;
  min-height: 70vh;
  display: flex;
  justify-content: center;
  align-items: center;
}
#course-intro h1 {
  color: #f1f1f1;
}

.course:hover .has-lightgrey-color {
  color: #000;
}
.course:hover img {
  transform: scale(1.2);
}
.course img {
  transition: all 1s ease;
}
.course a {
  position: relative;
  display: block;
  overflow: hidden;
}
.course .trcc-badge {
  top: 0;
  right: 0;
  display: inline-block;
  position: absolute;
  margin: 15px 10px;
}

.course-count {
  color: #bbb;
  padding-right: 10px;
}

.trcc-courses-grid-item-wrapper {
  margin-bottom: 20px;
}
.trcc-courses-grid-item-wrapper:hover .trcc-wip-badge {
  right: 0;
}
.trcc-courses-grid-item-wrapper:hover .course-arrow-right {
  padding-left: 10px;
}
.trcc-courses-grid-item-wrapper .course-arrow-right {
  transition: padding-left 0.4s ease;
}
@media (max-width: 500px) {
  .trcc-courses-grid-item-wrapper {
    margin-bottom: 50px;
  }
}

a.trcc-courses-grid-item:hover {
  background: #ddd;
}
a.trcc-courses-grid-item:hover .trcc-courses-grid-meta {
  opacity: 1;
}
a.trcc-courses-grid-item:hover .trcc-courses-grid-meta .has-tiny-font-size {
  color: black;
}
a.trcc-courses-grid-item.course-locked:hover .trcc-courses-grid-thumb img {
  opacity: 1;
}

.trcc-courses-grid-thumb {
  position: relative;
  display: block;
  overflow: hidden;
}
.trcc-courses-grid-thumb img {
  transition: all 0.4s ease;
}
@media (max-width: 500px) {
  .trcc-courses-grid-thumb img {
    display: block;
    margin-bottom: 10px;
  }
}

.trcc-courses-grid-meta {
  opacity: 1;
  transition: 0.4s ease;
}
.trcc-courses-grid-meta .has-tiny-font-size {
  color: #aaa;
  transition: color 0.4s ease;
}

.trcc-courses-grid-item-subjects {
  color: black;
}

.course-locked {
  opacity: 0.3;
  cursor: not-allowed;
}

.trcc-radio-courses-filter * {
  cursor: pointer;
}
.trcc-radio-courses-filter label {
  margin-bottom: 0;
}

/* ========================================= Forms ========================================= */
input[type=text],
input[type=email],
input[type=url],
input[type=search],
input[type=password],
textarea {
  -webkit-appearance: none;
  appearance: none;
  outline: none;
  box-shadow: 0;
  border: none;
  background: #f1f1f1;
  color: #000;
}

/* ========================================= Colors ========================================= */
.has-black-color {
  color: #000;
}

.has-yellow-color {
  color: #ff0;
}

.has-black-background-color {
  background: #000;
}

.has-white-color {
  color: #f1f1f1;
}

.has-white-color::before {
  color: #f1f1f1;
}

.has-white-background-color {
  background: #f1f1f1;
}

.has-lightgrey-color {
  color: #bbb;
}

.has-lightgrey-color p {
  color: #bbb;
}

.has-lightgrey-background-color {
  background: #bbb;
}

.has-lightest-background-color {
  background: #f1f1f1;
}

.has-red-background-color {
  background: #f00;
  color: #f1f1f1;
}

.has-red-background-color a {
  color: #f1f1f1;
}

.has-red-background-color a:hover {
  color: black !important;
}

.has-red-color {
  color: #f00 !important;
}

.has-red-color-important {
  color: #f00 !important;
}

.has-blue-color {
  color: #00f;
}

.has-blue-color-important {
  color: #00f !important;
}

.has-green-color {
  color: #03fc62;
}

/* ========================================= Gutenberg ========================================= */
.gutenberg p, .gutenberg hr, .gutenberg h1, .gutenberg h2, .gutenberg h3, .gutenberg h4, .gutenberg h5 {
  width: 100% !important;
  margin: 25px 0 15px 0;
}
.gutenberg h2 {
  color: red;
}
.gutenberg h3, .gutenberg h4 {
  color: #aaaaaa;
  line-height: 125%;
}
.gutenberg h1 {
  margin-bottom: 50px;
}
.gutenberg-layout h2, .gutenberg-layout h3, .gutenberg-layout h4 {
  margin-top: 50px;
}
.gutenberg-layout .wp-block-embed {
  margin-bottom: 50px;
}
.gutenberg-layout .wp-block-image {
  margin: 25px 0;
}
@media (min-width: 750px) {
  .gutenberg-layout .wp-block-image {
    margin: 50px 0;
  }
}
.gutenberg ul {
  padding: 0;
}
.gutenberg ul li {
  margin-left: 25px;
}
.gutenberg tr {
  border-bottom: 1px solid #000;
}
.gutenberg table a {
  color: #00f;
}
.gutenberg table a[target=_blank]::after {
  color: #00f;
  content: " ↗";
}
.gutenberg .wp-block-pullquote {
  text-align: left;
  padding: 2vw 0;
  margin: 0;
}
.gutenberg .wp-block-pullquote blockquote p {
  font-size: calc(22px + 1.5vw);
  line-height: 110%;
  font-family: SuisseWorks, times, serif !important;
  font-weight: normal !important;
  text-align: left;
}
.gutenberg .wp-block-pullquote blockquote p::before {
  content: "";
}
.gutenberg .wp-block-pullquote blockquote p::after {
  content: "";
}
@media (min-width: 750px) and (min-width: 750px) {
  .gutenberg .alignfull {
    max-width: 1000%;
    margin-right: calc(50% - 50vw);
    margin-left: calc(50% - 50vw);
    width: auto;
    padding: 15px;
  }
}
@media (min-width: 750px) {
  .gutenberg .alignwide {
    width: calc(100% + 400px);
    max-width: calc(100% + 400px);
    margin-left: -200px !important;
    margin-right: -200px !important;
  }
}
@media (min-width: 750px) and (max-width: 1300px) {
  .gutenberg .alignwide {
    width: calc(100% + 200px);
    max-width: calc(100% + 200px);
    margin-left: -100px !important;
    margin-right: -100px !important;
  }
}
@media (min-width: 750px) and (max-width: 1200px) {
  .gutenberg .alignwide {
    width: 100%;
    max-width: 100%;
    margin: 0 auto;
    margin-left: 0 !important;
    margin-right: 0 !important;
  }
}
@media (min-width: 750px) {
  .gutenberg .wp-block-group__inner-container {
    max-width: 85.7143rem;
    margin: auto;
  }
}

.wp-block-separator {
  margin: 80px 0 !important;
  height: 0px !important;
  border: 0 !important;
  background: #bbb;
}

.wp-block-quote {
  border-left: 3px solid #000;
  padding-left: 15px;
}

.wp-block-code {
  background: #f1f1f1;
  line-height: 130% !important;
  padding: 15px;
  border: 0 !important;
  border-radius: 0 !important;
  margin-bottom: 15px;
  font-size: 13px;
  line-height: 190% !important;
}
.wp-block-code * {
  font-family: PlexMono, monospace !important;
}

.wp-block-gallery {
  padding: 0 !important;
}
@media (max-width: 1200px) {
  .wp-block-gallery {
    width: 100%;
    margin: 0 !important;
  }
}
.wp-block-gallery .blocks-gallery-image,
.wp-block-gallery .blocks-gallery-item {
  padding: 0;
}
.wp-block-gallery .blocks-gallery-image figcaption,
.wp-block-gallery .blocks-gallery-item figcaption {
  position: relative !important;
  color: #000 !important;
  padding: 10px 0 0 0 !important;
  background: transparent !important;
}
.wp-block-gallery .blocks-gallery-image figure,
.wp-block-gallery .blocks-gallery-item figure {
  display: block !important;
}
.wp-block-gallery.has-nested-images figure.wp-block-image figcaption {
  display: block;
  background: none;
  position: relative;
  margin: 0;
  color: #000;
  flex-grow: 0;
  flex-basis: auto;
  padding: 10px 0;
}
.wp-block-gallery figure.wp-block-image::before {
  display: none;
  filter: none;
}
.wp-block-gallery .wp-element-caption {
  position: relative !important;
  color: #aaaaaa !important;
  text-shadow: none !important;
  background: none !important;
  padding: 10px !important;
}

.wp-block-video video {
  display: block;
  margin: 0 auto;
}

.wp-block-embed__wrapper {
  position: relative;
  padding-bottom: 56.25%; /* 16:9 */
  padding-top: 25px;
  height: 0;
}
.wp-block-embed__wrapper iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.wp-block-image img {
  height: auto;
}

.is-style-outline .wp-block-button__link {
  border: 1px solid #000;
}

.postergallery img {
  box-shadow: 2px 2px 2px #888;
}

.serif {
  font-family: "SuisseWorks", serif;
}

.has-small-font-size,
.smallMono,
.smallMono * {
  font-family: PlexMono, monospace;
  text-transform: uppercase;
  font-size: 12px;
}

cite {
  font-size: 13px;
  line-height: 130%;
  display: block;
  text-align: left;
  max-width: 600px;
  font-style: normal;
}

.footnotes {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}
.footnotes li {
  list-style: none;
  margin: 0px 10px 10px 0 !important;
  display: block;
}

.wp-block-table.table-footnotes tr {
  border: 0;
}
.wp-block-table.table-footnotes td {
  padding: 0;
  border: 0;
  vertical-align: top;
}
.wp-block-table.table-footnotes td:first-child {
  color: #00f;
  padding-right: 10px;
}

.beware {
  background: #f1f1f1;
  border: 1px solid red;
}
.beware h2, .beware h3 {
  font-weight: normal;
  margin: 0;
  width: 100%;
  background: red;
  padding: 10px;
  color: white;
}
.beware p {
  padding: 10px;
  background: #f1f1f1;
  margin: 0;
}

.gutenberg-gallery-more-margin-bottom .blocks-gallery-item {
  margin-bottom: 45px;
}

/* PrismJS 1.17.1
https://prismjs.com/download.html#themes=prism&languages=clike+javascript+java+json+processing&plugins=line-highlight+line-numbers */
/**
 * prism.js default theme for JavaScript, CSS and HTML
 * Based on dabblet (http://dabblet.com)
 * @author Lea Verou
 */
p code {
  color: #0000ff;
}

code[class*=language-],
pre[class*=language-] {
  color: black;
  background: none;
  font-family: "SuisseMono", monospace;
  text-align: left;
  white-space: pre;
  word-spacing: normal;
  word-break: normal;
  word-wrap: normal;
  line-height: 1.5;
  -moz-tab-size: 4;
  -o-tab-size: 4;
  tab-size: 4;
  -webkit-hyphens: none;
  -moz-hyphens: none;
  -ms-hyphens: none;
  hyphens: none;
}

pre[class*=language-]::-moz-selection,
pre[class*=language-] ::-moz-selection,
code[class*=language-]::-moz-selection,
code[class*=language-] ::-moz-selection {
  text-shadow: none;
  color: #000000;
  background: #ffff00;
}

pre[class*=language-]::selection,
pre[class*=language-] ::selection,
code[class*=language-]::selection,
code[class*=language-] ::selection {
  text-shadow: none;
  color: #000000;
  background: #ffff00;
}

@media print {
  code[class*=language-],
  pre[class*=language-] {
    text-shadow: none;
  }
}
/* Code blocks */
pre[class*=language-] {
  padding: 1em;
  margin: 0.5em 0;
  overflow: auto;
}

:not(pre) > code[class*=language-],
pre[class*=language-] {
  background: #dddddd;
}

/* Inline code */
:not(pre) > code[class*=language-] {
  padding: 0.1em;
  white-space: normal;
}

.token.comment,
.token.prolog,
.token.doctype,
.token.cdata {
  color: slategray;
}

.token.punctuation {
  color: #999;
}

.namespace {
  opacity: 0.7;
}

.token.property,
.token.tag,
.token.boolean,
.token.number,
.token.constant,
.token.symbol,
.token.deleted {
  color: #000000;
}

.token.selector,
.token.attr-name,
.token.string,
.token.char,
.token.builtin,
.token.inserted {
  color: #000000;
}

.token.operator,
.token.entity,
.token.url,
.language-css .token.string,
.style .token.string {
  color: #000000;
}

.token.atrule,
.token.attr-value,
.token.keyword {
  color: #0000ff;
}

.token.function,
.token.class-name {
  color: #0000ff;
}

.token.regex,
.token.important,
.token.variable {
  color: #ff0000;
}

.token.entity {
  cursor: help;
}

pre[data-line] {
  position: relative;
  padding: 1em 0 1em 3em;
}

.line-highlight {
  position: absolute;
  left: 0;
  right: 0;
  padding: inherit 0;
  margin-top: 1em; /* Same as .prism’s padding-top */
  background: hsla(24, 20%, 50%, 0.08);
  background: linear-gradient(to right, hsla(24, 20%, 50%, 0.1) 70%, hsla(24, 20%, 50%, 0));
  pointer-events: none;
  line-height: inherit;
  white-space: pre;
}

.line-highlight:before,
.line-highlight[data-end]:after {
  content: attr(data-start);
  position: absolute;
  top: 0.4em;
  left: 0.6em;
  min-width: 1em;
  padding: 0 0.5em;
  background-color: hsla(24, 20%, 50%, 0.4);
  color: hsl(24, 20%, 95%);
  font: bold 65%/1.5 sans-serif;
  text-align: center;
  vertical-align: 0.3em;
  border-radius: 999px;
  text-shadow: none;
}

.line-highlight[data-end]:after {
  content: attr(data-end);
  top: auto;
  bottom: 0.4em;
}

.line-numbers .line-highlight:before,
.line-numbers .line-highlight:after {
  content: none;
}

pre[class*=language-].line-numbers {
  position: relative;
  padding-left: 3.8em;
  counter-reset: linenumber;
}

pre[class*=language-].line-numbers > code {
  position: relative;
  white-space: inherit;
}

.line-numbers .line-numbers-rows {
  position: absolute;
  pointer-events: none;
  top: 0;
  font-size: 100%;
  left: -3.8em;
  width: 3em; /* works for line-numbers below 1000 lines */
  letter-spacing: -1px;
  border-right: 1px solid #999;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}

.line-numbers-rows > span {
  pointer-events: none;
  display: block;
  counter-increment: linenumber;
}

.line-numbers-rows > span:before {
  content: counter(linenumber);
  color: #999;
  display: block;
  padding-right: 0.8em;
  text-align: right;
}

.course-excerpt .button {
  background: #aaaaaa;
  color: black;
  margin: 10px 0;
  min-width: 0;
}

.course-excerpt a.button:hover {
  background: #00ff00 !important;
  color: black !important;
}

#curriculum-grid-view,
#curriculum-list-view {
  display: none;
}

#curriculum-grid-view.active,
#curriculum-list-view.active {
  display: block;
}

.view-toggle {
  display: flex;
  justify-content: center;
  margin-bottom: 50px;
  padding: 50px 0;
}

.view-toggle button {
  padding: 10px 20px;
  background: #f1f1f1;
  color: #aaaaaa;
  border: none;
  cursor: pointer;
  border-radius: 40px;
  transition: none !important;
}

.view-toggle button.active {
  background: #00ff00;
  color: #000000;
}

.view-toggle button:hover {
  background: #00ff00 !important;
  color: black !important;
}

.course-excerpt {
  line-height: 120%;
  padding: 10px 0;
}

.course-grid-item h3 {
  color: red;
}
.course-grid-item .course-excerpt {
  color: #aaaaaa;
}

@media (min-width: 1200px) {
  #curriculum-grid .course-grid-item:hover {
    background: #f1f1f1;
  }
}
#curriculum-list-view .module-course-item .button {
  background: #00ff00;
  color: black;
}
#curriculum-list-view .module-course-item .button:hover {
  background: blue !important;
  color: white !important;
}
#curriculum-list-view .module-course-item p, #curriculum-list-view .module-course-item ol li, #curriculum-list-view .module-course-item ol li a {
  color: #aaaaaa;
}
#curriculum-list-view .module-course-item ol a:hover {
  color: blue;
}
#curriculum-list-view .module-course-item h2 a {
  color: red;
}
#curriculum-list-view .sticky-top {
  color: #aaaaaa;
}

.course-toc {
  padding: 0;
  margin: 30px 0 0 0;
  border-bottom: 1px solid #000;
  list-style: none;
  counter-reset: my-awesome-counter;
}

.course-toc a::after {
  content: none !important;
}

.course-toc li {
  counter-increment: my-awesome-counter;
}

.course-toc li::before {
  content: counter(my-awesome-counter) ". ";
  min-width: 30px;
  display: inline-block;
}

.course-toc li {
  margin-left: 0 !important;
  border-top: 1px solid #000;
  padding: 5px 0 5px 0;
  color: #000;
}

.course-toc li:hover .text-mono {
  color: #00f;
}

.course-toc li:hover a {
  color: #00f;
}

.course-toc li:hover a h3, .course-toc li:hover a p {
  color: #00f;
}

.course-toc li.active {
  color: #00f;
}

.course-toc li.active .text-mono {
  color: #00f;
}

.course-toc li.active:hover .text-mono {
  color: #00f;
}

.course-toc li.active:hover h3 {
  color: #00f !important;
}

.course-toc li h3 {
  margin: 0;
}

.btn-prev {
  background: #aaa !important;
}

.prevnext-buttons {
  display: flex;
  margin-top: 50px;
}

.prevnext-buttons a {
  display: flex !important;
  justify-content: center;
  align-items: center;
  padding: 25px 15px;
  text-align: center;
  color: #f1f1f1;
  width: 100%;
  background: #00f;
  display: inline-block;
}

.prevnext-buttons a h3 {
  margin: 0;
}

.prevnext-buttons a * {
  color: #f1f1f1;
}

.prevnext-buttons a a .small {
  display: block;
  text-transform: uppercase;
  margin-bottom: 5px;
}

.prevnext-buttons a:hover {
  background: #000;
  color: #f1f1f1;
}

.prevnext-buttons a:hover * {
  color: #f1f1f1;
}

@media (max-width: 700px) {
  .prevnext-buttons {
    flex-wrap: wrap;
  }
  .prevnext-buttons a:first-of-type {
    margin-right: 0;
    margin-bottom: 5px;
  }
}
.btn-navigate-forward::after {
  content: "→";
  margin-left: 10px;
}

.btn-navigate-forward:hover::after {
  margin-left: 30px;
}

.btn-navigate-backward::before {
  content: "←";
  margin-right: 10px;
}

.btn-navigate-backward:hover::before {
  margin-right: 30px;
}

/*
 =========================================
 Dark Mode Styles
 =========================================
*/
body.darkmode {
  background: #121212;
  color: #e0e0e0;
}
body.darkmode p, body.darkmode h1, body.darkmode h2, body.darkmode h3, body.darkmode h4, body.darkmode h5, body.darkmode h6, body.darkmode li, body.darkmode span, body.darkmode div {
  color: #e0e0e0;
}
body.darkmode h1, body.darkmode h2, body.darkmode h3, body.darkmode h4, body.darkmode h5, body.darkmode h6 {
  color: #e0e0e0;
}
body.darkmode a {
  color: #4a9eff;
}
body.darkmode a:hover {
  color: #ffeb3b;
}
body.darkmode a:visited {
  color: #4a9eff;
}
body.darkmode .container-wide,
body.darkmode .container-normal,
body.darkmode .container-narrow,
body.darkmode .container-fluid,
body.darkmode .container {
  background-color: transparent;
}
body.darkmode .bg-paper {
  background-color: #1a1a1a;
}
body.darkmode .has-black-color {
  color: #e0e0e0 !important;
}
body.darkmode .has-white-color {
  color: #e0e0e0 !important;
}
body.darkmode .has-yellow-color {
  color: #ffeb3b !important;
}
body.darkmode .has-red-color,
body.darkmode .has-red-color-important {
  color: #ff4444 !important;
}
body.darkmode .has-blue-color,
body.darkmode .has-blue-color-important {
  color: #4a9eff !important;
}
body.darkmode .has-green-color {
  color: #4caf50 !important;
}
body.darkmode .has-lightgrey-color {
  color: #b0b0b0 !important;
}
body.darkmode .has-black-background-color {
  background: #1a1a1a !important;
}
body.darkmode .has-white-background-color {
  background: #242424 !important;
}
body.darkmode .has-lightgrey-background-color {
  background: #242424 !important;
}
body.darkmode .has-lightest-background-color {
  background: #1a1a1a !important;
}
body.darkmode .has-red-background-color {
  background: #ff4444 !important;
  color: #e0e0e0 !important;
}
body.darkmode .has-red-background-color a {
  color: #e0e0e0 !important;
}
body.darkmode .has-red-background-color a:hover {
  color: #ffeb3b !important;
}
body.darkmode .color-primary {
  color: #ff4444 !important;
}
body.darkmode button,
body.darkmode .button,
body.darkmode .wp-block-button__link,
body.darkmode .add_to_cart_button,
body.darkmode #mc-embedded-subscribe,
body.darkmode input[type=submit] {
  background: #4a9eff !important;
  color: #e0e0e0 !important;
  border-color: #333333;
}
body.darkmode button:hover,
body.darkmode .button:hover,
body.darkmode .wp-block-button__link:hover,
body.darkmode .add_to_cart_button:hover,
body.darkmode #mc-embedded-subscribe:hover,
body.darkmode input[type=submit]:hover {
  background: #4caf50 !important;
  color: #121212 !important;
}
body.darkmode button.locked,
body.darkmode .button.locked,
body.darkmode .wp-block-button__link.locked,
body.darkmode .add_to_cart_button.locked,
body.darkmode #mc-embedded-subscribe.locked,
body.darkmode input[type=submit].locked {
  background: #242424 !important;
  color: #888888 !important;
}
body.darkmode button.locked:hover,
body.darkmode .button.locked:hover,
body.darkmode .wp-block-button__link.locked:hover,
body.darkmode .add_to_cart_button.locked:hover,
body.darkmode #mc-embedded-subscribe.locked:hover,
body.darkmode input[type=submit].locked:hover {
  background: transparent !important;
  color: #ff4444 !important;
  border-color: #ff4444;
}
body.darkmode button.grey,
body.darkmode .button.grey,
body.darkmode .wp-block-button__link.grey,
body.darkmode .add_to_cart_button.grey,
body.darkmode #mc-embedded-subscribe.grey,
body.darkmode input[type=submit].grey {
  background: #242424 !important;
  color: #e0e0e0 !important;
}
body.darkmode .wp-block-button .has-red-background-color {
  background: #ff4444 !important;
}
body.darkmode .wp-block-button .has-red-background-color:hover {
  background: #242424 !important;
}
body.darkmode :root :where(.wp-element-button, .wp-block-button__link) {
  background: #1a1a1a !important;
  color: #e0e0e0 !important;
}
body.darkmode nav {
  background: #1a1a1a !important;
  border-bottom: 1px solid #333333;
}
body.darkmode nav a {
  color: #b0b0b0;
}
body.darkmode nav a:hover {
  color: #ffeb3b;
}
body.darkmode nav .current-menu-item a {
  color: #e0e0e0;
}
body.darkmode nav .accent a {
  color: #ffeb3b;
}
body.darkmode nav .accent a:hover {
  color: #ff4444;
}
body.darkmode #main-navigation {
  background: #1a1a1a;
}
body.darkmode #main-navigation-left-logo {
  fill: #ff4444;
}
body.darkmode #main-navigation-left-logo:hover {
  fill: #ffeb3b;
}
body.darkmode footer,
body.darkmode #colophon {
  background: #1a1a1a !important;
  border-top: 1px solid #333333;
  color: #b0b0b0;
}
body.darkmode footer *,
body.darkmode #colophon * {
  color: #b0b0b0;
}
body.darkmode footer a,
body.darkmode #colophon a {
  color: #b0b0b0;
}
body.darkmode footer a:hover,
body.darkmode #colophon a:hover {
  color: #ffeb3b;
}
body.darkmode footer h2,
body.darkmode #colophon h2 {
  color: #e0e0e0;
}
body.darkmode .gutenberg,
body.darkmode .gutenberg-inner {
  background: transparent;
  color: #e0e0e0;
}
body.darkmode .gutenberg h2,
body.darkmode .gutenberg-inner h2 {
  color: #ff4444;
}
body.darkmode .gutenberg h3, body.darkmode .gutenberg h4,
body.darkmode .gutenberg-inner h3,
body.darkmode .gutenberg-inner h4 {
  color: #b0b0b0;
}
body.darkmode .gutenberg p,
body.darkmode .gutenberg-inner p {
  color: #e0e0e0;
}
body.darkmode .gutenberg code,
body.darkmode .gutenberg-inner code {
  background: #242424;
  color: #ffeb3b;
  padding: 2px 6px;
  border-radius: 3px;
}
body.darkmode .gutenberg pre,
body.darkmode .gutenberg .wp-block-code,
body.darkmode .gutenberg-inner pre,
body.darkmode .gutenberg-inner .wp-block-code {
  background: #1a1a1a;
  border: 1px solid #333333;
  color: #e0e0e0;
}
body.darkmode .gutenberg pre code,
body.darkmode .gutenberg .wp-block-code code,
body.darkmode .gutenberg-inner pre code,
body.darkmode .gutenberg-inner .wp-block-code code {
  background: transparent;
  color: #ffeb3b;
}
body.darkmode .gutenberg blockquote,
body.darkmode .gutenberg .wp-block-quote,
body.darkmode .gutenberg-inner blockquote,
body.darkmode .gutenberg-inner .wp-block-quote {
  border-left-color: #4a9eff;
  color: #b0b0b0;
}
body.darkmode .gutenberg table,
body.darkmode .gutenberg-inner table {
  border-color: #333333;
}
body.darkmode .gutenberg table th,
body.darkmode .gutenberg-inner table th {
  background: #242424;
  color: #4a9eff;
  border-color: #333333;
}
body.darkmode .gutenberg table td,
body.darkmode .gutenberg-inner table td {
  border-color: #333333;
}
body.darkmode .gutenberg hr,
body.darkmode .gutenberg .wp-block-separator,
body.darkmode .gutenberg-inner hr,
body.darkmode .gutenberg-inner .wp-block-separator {
  background: #333333;
  border-color: #333333;
}
body.darkmode .gutenberg figcaption,
body.darkmode .gutenberg-inner figcaption {
  color: #888888;
}
body.darkmode .gutenberg .wp-block-image img,
body.darkmode .gutenberg-inner .wp-block-image img {
  opacity: 0.9;
}
body.darkmode input[type=text],
body.darkmode input[type=email],
body.darkmode input[type=password],
body.darkmode input[type=search],
body.darkmode textarea,
body.darkmode select {
  background: #242424;
  color: #e0e0e0;
  border: 1px solid #333333;
}
body.darkmode input[type=text]:focus,
body.darkmode input[type=email]:focus,
body.darkmode input[type=password]:focus,
body.darkmode input[type=search]:focus,
body.darkmode textarea:focus,
body.darkmode select:focus {
  border-color: #4a9eff;
  outline: none;
}
body.darkmode input[type=text]::placeholder,
body.darkmode input[type=email]::placeholder,
body.darkmode input[type=password]::placeholder,
body.darkmode input[type=search]::placeholder,
body.darkmode textarea::placeholder,
body.darkmode select::placeholder {
  color: #888888;
}
body.darkmode .blogpost,
body.darkmode .course-grid-item,
body.darkmode .card {
  background: #1a1a1a;
  border-color: #333333;
}
body.darkmode .blogpost:hover,
body.darkmode .course-grid-item:hover,
body.darkmode .card:hover {
  background: #242424;
}
body.darkmode .excerpt {
  color: #b0b0b0;
}
body.darkmode .pill {
  background: #242424;
  color: #e0e0e0;
  border-color: #333333;
}
body.darkmode .pill:hover {
  background: #1a1a1a;
  color: #ffeb3b;
}
body.darkmode .pill.active {
  background: #121212;
  color: #ffeb3b;
  border-color: #ffeb3b;
}
body.darkmode .course-excerpt {
  color: #b0b0b0;
}
body.darkmode .trcc-badge {
  background: #242424;
  color: #e0e0e0;
}
body.darkmode .player,
body.darkmode #videoplayer {
  background: #1a1a1a;
}
body.darkmode .player video,
body.darkmode #videoplayer video {
  background: #121212;
}
body.darkmode .faq_acc {
  background: #1a1a1a;
  border-color: #333333;
}
body.darkmode .faq_acc .faq_acc_header {
  color: #e0e0e0;
}
body.darkmode .faq_acc .faq_acc_header:hover, body.darkmode .faq_acc .faq_acc_header.active {
  background: #242424;
}
body.darkmode .faq_acc .faq_acc_content {
  background: #121212;
  color: #e0e0e0;
}
body.darkmode .testimonial-single {
  background: #1a1a1a;
  color: #e0e0e0;
}
body.darkmode .resource-single {
  color: #e0e0e0;
  border-color: #333333;
}
body.darkmode .resource-single:hover {
  color: #ff4444;
}
body.darkmode .resource-separator,
body.darkmode .term-separator {
  border-color: #333333;
}
body.darkmode .pagination a {
  color: #b0b0b0;
}
body.darkmode .pagination a:hover {
  color: #4a9eff;
}
body.darkmode .pagination a.current {
  color: #ff4444;
}
body.darkmode .pagination a.inactive {
  color: #888888;
}
body.darkmode #hero,
body.darkmode #videoHeader {
  background-color: #121212;
}
body.darkmode #hero #longlogo,
body.darkmode #videoHeader #longlogo {
  fill: #ffeb3b;
}
body.darkmode .ctaSection {
  background: #1a1a1a;
}
body.darkmode .ctaSection:hover {
  background: #121212 !important;
}
body.darkmode .wp-block-code,
body.darkmode code[class*=language-],
body.darkmode pre[class*=language-] {
  background: #1a1a1a !important;
  color: #e0e0e0 !important;
}
body.darkmode img {
  opacity: 0.9;
  filter: brightness(0.95);
}
body.darkmode img:hover {
  opacity: 1;
  filter: brightness(1);
}
body.darkmode ::selection {
  background: #ffeb3b;
  color: #121212;
}
body.darkmode ::-moz-selection {
  background: #ffeb3b;
  color: #121212;
}
body.darkmode ::-webkit-scrollbar {
  background: #121212;
}
body.darkmode ::-webkit-scrollbar-track {
  background: #1a1a1a;
}
body.darkmode ::-webkit-scrollbar-thumb {
  background: #ff4444;
}
body.darkmode ::-webkit-scrollbar-thumb:hover {
  background: #ffeb3b;
}
body.darkmode .dashboard-card {
  background: #242424;
  color: #e0e0e0;
}
body.darkmode .dashboard-card:hover:not(.deactivated) {
  background: #1a1a1a;
}
body.darkmode .dashboard-card.deactivated {
  background: #1a1a1a;
  color: #888888;
}
body.darkmode .text-meta {
  color: #888888 !important;
}
body.darkmode .text-mono {
  color: #b0b0b0;
}
body.darkmode .text-serif {
  color: #e0e0e0;
}
body.darkmode .border-1 img {
  border-color: #333333;
}
body.darkmode .work-in-progress-banner {
  background: rgba(0, 0, 0, 0.9);
  color: #e0e0e0;
}
body.darkmode .work-in-progress-banner p {
  background: #ffeb3b;
  color: #121212;
}

/*# sourceMappingURL=style.css.map */
