@charset "UTF-8";
/*!
Theme Name: Kids in Tech 2
Theme URI: http://underscores.me/
Author: Abbi Aldrich
Author URI: http://abbialdrich.com
Description: Description
Version: 1.0.0
License: GNU General Public License v2 or later
License URI: LICENSE
Text Domain: kids-in-tech-2
Tags: custom-background, custom-logo, custom-menu, featured-images, threaded-comments, translation-ready

This theme, like WordPress, is licensed under the GPL.
Use it to make something cool, have fun, and share what you've learned with others.

Kids in Tech 2 is based on Underscores https://underscores.me/, (C) 2012-2017 Automattic, Inc.
Underscores is distributed under the terms of the GNU GPL v2 or later.

Normalizing styles have been helped along thanks to the fine work of
Nicolas Gallagher and Jonathan Neal https://necolas.github.io/normalize.css/
*/
/*--------------------------------------------------------------
>>> TABLE OF CONTENTS:
----------------------------------------------------------------
# Normalize
# Typography
# Elements
# Forms
# Navigation
	## Links
	## Menus
# Accessibility
# Alignments
# Clearings
# Layouts
# Widgets
# Content
	## Posts and pages
	## Comments
# Infinite scroll
# Media
	## Captions
	## Galleries
--------------------------------------------------------------*/
/*--------------------------------------------------------------
# Normalize
--------------------------------------------------------------*/
/*! normalize.css v8.0.0 | MIT License | github.com/necolas/normalize.css */
/* Document
	 ========================================================================== */
/**
 * 1. Correct the line height in all browsers.
 * 2. Prevent adjustments of font size after orientation changes in iOS.
 */
html {
  line-height: 1.15;
  /* 1 */
  -webkit-text-size-adjust: 100%;
  /* 2 */
}

/* Sections
	 ========================================================================== */
/**
 * Remove the margin in all browsers.
 */
body {
  margin: 0;
}

/**
 * Correct the font size and margin on `h1` elements within `section` and
 * `article` contexts in Chrome, Firefox, and Safari.
 */
h1 {
  font-size: 2em;
  margin: 0.67em 0;
}

/* Grouping content
	 ========================================================================== */
/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */
hr {
  box-sizing: content-box;
  /* 1 */
  height: 0;
  /* 1 */
  overflow: visible;
  /* 2 */
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
pre {
  font-family: monospace, monospace;
  /* 1 */
  font-size: 1em;
  /* 2 */
}

/* Text-level semantics
	 ========================================================================== */
/**
 * Remove the gray background on active links in IE 10.
 */
a {
  background-color: transparent;
}

/**
 * 1. Remove the bottom border in Chrome 57-
 * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 */
abbr[title] {
  border-bottom: none;
  /* 1 */
  text-decoration: underline;
  /* 2 */
  text-decoration: underline dotted;
  /* 2 */
}

/**
 * Add the correct font weight in Chrome, Edge, and Safari.
 */
b,
strong {
  font-weight: bolder;
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
code,
kbd,
samp {
  font-family: monospace, monospace;
  /* 1 */
  font-size: 1em;
  /* 2 */
}

/**
 * Add the correct font size in all browsers.
 */
small {
  font-size: 80%;
}

/**
 * Prevent `sub` and `sup` elements from affecting the line height in
 * all browsers.
 */
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

/* Embedded content
	 ========================================================================== */
/**
 * Remove the border on images inside links in IE 10.
 */
img {
  border-style: none;
}

/* Forms
	 ========================================================================== */
/**
 * 1. Change the font styles in all browsers.
 * 2. Remove the margin in Firefox and Safari.
 */
button,
input,
optgroup,
select,
textarea {
  font-family: inherit;
  /* 1 */
  font-size: 100%;
  /* 1 */
  line-height: 1.15;
  /* 1 */
  margin: 0;
  /* 2 */
}

/**
 * Show the overflow in IE.
 * 1. Show the overflow in Edge.
 */
button,
input {
  /* 1 */
  overflow: visible;
}

/**
 * Remove the inheritance of text transform in Edge, Firefox, and IE.
 * 1. Remove the inheritance of text transform in Firefox.
 */
button,
select {
  /* 1 */
  text-transform: none;
}

/**
 * Correct the inability to style clickable types in iOS and Safari.
 */
button,
[type=button],
[type=reset],
[type=submit] {
  -webkit-appearance: button;
}

/**
 * Remove the inner border and padding in Firefox.
 */
button::-moz-focus-inner,
[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

/**
 * Restore the focus styles unset by the previous rule.
 */
button:-moz-focusring,
[type=button]:-moz-focusring,
[type=reset]:-moz-focusring,
[type=submit]:-moz-focusring {
  outline: 1px dotted ButtonText;
}

/**
 * Correct the padding in Firefox.
 */
fieldset {
  padding: 0.35em 0.75em 0.625em;
}

/**
 * 1. Correct the text wrapping in Edge and IE.
 * 2. Correct the color inheritance from `fieldset` elements in IE.
 * 3. Remove the padding so developers are not caught out when they zero out
 *		`fieldset` elements in all browsers.
 */
legend {
  box-sizing: border-box;
  /* 1 */
  color: inherit;
  /* 2 */
  display: table;
  /* 1 */
  max-width: 100%;
  /* 1 */
  padding: 0;
  /* 3 */
  white-space: normal;
  /* 1 */
}

/**
 * Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */
progress {
  vertical-align: baseline;
}

/**
 * Remove the default vertical scrollbar in IE 10+.
 */
textarea {
  overflow: auto;
}

/**
 * 1. Add the correct box sizing in IE 10.
 * 2. Remove the padding in IE 10.
 */
[type=checkbox],
[type=radio] {
  box-sizing: border-box;
  /* 1 */
  padding: 0;
  /* 2 */
}

/**
 * Correct the cursor style of increment and decrement buttons in Chrome.
 */
[type=number]::-webkit-inner-spin-button,
[type=number]::-webkit-outer-spin-button {
  height: auto;
}

/**
 * 1. Correct the odd appearance in Chrome and Safari.
 * 2. Correct the outline style in Safari.
 */
[type=search] {
  -webkit-appearance: textfield;
  /* 1 */
  outline-offset: -2px;
  /* 2 */
}

/**
 * Remove the inner padding in Chrome and Safari on macOS.
 */
[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}

/**
 * 1. Correct the inability to style clickable types in iOS and Safari.
 * 2. Change font properties to `inherit` in Safari.
 */
::-webkit-file-upload-button {
  -webkit-appearance: button;
  /* 1 */
  font: inherit;
  /* 2 */
}

/* Interactive
	 ========================================================================== */
/*
 * Add the correct display in Edge, IE 10+, and Firefox.
 */
details {
  display: block;
}

/*
 * Add the correct display in all browsers.
 */
summary {
  display: list-item;
}

/* Misc
	 ========================================================================== */
/**
 * Add the correct display in IE 10+.
 */
template {
  display: none;
}

/**
 * Add the correct display in IE 10.
 */
[hidden] {
  display: none;
}

/*--------------------------------------------------------------
# Typography
--------------------------------------------------------------*/
body,
button,
input,
select,
optgroup,
textarea {
  color: #404040;
  font-family: "Arial", sans-serif;
  font-size: 16px;
  font-size: 1rem;
  line-height: 1.5;
}

h1, h2, h3, h4, h5, h6 {
  font-family: "uDIN1451MittelschriftRegular", "Trebuchet MS";
  font-weight: normal;
  clear: both;
  margin: 1rem 0;
}

h1 {
  font-size: 28px;
  font-size: 1.75rem;
  color: #404040;
}

h2 {
  font-size: 24px;
  font-size: 1.5rem;
  color: #2699fb;
}

h3.subtitle {
  color: #2699fb;
}

.front-page h2 {
  text-align: center;
  color: #404040;
}

p {
  margin-bottom: 1.5em;
}

dfn, cite, em, i {
  font-style: italic;
}

blockquote {
  margin: 0 1.5em;
  border-left: #404040 solid 3px;
  padding-left: 10px;
}

address {
  margin: 0 0 1.5em;
}

pre {
  background: #eee;
  font-family: "Courier 10 Pitch", Courier, monospace;
  font-size: 15px;
  font-size: 0.9375rem;
  line-height: 1.6;
  margin-bottom: 1.6em;
  max-width: 100%;
  overflow: auto;
  padding: 1.6em;
}

code, kbd, tt, var {
  font-family: Monaco, Consolas, "Andale Mono", "DejaVu Sans Mono", monospace;
  font-size: 15px;
  font-size: 0.9375rem;
}

abbr, acronym {
  border-bottom: 1px dotted #666;
  cursor: help;
}

mark, ins {
  background: #fff9c0;
  text-decoration: none;
}

big {
  font-size: 125%;
}

span.highlight {
  text-transform: uppercase;
  color: #2699fb;
}

/*--------------------------------------------------------------
# Elements
--------------------------------------------------------------*/
html {
  box-sizing: border-box;
}

*,
*:before,
*:after {
  /* Inherit box-sizing to make it easier to change the property for components that leverage other behavior; see https://css-tricks.com/inheriting-box-sizing-probably-slightly-better-best-practice/ */
  box-sizing: inherit;
}

body {
  background: #fff;
  /* Fallback for when there is no custom background color defined. */
}

.site-footer {
  background: #dcdcdc;
}

hr {
  background-color: #ccc;
  border: 0;
  height: 1px;
  margin-bottom: 1.5em;
}

ul, ol {
  margin: 0 0 1.5em 0;
  padding-left: 1rem;
}

ul {
  list-style: disc;
}

ol {
  list-style: decimal;
}

li > ul,
li > ol {
  margin-bottom: 0;
  margin-left: 0;
}

dt {
  font-weight: bold;
}

dd {
  margin: 0 1.5em 1.5em;
}

img {
  height: auto;
  /* Make sure images are scaled correctly. */
  max-width: 100%;
  /* Adhere to container width. */
}

figure {
  margin: 0;
  /* Extra wide images within figure tags don't overflow the content area. */
}

table {
  margin: 0 0 1.5em;
  width: 100%;
}

.featured-section .feature-group {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
}
@media (min-width: 600px) {
  .featured-section .feature-group {
    width: 48%;
  }
}
@media (min-width: 900px) {
  .featured-section .feature-group {
    flex-grow: 1;
    margin: 0 10px 0 0;
  }
}
@media (min-width: 900px) {
  .featured-section .feature-group:last-child {
    margin: 0;
  }
}
.featured-section .feature-group .feature_photo {
  max-width: 125px;
}
.featured-section .feature-group .feature_photo img {
  border-radius: 50%;
}
.featured-section .feature-group .feature-box {
  margin: 0 1rem 1rem;
  padding: 0.75rem 1.25rem;
  background-color: #ddeffe;
  text-align: center;
  height: 100%;
  width: 100%;
}
.featured-section .feature-group .feature-box h3 {
  color: #2699fb;
}
.featured-section .feature-group .feature-box p {
  color: #8c8c8c;
}
.featured-section .feature-group .feature_photo ~ .feature-box {
  position: relative;
  top: -30px;
  z-index: -1;
}

.front-page .generic-content-section p {
  text-align: center;
}

.cover-photo div {
  background-position: center 40%;
  background-size: cover;
  height: 25vh;
}
@media (min-width: 50rem) {
  .cover-photo div {
    height: 35vh;
  }
}
@media (min-width: 62.5rem) {
  .cover-photo div {
    height: 30vh;
  }
}

.full-width-banner {
  display: block;
  position: relative;
  min-height: 500px;
  background-image: url("/wp-content/uploads/2020/09/stem-banner-background.jpg");
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
  height: calc(100vh - 200px);
}
.full-width-banner.halved-banner {
  min-height: 300px;
  max-height: 500px;
}
.full-width-banner::before {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  top: 0;
  background: rgba(9, 158, 218, 0.75);
  height: 100%;
  width: 100%;
}
.full-width-banner::after {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  top: 50%;
  transform: translate(0, -50%);
  background: #ffffff;
  height: 10px;
  width: 100%;
  z-index: 1;
}
.full-width-banner .stem-logo {
  height: 300px;
  width: 300px;
  max-width: 50vw;
  position: absolute;
  display: inline-block;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  background: url("/wp-content/uploads/2020/09/mass-stem-logo.svg") no-repeat center center;
  background-size: contain;
  z-index: 3;
}
.full-width-banner .banner-overlay {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  top: 0;
  height: 100%;
  width: 100%;
}
.full-width-banner .banner-overlay::before, .full-width-banner .banner-overlay::after {
  content: "";
  display: inline-block;
  position: absolute;
  max-width: 200px;
  height: 200px;
  width: 20vw;
  background-image: url("/wp-content/uploads/2020/09/icon-stem-circuit-white.svg");
  background-repeat: no-repeat;
  background-size: contain;
  background-position: bottom center;
}
.full-width-banner .banner-overlay::before {
  left: 50px;
  bottom: 0;
}
.full-width-banner .banner-overlay::after {
  right: 50px;
  top: 0;
  transform: rotate(180deg);
}

.hero {
  position: relative;
  height: 60vh;
  z-index: -1;
}
@media (min-width: 50rem) {
  .hero {
    position: static;
  }
}
.hero .hero-img {
  background-position: center 40%;
  background-size: cover;
  height: inherit;
  position: relative;
  z-index: -1;
}
@media (min-width: 50rem) {
  .hero .hero-img {
    position: static;
  }
}

#hero-overlay {
  position: relative;
  z-index: -1;
  top: -85%;
  background-color: rgba(0, 159, 218, 0.5);
  text-align: center;
  width: 85%;
  margin: 0 auto;
  padding: 2rem;
  font-family: "Arial", sans-serif;
  color: white;
}
@media (min-width: 600px) {
  #hero-overlay {
    width: 70%;
    top: -80%;
  }
}
@media (min-width: 50rem) {
  #hero-overlay {
    z-index: 0;
  }
}
@media (min-width: 900px) {
  #hero-overlay {
    width: 50%;
    top: -80%;
  }
}
#hero-overlay p {
  font-size: 14.4px;
  font-size: 0.9rem;
}
@media (min-width: 600px) {
  #hero-overlay p {
    font-size: 16px;
    font-size: 1rem;
  }
}
#hero-overlay h2 {
  margin: 0;
  color: white;
  font-size: 22.4px;
  font-size: 1.4rem;
}
@media (min-width: 600px) {
  #hero-overlay h2 {
    font-size: 24px;
    font-size: 1.5rem;
  }
}
#hero-overlay .button {
  display: none;
  background-color: white;
  color: #2699fb;
  padding: 0.75rem 1.5rem;
  border-radius: 4px;
  font-size: 12px;
  font-size: 0.75rem;
  font-weight: bold;
}
@media (min-width: 50rem) {
  #hero-overlay .button {
    display: inline;
  }
}

.results-section {
  text-align: center;
}
.results-section .result-group {
  width: 100%;
}
@media (min-width: 600px) {
  .results-section .result-group {
    width: 30%;
  }
}
.results-section .result-group .result {
  font-weight: bold;
  font-size: 56px;
  font-size: 3.5rem;
  margin: 0;
}

.sa_hover_container {
  min-height: 150px !important;
  max-height: 250px;
  display: flex;
  align-items: center;
}

.owl-prev {
  left: -30px !important;
}

.owl-next {
  right: -30px !important;
}

.nextend-bullet-bar {
  top: -40px;
  position: relative;
}

.donation-widget.tabs {
  max-width: 1200px !important;
}

.testimonials .circle-image img {
  border-radius: 50% !important;
}

.n2-ss-slider .n2-ow-all img, .n2-ss-slider img.n2-ow {
  border-radius: 50% !important;
}

.newsletter-pu-background + figcaption {
  font-size: 8vw;
  position: absolute;
  font-family: "uDIN1451MittelschriftRegular", "Trebuchet MS";
  text-align: left;
  font-weight: bold;
  z-index: 200;
  color: white;
  bottom: 80px;
  left: 10px;
  width: 85%;
}
@media (min-width: 600px) {
  .newsletter-pu-background + figcaption {
    bottom: 80px;
    font-size: 45px;
    width: 67%;
    left: 15px;
  }
}
@media (min-width: 900px) {
  .newsletter-pu-background + figcaption {
    bottom: 55px;
    font-size: 53px;
    width: 500px;
    left: 15px;
  }
}

#popmake-266 .wp-caption {
  margin: 0;
}
#popmake-266 h3 {
  font-size: 4vw;
  max-width: 500px;
}
@media (min-width: 600px) {
  #popmake-266 h3 {
    font-size: 22px;
    max-width: 590px;
  }
}
@media (min-width: 900px) {
  #popmake-266 h3 {
    max-width: 650px;
  }
}
#popmake-266 p {
  text-align: center;
  margin: 0;
}

html.pum-open.pum-open-overlay.pum-open-scrollable body > [aria-hidden] {
  padding-right: 0 !important;
}

#popmake-223 p {
  margin: 0;
}

.people .feature-box {
  padding: 0.75rem 1.25rem;
  background-color: #ddeffe;
  text-align: center;
  width: 100%;
}
@media (min-width: 900px) {
  .people .feature-box {
    width: 31%;
  }
}
.people .feature-box h3 {
  color: #2699fb;
}
.people .feature-box .list {
  color: #8c8c8c;
}
.people .feature-box .list a {
  display: block;
  color: #8c8c8c;
  padding-bottom: 0.5rem;
}
.people .feature-box .list a:hover {
  color: #2699fb;
}

.column {
  width: 100%;
}
.column .block-content {
  width: 100%;
}
@media (min-width: 600px) {
  .column {
    flex-grow: 1;
    margin-right: 25px;
  }
}
@media (min-width: 600px) {
  .column:last-child {
    margin-right: 0;
  }
}

.content-block {
  margin-top: 0;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}
@media (min-width: 600px) {
  .content-block {
    flex-wrap: nowrap;
  }
}

.icon {
  min-width: 70px;
  height: 70px;
  display: flex;
  justify-content: center;
  align-items: center;
  color: #2699fb;
  border-radius: 50%;
  border: #2699fb 5px solid;
  border-width: 5px;
  justify-content: center;
  align-content: center;
}
@media (min-width: 600px) {
  .icon {
    min-width: 80px;
    height: 80px;
    margin: 1rem 1rem 0 0;
  }
}
.icon .wow_icon_outer_alignleft {
  margin: 0;
}
.icon .wow_icon_element_inner {
  display: flex;
}
.icon .wow_icon_element_inner .wow_icon_element_icon_size_nm {
  font-size: 2rem !important;
}

article.press {
  border-bottom: 1px solid #8c8c8c;
  padding: 1rem 0;
}
article.press .press {
  margin: 0;
}
article.press .category, article.press .publication-date {
  font-size: 14.4px;
  font-size: 0.9rem;
}

.category {
  margin: 0.25rem 0;
}
.category a {
  color: #404040 !important;
  font-weight: bold;
}
.category a:hover, .category a:focus, .category a:active {
  color: #404040;
}

.post-thumbnail {
  margin-top: 1em;
}

.single-post {
  margin-bottom: 2rem;
}
.single-post h2 {
  margin: 0;
}

#dafdirectdiv {
  width: 100% !important;
}
#dafdirectdiv .whatThis {
  text-align: center;
}
#dafdirectdiv .whatThis a {
  display: inline;
  position: relative;
  top: -20px;
  border: none;
}
#dafdirectdiv .dafdirectDonateFrom {
  width: 100%;
}
#dafdirectdiv .dafdirectInputFull {
  width: 100%;
}
#dafdirectdiv .dafdirectscroll {
  width: 100%;
}

/*--------------------------------------------------------------
# Forms
--------------------------------------------------------------*/
.button,
button,
#caldera_form_1 .button,
input[type=button],
input[type=reset],
input[type=submit] {
  border-radius: 3px;
  background-color: #2699fb;
  color: #fff;
  font-size: 12px;
  font-size: 0.75rem;
  line-height: 1.25rem;
  padding: 0.25rem 0.5rem;
  text-transform: uppercase;
  border: none;
}
.button:hover,
button:hover,
#caldera_form_1 .button:hover,
input[type=button]:hover,
input[type=reset]:hover,
input[type=submit]:hover {
  border-color: #ccc #bbb #aaa;
}
.button:active, .button:focus,
button:active,
button:focus,
#caldera_form_1 .button:active,
#caldera_form_1 .button:focus,
input[type=button]:active,
input[type=button]:focus,
input[type=reset]:active,
input[type=reset]:focus,
input[type=submit]:active,
input[type=submit]:focus {
  border-color: #aaa #bbb #bbb;
}

.button-section {
  margin-top: 1.5rem !important;
}
.button-section .button {
  padding: 0.75rem 2rem;
  display: inline-block;
}
.button-section .button a {
  color: #fff;
}
.button-section .button p {
  margin: 0;
}

.add-button {
  padding: 0.75rem 2rem;
  display: inline-block;
  text-align: center;
}
.add-button a {
  color: #fff;
}
.add-button p {
  margin: 0;
}

.button-container {
  text-align: center;
}
.button-container .button {
  min-width: 90px;
}

.mc4wp-form-fields input[type=button],
.mc4wp-form-fields input[type=reset],
.mc4wp-form-fields input[type=submit] {
  height: 30px;
}
@media (min-width: 600px) {
  .mc4wp-form-fields input[type=button],
.mc4wp-form-fields input[type=reset],
.mc4wp-form-fields input[type=submit] {
    width: 90px;
  }
}

input[type=text],
input[type=email],
input[type=url],
input[type=password],
input[type=search],
input[type=number],
input[type=phone],
input[type=tel],
input[type=range],
input[type=date],
input[type=month],
input[type=week],
input[type=time],
input[type=datetime],
input[type=datetime-local],
input[type=color],
textarea {
  color: #404040;
  border: 1px solid #2699fb;
  border-radius: 3px;
  padding: 3px;
}
input[type=text]:focus,
input[type=email]:focus,
input[type=url]:focus,
input[type=password]:focus,
input[type=search]:focus,
input[type=number]:focus,
input[type=phone]:focus,
input[type=tel]:focus,
input[type=range]:focus,
input[type=date]:focus,
input[type=month]:focus,
input[type=week]:focus,
input[type=time]:focus,
input[type=datetime]:focus,
input[type=datetime-local]:focus,
input[type=color]:focus,
textarea:focus {
  color: #2699fb;
}

select {
  border: 1px solid #2699fb;
}

textarea {
  width: 100%;
}

.mc4wp-form-fields input[type=email] {
  font-size: 0.75rem;
  padding-left: 0.75rem;
  width: 70%;
  height: 30px;
}
@media (min-width: 600px) {
  .mc4wp-form-fields input[type=email] {
    width: 250px;
  }
}

#caldera_form_1 .form-control::placeholder {
  color: #2699fb;
}
#caldera_form_1 input, #caldera_form_1 select {
  border-width: 0 0 1px 0;
  box-shadow: none;
  border-color: #404040;
  color: #404040;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}
#caldera_form_1 input:focus, #caldera_form_1 select:focus {
  color: #2699fb;
  border-color: #2699fb;
}
#caldera_form_1 input option, #caldera_form_1 select option {
  color: #404040;
}
#caldera_form_1 textarea {
  border: 1px solid #404040;
  color: #404040;
  box-shadow: none;
}
#caldera_form_1 textarea:focus {
  color: #2699fb;
  border-color: #2699fb;
}
#caldera_form_1 .select-div:after {
  content: ">";
  font: 17px "Consolas", monospace;
  color: #2699fb;
  -webkit-transform: rotate(90deg);
  -moz-transform: rotate(90deg);
  -ms-transform: rotate(90deg);
  transform: rotate(90deg);
  position: absolute;
  right: 20px;
  bottom: 21px;
  pointer-events: none;
}

/*--------------------------------------------------------------
# Navigation
--------------------------------------------------------------*/
/*--------------------------------------------------------------
## Links
--------------------------------------------------------------*/
a {
  color: #2699fb;
  text-decoration: none;
}
a:visited {
  color: #2699fb;
}
a:hover, a:focus, a:active {
  color: #2699fb;
}
a:focus {
  outline: thin dotted;
}
a:hover, a:active {
  outline: 0;
}

/*--------------------------------------------------------------
## Menus
--------------------------------------------------------------*/
.main-navigation {
  display: block;
  float: left;
  margin-top: 1rem;
}
.main-navigation .menu-main-menu-container {
  position: absolute;
  width: 100%;
  right: 0;
}
.main-navigation ul {
  display: none;
  list-style: none;
  margin: 0;
  padding-left: 0;
}
.main-navigation ul ul {
  box-shadow: 0 3px 3px rgba(0, 0, 0, 0.2);
  float: left;
  display: none;
}
.main-navigation ul ul li {
  color: #fff;
}
.main-navigation ul ul li:hover, .main-navigation ul ul li:active,
.main-navigation ul ul li .focus {
  background-color: #2699fb;
}
.main-navigation ul ul li:hover > ul, .main-navigation ul ul li:active > ul, .main-navigation ul ul li.focus > ul {
  left: 100%;
}
.main-navigation ul ul a {
  color: #fff;
}
.main-navigation ul ul a:hover, .main-navigation ul ul a:active,
.main-navigation ul ul a .focus {
  text-decoration: underline;
}
.main-navigation ul ul:hover > a, .main-navigation ul ul:active > a,
.main-navigation ul ul .focus > a {
  color: #fff;
}
.main-navigation ul li:hover > ul,
.main-navigation ul li:active > ul,
.main-navigation ul li.focus > ul {
  left: auto;
}
.main-navigation li {
  float: left;
  position: relative;
}
.main-navigation li a {
  width: 100%;
  padding: 0.25rem 5vw;
}
.main-navigation li:hover li, .main-navigation li:active li,
.main-navigation li .focus li {
  background-color: #2699fb;
}
.main-navigation li > a:after {
  content: " +";
  font-size: 17px;
}
.main-navigation li > a:only-child:after {
  content: "";
}
.main-navigation a {
  display: block;
  text-decoration: none;
  color: #000;
  font-family: "uDIN1451MittelschriftRegular", "Trebuchet MS";
  text-transform: uppercase;
  font-size: 12.8px;
  font-size: 0.8rem;
}
.main-navigation a:hover, .main-navigation a:active,
.main-navigation a .focus {
  color: #2699fb;
}
@media (min-width: 1200px) {
  .main-navigation a {
    font-size: 14.4px;
    font-size: 0.9rem;
    padding: 0 0.6rem;
  }
}
.main-navigation .sub-menu a:hover, .main-navigation .sub-menu a:active,
.main-navigation .sub-menu a .focus {
  color: #fff;
  background-color: #2699fb;
}
.main-navigation .current_page_item > a,
.main-navigation .current-menu-item > a,
.main-navigation .current_page_ancestor > a,
.main-navigation .current-menu-ancestor > a {
  color: #2699fb;
}

#main-menu > li:last-child {
  background-color: #2699fb;
}
#main-menu > li:last-child a {
  color: #fff;
}

.social-navigation {
  width: 100%;
}
.social-navigation ul {
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  justify-content: space-between;
}
.social-navigation ul li {
  display: inline;
}
.social-navigation ul li a {
  color: #9b9b9b;
  font-size: 20px;
  font-size: 1.25rem;
}
.social-navigation ul li a:hover, .social-navigation ul li a:active .focus {
  color: #2699fb;
}

.widget_nav_menu {
  width: 100%;
}
.widget_nav_menu .menu {
  max-width: 170px;
  padding: 0;
  list-style: none;
  margin: 0;
  display: flex;
  justify-content: space-between;
}
.widget_nav_menu .menu li {
  display: inline;
}
.widget_nav_menu .menu li a {
  color: #636363;
  font-size: 20px;
  font-size: 1.25rem;
  padding: 0;
}
.widget_nav_menu .menu li a:hover, .widget_nav_menu .menu li a:active, .widget_nav_menu .menu li a.focus {
  color: #2699fb;
}

/* Small menu.  add breakpoint at 750px for menu toggle */
.menu-toggle {
  background: none;
  font-size: 2rem;
  color: #2699fb;
  padding: 0.25rem;
  cursor: pointer;
  text-align: right;
}

.main-navigation.toggled ul {
  display: flex;
  flex-direction: column;
  background: white;
  opacity: 0.99;
  z-index: 1000;
}
.main-navigation.toggled ul ul {
  display: none;
}
.main-navigation.toggled ul li:hover > ul, .main-navigation.toggled ul li:active > ul, .main-navigation.toggled ul li.focus > ul {
  display: block;
  width: 100%;
}
.main-navigation.toggled ul li:hover > ul li, .main-navigation.toggled ul li:active > ul li, .main-navigation.toggled ul li.focus > ul li {
  transition: all 100ms ease;
  width: 100%;
}
.main-navigation.toggled ul li:hover > ul li a, .main-navigation.toggled ul li:active > ul li a, .main-navigation.toggled ul li.focus > ul li a {
  width: 100%;
  padding-left: 8vw;
}

@media (min-width: 50rem) {
  .social-navigation {
    width: 150px;
  }

  .menu-toggle {
    display: none;
  }

  #main-menu {
    display: flex;
    justify-content: space-between;
    width: 90vw;
    margin: 0 auto;
    flex-direction: row;
  }

  .main-navigation {
    margin-top: 0;
  }
  .main-navigation .menu-main-menu-container {
    position: absolute;
    width: 100%;
    right: 0;
    top: 6rem;
    display: flex;
    justify-content: center;
    background-color: white;
    padding: 0.5rem 0;
  }
  .main-navigation .menu-main-menu-container ul {
    left: -999em;
    top: 0;
    display: block;
  }
  .main-navigation .menu-main-menu-container ul li {
    padding: 0.25rem 0;
  }
  .main-navigation .menu-main-menu-container ul li a {
    padding: 0;
  }
  .main-navigation .menu-main-menu-container ul ul {
    position: absolute;
    top: 100%;
    left: -999em;
    z-index: 99999;
  }
  .main-navigation .menu-main-menu-container ul ul a {
    padding-left: 10px;
  }

  #main-menu > li:last-child {
    background-color: #2699fb;
    padding: 0.25rem 0.5rem;
    border-radius: 3px;
  }
  #main-menu > li:last-child a {
    color: #fff;
    padding: 0 0.5rem;
  }
}
@media (min-width: 62.5rem) {
  .main-navigation {
    width: 100%;
    max-width: 720px;
  }
  .main-navigation .menu-main-menu-container {
    position: relative;
    top: 0;
    width: 100%;
    display: flex;
    justify-content: center;
    padding: 0;
  }
  .main-navigation ul {
    display: flex;
    justify-content: space-between;
    width: inherit;
    margin: 0 auto;
  }
}
@media (min-width: 1200px) {
  .main-navigation {
    max-width: 820px;
  }
  .main-navigation li > a:after {
    content: " +";
    font-size: 20px;
  }
}
.site-main .comment-navigation,
.site-main .posts-navigation,
.site-main .post-navigation {
  margin: 0 0 1.5em;
  overflow: hidden;
}
.comment-navigation .nav-previous,
.posts-navigation .nav-previous,
.post-navigation .nav-previous {
  float: left;
  width: 50%;
}
.comment-navigation .nav-next,
.posts-navigation .nav-next,
.post-navigation .nav-next {
  float: right;
  text-align: right;
  width: 50%;
}

/*--------------------------------------------------------------
# Accessibility
--------------------------------------------------------------*/
/* Text meant only for screen readers. */
.screen-reader-text {
  border: 0;
  clip: rect(1px, 1px, 1px, 1px);
  clip-path: inset(50%);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute !important;
  width: 1px;
  word-wrap: normal !important;
  /* Many screen reader and browser combinations announce broken words as they would appear visually. */
}
.screen-reader-text:focus {
  background-color: #f1f1f1;
  border-radius: 3px;
  box-shadow: 0 0 2px 2px rgba(0, 0, 0, 0.6);
  clip: auto !important;
  clip-path: none;
  color: #21759b;
  display: block;
  font-size: 14px;
  font-size: 0.875rem;
  font-weight: bold;
  height: auto;
  left: 5px;
  line-height: normal;
  padding: 15px 23px 14px;
  text-decoration: none;
  top: 5px;
  width: auto;
  z-index: 100000;
  /* Above WP toolbar. */
}

/* Do not show the outline on the skip link target. */
#content[tabindex="-1"]:focus {
  outline: 0;
}

/*--------------------------------------------------------------
# Alignments
--------------------------------------------------------------*/
.alignleft {
  display: inline;
  float: left;
  margin-right: 1.5em;
}

.alignright {
  display: inline;
  float: right;
  margin-left: 1.5em;
}

.aligncenter {
  clear: both;
  display: block;
  margin-left: auto;
  margin-right: auto;
}

/*--------------------------------------------------------------
# Clearings
--------------------------------------------------------------*/
.clear:before,
.clear:after,
.entry-content:before,
.entry-content:after,
.comment-content:before,
.comment-content:after,
.site-header:before,
.site-header:after,
.site-content:before,
.site-content:after,
.site-footer:before,
.site-footer:after {
  content: "";
  display: table;
  table-layout: fixed;
}

.clear:after,
.entry-content:after,
.comment-content:after,
.site-header:after,
.site-content:after,
.site-footer:after {
  clear: both;
}

/*--------------------------------------------------------------
# Layouts
--------------------------------------------------------------*/
.site-margin {
  width: 90vw;
  margin: 0 auto;
}

.content-margin {
  width: 75vw;
  margin: 10vh auto;
}
.content-margin section {
  margin-top: 4rem;
}
@media (min-width: 600px) {
  .content-margin section {
    margin-top: 5rem;
  }
}

.entry-content section:first-child {
  margin-top: 0;
}

.site-header {
  display: flex;
  justify-content: center;
  align-items: center;
}
.site-header .site-margin {
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  min-height: 12vh;
}
.site-header .site-margin .site-branding {
  width: 65%;
  align-self: center;
}
.site-header .site-margin .site-branding img {
  padding: 5px 0;
}
@media (min-width: 50rem) {
  .site-header .site-margin .site-branding {
    width: 250px;
  }
}
@media (min-width: 62.5rem) {
  .site-header .site-margin .site-branding {
    width: 25%;
  }
}
.site-header .site-margin .nav-group {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  justify-content: space-evenly;
  width: 30%;
}
@media (min-width: 50rem) {
  .site-header .site-margin .nav-group {
    justify-content: center;
  }
}
@media (min-width: 62.5rem) {
  .site-header .site-margin .nav-group {
    width: 75%;
    justify-content: space-evenly;
  }
}

.row {
  display: flex;
  flex-direction: row;
  justify-content: space-around;
  flex-wrap: wrap;
}
@media (min-width: 900px) {
  .row {
    justify-content: space-between;
    flex-wrap: nowrap;
  }
}

.button-section {
  text-align: center;
}

.footer-newsletter {
  width: 75vw;
  margin: 0 auto;
}

#footer-newsletter {
  text-align: center;
  color: #79c0fd;
}

.site-footer {
  padding: 10vh 0 5vh;
  display: flex;
  justify-content: center;
  align-items: center;
}
.site-footer .row {
  align-items: flex-start;
  flex-direction: column;
  flex-wrap: nowrap;
}
@media (min-width: 600px) {
  .site-footer .row {
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-around;
  }
}
.site-footer .widget-area {
  margin: 0;
  display: flex;
  flex-direction: column;
}
@media (min-width: 600px) {
  .site-footer .widget-area {
    width: 25%;
  }
}
@media (min-width: 900px) {
  .site-footer .widget-area {
    width: 22%;
  }
}
.site-footer .widget-area p {
  margin: 0;
  font-size: 14.4px;
  font-size: 0.9rem;
}
@media (min-width: 900px) {
  .site-footer .widget-area p {
    font-size: 16px;
    font-size: 1rem;
  }
}

#footer-area-1 {
  align-items: center;
}
@media (min-width: 600px) {
  #footer-area-1 {
    width: 100%;
    order: 5;
  }
}
@media (min-width: 900px) {
  #footer-area-1 {
    width: 22%;
    order: 0;
  }
}
@media (min-width: 600px) {
  #footer-area-1 .widget {
    width: 50%;
    text-align: center;
  }
}
@media (min-width: 900px) {
  #footer-area-1 .widget {
    width: 100%;
  }
}

#footer-area-2 {
  order: 2;
}

#footer-area-3 {
  order: 3;
}

#footer-area-4 {
  order: 1;
}
@media (min-width: 600px) {
  #footer-area-4 {
    order: 4;
  }
}

.content-margin.with-sidebar {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
@media (min-width: 600px) {
  .content-margin.with-sidebar {
    flex-direction: row;
  }
}

#primary {
  width: 100%;
}
@media (min-width: 600px) {
  #primary {
    width: 65%;
  }
}

#secondary {
  width: 100%;
}
@media (min-width: 600px) {
  #secondary {
    width: 30%;
  }
}

.stem-layout .button {
  padding: 10px;
  font-size: 16px;
  line-height: 20px;
}
.stem-layout .button:visited {
  color: #ffffff !important;
}
.stem-layout .text-center {
  text-align: center;
}
.stem-layout .stem-intro-copy {
  display: block;
  position: relative;
  width: 100%;
  max-width: 800px;
  margin: 0 auto 50px;
  padding: 0 15px;
  box-sizing: border-box;
}
.stem-layout .content-area {
  margin: 5vw auto !important;
}
.stem-layout .icon-callouts-wrapper {
  position: relative;
  display: block;
}
.stem-layout .icon-callouts-wrapper::before, .stem-layout .icon-callouts-wrapper::after {
  content: "";
  height: 200px;
  width: 200px;
  position: absolute;
  background-repeat: no-repeat;
  background-size: contain;
  background-position: left center;
  top: 50%;
  z-index: -1;
}
.stem-layout .icon-callouts-wrapper::before {
  left: 0;
  transform: translate(0, -50%);
  background-image: url("/wp-content/uploads/2020/09/icon-stem-circuit-yellow.svg");
}
.stem-layout .icon-callouts-wrapper::after {
  right: 0;
  transform: translate(0, -50%) rotate(180deg);
  background-image: url("/wp-content/uploads/2020/09/icon-stem-circuit-yellow.svg");
}
.stem-layout .icon-callouts-wrapper .icon-callouts {
  display: block;
  position: relative;
  width: 100%;
  max-width: 1000px;
  margin: 0 auto;
  white-space: nowrap;
}
.stem-layout .icon-callouts-wrapper .icon-callouts .icon-callout {
  position: relative;
  display: inline-block;
  vertical-align: top;
  width: calc(33% - 1px);
  white-space: normal;
  text-align: center;
  margin: 0 0 30px;
  transition: margin 0.3s ease 0s;
}
.stem-layout .icon-callouts-wrapper .icon-callouts .icon-callout .icon-callout-hero {
  position: relative;
  display: block;
  width: 100%;
  max-height: 215px;
  height: 40vw;
  background-size: contain;
  background-position: center center;
  background-repeat: no-repeat;
  background-image: url("/wp-content/uploads/2020/09/circle-icon-good-digital-citizen.svg");
}
.stem-layout .icon-callouts-wrapper .icon-callouts .icon-callout h2 {
  font-size: 18px;
  line-height: 24px;
  letter-spacing: 2px;
  color: #000000;
}
.stem-layout .icon-callouts-wrapper .icon-callouts .icon-callout:hover {
  margin: -15px 0 30px;
}
@media (max-width: 600px) {
  .stem-layout .icon-callouts-wrapper::before, .stem-layout .icon-callouts-wrapper::after {
    display: none;
  }
  .stem-layout .icon-callouts-wrapper .icon-callouts {
    white-space: normal;
  }
  .stem-layout .icon-callouts-wrapper .icon-callouts .icon-callout {
    width: 100%;
    margin: 0 0 15px;
  }
}
.stem-layout .halved-content-wrapper {
  display: block;
  width: 100%;
  position: relative;
  margin-top: 4vw;
}
.stem-layout .halved-content-wrapper .halved-content-intro {
  display: block;
  position: relative;
  width: 100%;
  max-width: 800px;
  margin: 0 auto 60px;
  padding: 0 15px;
  box-sizing: border-box;
}
.stem-layout .halved-content-wrapper .halved-content-intro h2 {
  color: #000000;
  font-size: 32px;
  line-height: 36px;
  position: relative;
  padding-top: 20px;
  text-align: center;
}
.stem-layout .halved-content-wrapper .halved-content-intro h2::before {
  content: "";
  display: inline-block;
  height: 5px;
  width: 100px;
  background: #FACE41;
  position: absolute;
  left: 50%;
  top: 0;
  transform: translate(-50%, -50%);
}
.stem-layout .halved-content-wrapper .halved-content-row {
  display: block;
  width: 100%;
  position: relative;
  margin: 50px 0;
}
.stem-layout .halved-content-wrapper .halved-content-row::before {
  content: "";
  height: 50%;
  width: 100%;
  position: absolute;
  background-repeat: repeat;
  background-image: url("/wp-content/themes/kids-in-tech-2/img/pattern-dots.svg");
  background-position: center center;
  top: 50%;
  left: 0;
  transform: translate(0, -50%);
}
.stem-layout .halved-content-wrapper .halved-content-row .halved-content-row-inner {
  display: block;
  width: 100%;
  max-width: 1000px;
  padding: 0 15px;
  margin: 0 auto;
  box-sizing: border-box;
  position: relative;
  white-space: nowrap;
}
.stem-layout .halved-content-wrapper .halved-content-row .halved-content-row-inner .halved-image {
  position: relative;
  display: inline-block;
  vertical-align: middle;
  width: calc(48% - 1px);
  background-image: url("//placehold.it/500x500?text=Hero+Image");
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center center;
  max-height: 350px;
  height: 55vw;
  white-space: normal;
  box-shadow: -20px 20px 0px 0px #F4F4F4;
}
.stem-layout .halved-content-wrapper .halved-content-row .halved-content-row-inner .halved-image.halved-image-mobile {
  display: none;
}
.stem-layout .halved-content-wrapper .halved-content-row .halved-content-row-inner .halved-content {
  position: relative;
  display: inline-block;
  padding: 25px 40px 25px 25px;
  background: #ffffff;
  vertical-align: middle;
  width: calc(52% - 1px);
  white-space: normal;
}
.stem-layout .halved-content-wrapper .halved-content-row .halved-content-row-inner .halved-content h3 {
  color: #099EDA;
  font-size: 28px;
  line-height: 32px;
  font-weight: bold;
}
@media (max-width: 650px) {
  .stem-layout .halved-content-wrapper .halved-content-row {
    margin: 20px 0;
  }
  .stem-layout .halved-content-wrapper .halved-content-row::before {
    display: none;
  }
  .stem-layout .halved-content-wrapper .halved-content-row .halved-content-row-inner {
    white-space: normal;
  }
  .stem-layout .halved-content-wrapper .halved-content-row .halved-content-row-inner .halved-image {
    width: 100%;
    box-shadow: 0 20px 0 -10px #F4F4F4;
  }
  .stem-layout .halved-content-wrapper .halved-content-row .halved-content-row-inner .halved-image.halved-image-desktop {
    display: none;
  }
  .stem-layout .halved-content-wrapper .halved-content-row .halved-content-row-inner .halved-image.halved-image-mobile {
    display: block;
  }
  .stem-layout .halved-content-wrapper .halved-content-row .halved-content-row-inner .halved-content {
    width: 100%;
    background: none;
    padding: 15px 15px 0;
  }
}
.stem-layout .blue-banner {
  width: 100%;
  display: block;
  position: relative;
  background: #099EDA;
  padding: 40px 15px;
  box-sizing: border-box;
}
.stem-layout .blue-banner .blue-banner-content {
  display: block;
  width: 100%;
  max-width: 850px;
  padding: 0 15px;
  margin: 0 auto;
  box-sizing: border-box;
  position: relative;
  text-align: center;
}
.stem-layout .blue-banner .blue-banner-content * {
  color: #ffffff;
}
.stem-layout .blue-banner .blue-banner-content ol {
  margin: 0;
  padding: 0;
  counter-reset: count;
}
.stem-layout .blue-banner .blue-banner-content ol li {
  display: inline-block;
  position: relative;
  width: calc(50% - 3px);
  box-sizing: border-box;
  vertical-align: top;
  white-space: normal;
  text-align: left;
  letter-spacing: 1px;
  padding: 10px 15px 5px 25px;
}
.stem-layout .blue-banner .blue-banner-content ol li:before {
  content: counter(count);
  counter-increment: count;
  background: rgba(255, 255, 255, 0.2);
  border-radius: 100%;
  height: 30px;
  width: 30px;
  line-height: 30px;
  text-align: center;
  position: absolute;
  left: 0;
  top: 50%;
  transform: translate(-50%, -50%);
}
@media (max-width: 700px) {
  .stem-layout .blue-banner .blue-banner-content ol li {
    width: 100%;
    padding: 10px 0 5px 25px;
  }
}
.stem-layout .form-section {
  width: 100%;
  display: block;
  position: relative;
  padding: 40px 15px;
  box-sizing: border-box;
}
.stem-layout .form-section .form-content {
  display: block;
  width: 100%;
  max-width: 850px;
  padding: 0 15px;
  margin: 0 auto;
  box-sizing: border-box;
  position: relative;
}
.stem-layout .form-section .form-content h2 {
  color: #000000;
  font-size: 32px;
  line-height: 36px;
  position: relative;
  padding-top: 20px;
  text-align: center;
}
.stem-layout .form-section .form-content form {
  text-align: left;
  margin-top: 50px;
}
@media (max-width: 700px) {
  .stem-layout .form-section .form-content form div[class^=col-], .stem-layout .form-section .form-content form div[class*=" col-"] {
    width: 100% !important;
  }
}
.stem-layout .webinar-callouts {
  display: block;
  width: 100%;
  position: relative;
  margin-top: 4vw;
}
.stem-layout .webinar-callouts .webinar-intro {
  display: block;
  position: relative;
  width: 100%;
  max-width: 800px;
  margin: 0 auto 60px;
  padding: 0 15px;
  box-sizing: border-box;
}
.stem-layout .webinar-callouts .webinar-intro h2 {
  color: #000000;
  font-size: 32px;
  line-height: 36px;
  position: relative;
  padding-top: 20px;
  font-weight: bold;
}
.stem-layout .webinar-callouts .webinar-intro h2 span {
  font-size: 20px;
  line-height: 24px;
  display: block;
}
.stem-layout .webinar-callouts .webinar-row {
  display: block;
  width: 100%;
  position: relative;
  margin: 50px 0;
}
.stem-layout .webinar-callouts .webinar-row::before {
  content: "";
  height: 60%;
  width: 100%;
  position: absolute;
  background-repeat: repeat;
  background-image: url("/wp-content/themes/kids-in-tech-2/img/pattern-dots.svg");
  background-position: center center;
  top: 50%;
  left: 0;
  transform: translate(0, -65%);
  z-index: -1;
}
.stem-layout .webinar-callouts .webinar-row .webinar-row-inner {
  display: block;
  width: 100%;
  max-width: 1000px;
  padding: 0 15px;
  margin: 0 auto;
  box-sizing: border-box;
  position: relative;
  white-space: nowrap;
}
.stem-layout .webinar-callouts .webinar-row .webinar-row-inner .session-callout {
  display: inline-block;
  position: relative;
  vertical-align: top;
  white-space: normal;
  width: calc(50% - 30px);
  margin: 15px;
}
.stem-layout .webinar-callouts .webinar-row .webinar-row-inner .session-callout .session-callout-inner {
  display: block;
  position: relative;
  width: calc(100% - 30px);
  margin: 0 auto;
  background: #ffffff;
  border: 5px solid #F4F4F4;
  padding: 50px 15px 30px;
}
.stem-layout .webinar-callouts .webinar-row .webinar-row-inner .session-callout .session-callout-inner::before {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  width: calc(100% + 40px);
  height: 100%;
  background: #EF402F;
  z-index: -1;
  transform: translate(-50%, calc(-50% - 20px));
}
.stem-layout .webinar-callouts .webinar-row .webinar-row-inner .session-callout .session-callout-inner .session-bubble {
  height: 115px;
  width: 115px;
  color: #EF402F;
  border-radius: 100%;
  background: #ffffff;
  padding: 13px 0 0;
  position: absolute;
  left: 50%;
  top: 0;
  transform: translate(-50%, calc(-50% - 10px));
  border: 5px solid #F4F4F4;
  text-align: center;
  font-family: "uDIN1451MittelschriftRegular", "Trebuchet MS";
}
.stem-layout .webinar-callouts .webinar-row .webinar-row-inner .session-callout .session-callout-inner .session-bubble .bubble-title {
  display: block;
  position: relative;
  width: 100%;
  font-size: 18px;
}
.stem-layout .webinar-callouts .webinar-row .webinar-row-inner .session-callout .session-callout-inner .session-bubble .bubble-number {
  display: block;
  position: relative;
  width: 100%;
  font-size: 48px;
  line-height: 48px;
}
.stem-layout .webinar-callouts .webinar-row .webinar-row-inner .session-callout .session-callout-inner h3 {
  font-weight: bold;
  font-size: 24px;
  line-height: 26px;
}
.stem-layout .webinar-callouts .webinar-row .webinar-row-inner .session-callout .session-callout-inner .webinar-btn {
  position: absolute;
  background: #EF402F;
  padding: 20px 30px;
  color: #ffffff;
  left: 50%;
  bottom: 0;
  transform: translate(-50%, 50%);
  font-weight: bold;
  transition: background 0.3s ease 0s;
  white-space: nowrap;
}
.stem-layout .webinar-callouts .webinar-row .webinar-row-inner .session-callout .session-callout-inner .webinar-btn:hover {
  background: #C11D0E;
}
.stem-layout .webinar-callouts .webinar-row .webinar-row-inner .session-callout.session-blue .session-callout-inner::before {
  background: #099EDA;
}
.stem-layout .webinar-callouts .webinar-row .webinar-row-inner .session-callout.session-blue .session-callout-inner .session-bubble {
  color: #099EDA;
}
.stem-layout .webinar-callouts .webinar-row .webinar-row-inner .session-callout.session-blue .session-callout-inner .webinar-btn {
  background: #099EDA;
}
.stem-layout .webinar-callouts .webinar-row .webinar-row-inner .session-callout.session-blue .session-callout-inner .webinar-btn:hover {
  background: #0B77A2;
}
.stem-layout .webinar-callouts .webinar-row .webinar-row-inner .session-callout.session-yellow .session-callout-inner::before {
  background: #FACE41;
}
.stem-layout .webinar-callouts .webinar-row .webinar-row-inner .session-callout.session-yellow .session-callout-inner .session-bubble {
  color: #FACE41;
}
.stem-layout .webinar-callouts .webinar-row .webinar-row-inner .session-callout.session-yellow .session-callout-inner .webinar-btn {
  background: #FACE41;
}
.stem-layout .webinar-callouts .webinar-row .webinar-row-inner .session-callout.session-yellow .session-callout-inner .webinar-btn:hover {
  background: #E5AE00;
}
@media (max-width: 700px) {
  .stem-layout .webinar-callouts .webinar-row {
    margin: 0;
  }
  .stem-layout .webinar-callouts .webinar-row .webinar-row-inner {
    white-space: normal;
  }
  .stem-layout .webinar-callouts .webinar-row .webinar-row-inner .session-callout {
    width: 100%;
    margin: 20px 0 85px;
  }
}
.stem-layout .downloads-wrapper {
  position: relative;
  display: block;
}
.stem-layout .downloads-wrapper .downloads-inner {
  display: block;
  position: relative;
  width: 100%;
  max-width: 600px;
  margin: 0 auto;
}
.stem-layout .downloads-wrapper .downloads-inner h2 {
  color: #000000;
  font-size: 32px;
  line-height: 36px;
  position: relative;
  padding-top: 20px;
  font-weight: bold;
}
.stem-layout .downloads-wrapper .downloads-inner .downloads-section a {
  display: block;
  position: relative;
  width: 100%;
  line-height: 20px;
  font-size: 16px;
  color: #ffffff;
  background: #099EDA;
  text-align: left;
  padding: 15px 10px 15px 40px;
  transition: background 0.3s ease 0s, color 0.3s ease 0s;
}
.stem-layout .downloads-wrapper .downloads-inner .downloads-section a::before {
  content: "";
  height: 20px;
  width: 20px;
  background: url("/wp-content/uploads/2020/10/Icon-download.svg") no-repeat center center;
  background-size: contain;
  display: inline-block;
  position: absolute;
  left: 10px;
  top: 50%;
  transform: translate(0, -50%);
}
.stem-layout .downloads-wrapper .downloads-inner .downloads-section a:nth-child(even) {
  background: #0B77A2;
}
.stem-layout .downloads-wrapper .downloads-inner .downloads-section a:hover {
  background: #FACE41;
  color: #2F2A2B;
}
.stem-layout .downloads-wrapper .downloads-inner .downloads-section a.download-all {
  background: #FACE41;
  color: #2F2A2B;
}
.stem-layout .downloads-wrapper .downloads-inner .downloads-section a.download-all:hover {
  background: #E5AE00;
  color: #2F2A2B;
}
:root {
  --header-outer-height: 0;
}

.stem-2021 {
  overflow: hidden;
}
.stem-2021 .caldera-grid .radio {
  position: relative !important;
  display: block !important;
  padding-left: 0px;
  margin-left: 0;
}
.stem-2021 .caldera-grid .radio-inline {
  position: relative !important;
  display: inline-block !important;
  padding-left: 20px;
  margin-left: 0;
}
.stem-2021 .caldera-grid .radio input,
.stem-2021 .caldera-grid .radio-inline input {
  margin: 0 !important;
  width: 16px;
  height: 16px;
  border-radius: 100%;
  top: 50%;
  left: 0;
  position: absolute !important;
  display: inline-block !important;
  transform: translate(0, -50%);
}
.stem-2021 .caldera-grid .radio input[type=radio]:after,
.stem-2021 .caldera-grid .radio-inline input[type=radio]:after {
  width: 16px;
  height: 16px;
  border-radius: 100%;
  top: 50%;
  left: 50%;
  position: absolute !important;
  display: inline-block !important;
  background-color: #ffffff;
  content: "";
  visibility: visible;
  border: 1px solid #2F2A2B;
  transform: translate(-50%, -50%);
}
.stem-2021 .caldera-grid .radio input[type=radio]:checked:after,
.stem-2021 .caldera-grid .radio-inline input[type=radio]:checked:after {
  background-color: #099EDA;
}
.stem-2021 .highlight {
  font-size: 20px;
  line-height: 1.4em;
}
.stem-2021 h2 {
  color: #2F2A2B;
  font-size: 28px;
}
@media (max-width: 991px) {
  .stem-2021 h2 {
    font-size: 22px;
  }
}
@media (max-width: 767px) {
  .stem-2021 .highlight {
    font-size: 18px;
  }
}
.stem-2021 .main-banner {
  display: block;
  position: relative;
  height: calc(100vh - var(--header-outer-height));
  min-height: 500px;
  width: 100%;
  background-image: url("/wp-content/uploads/2021/09/stem-banner-2021.svg");
  background-size: cover;
  background-position: top center;
  background-repeat: repeat-x;
  transition: height 0.3s ease 0s;
}
@media (max-width: 767px) {
  .stem-2021 .main-banner {
    max-height: 50vh;
  }
}
.stem-2021 .intro-copy {
  padding-top: 60px;
  padding-bottom: 60px;
}
.stem-2021 .intro-copy .intro-copy-inner *:last-child {
  margin-bottom: 0;
}
@media (max-width: 767px) {
  .stem-2021 .intro-copy {
    padding-top: 30px;
    padding-bottom: 30px;
  }
}
.stem-2021 .video-wrapper {
  position: relative;
  padding-top: 60px;
  padding-bottom: 60px;
}
.stem-2021 .video-wrapper::before {
  content: "";
  height: 40%;
  width: 100%;
  position: absolute;
  background-repeat: repeat;
  background-image: url("/wp-content/themes/kids-in-tech-2/img/pattern-dots.svg");
  background-position: center center;
  top: 50%;
  left: 0;
  transform: translate(0, -50%);
}
.stem-2021 .video-wrapper a {
  display: block;
  position: relative;
  width: 100%;
  padding-top: 55%;
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
}
.stem-2021 .video-wrapper a::before {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.1);
}
.stem-2021 .video-wrapper a::after {
  content: "";
  font-family: "Font Awesome 5 Free", sans-serif;
  text-align: center;
  text-indent: 5px;
  font-size: 62px;
  line-height: 86px;
  color: #FACE41;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  display: block;
  height: 86px;
  width: 86px;
  border-radius: 100%;
  background: #ffffff;
  transition: box-shadow 0.3s ease 0s;
  box-shadow: 0 0 0 0 rgba(0, 0, 0, 0);
}
.stem-2021 .video-wrapper a:hover::after {
  box-shadow: 0 0 60px 10px rgba(0, 0, 0, 0.4);
}
@media (max-width: 767px) {
  .stem-2021 .video-wrapper {
    padding-top: 30px;
    padding-bottom: 30px;
  }
  .stem-2021 .video-wrapper a::after {
    height: 15vw;
    width: 15vw;
    font-size: 12vw;
    line-height: 15vw;
  }
}
.stem-2021 .icon-callouts-title-outer {
  position: relative;
  padding-top: 75px;
  padding-bottom: 75px;
}
.stem-2021 .icon-callouts-title-outer .icon-callouts-title {
  position: relative;
  padding-top: 75px;
  padding-bottom: 75px;
}
.stem-2021 .icon-callouts-title-outer .icon-callouts-title::before {
  content: "";
  height: 100%;
  width: 150%;
  background: #EF402F;
  display: block;
  left: 50%;
  top: 50%;
  position: absolute;
  transform: rotate(-4deg) translate(-50%, -50%);
  transform-origin: bottom left;
}
.stem-2021 .icon-callouts-title-outer .icon-callouts-title .icon-callouts-title-inner {
  position: relative;
  z-index: 2;
}
.stem-2021 .icon-callouts-title-outer .icon-callouts-title .icon-callouts-title-inner * {
  color: #ffffff;
}
.stem-2021 .icon-callouts-title-outer .icon-callouts-title .icon-callouts-title-inner *:first-child {
  margin-top: 0;
}
.stem-2021 .icon-callouts-title-outer .icon-callouts-title .icon-callouts-title-inner *:last-child {
  margin-bottom: 0;
}
.stem-2021 .icon-callouts {
  padding-bottom: 20px;
}
.stem-2021 .icon-callouts .icon-callout-inner {
  text-align: center;
  display: block;
  position: relative;
  padding-bottom: 40px;
}
.stem-2021 .icon-callouts .icon-callout-inner .icon-wrapper {
  display: block;
  position: relative;
  height: 90px;
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center bottom;
}
.stem-2021 .icon-callouts .icon-callout-inner h2 {
  margin-top: 25px;
  font-size: 22px;
}
.stem-2021 .divider-line {
  position: relative;
  display: block;
  width: 100%;
  height: 10px;
}
.stem-2021 .divider-line::after {
  content: "";
  display: block;
  height: 5px;
  width: 155px;
  border-radius: 10px;
  background: #EF402F;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.stem-2021 .form-intro {
  position: relative;
  padding-top: 60px;
  padding-bottom: 15px;
}
.stem-2021 .form-intro *:last-child {
  margin-bottom: 0;
}
.stem-2021 .form-wrapper {
  position: relative;
  padding-top: 30px;
  padding-bottom: 30px;
  margin: 15px 0 60px;
}
.stem-2021 .form-wrapper::before, .stem-2021 .form-wrapper::after {
  content: "";
  width: 150px;
  height: 100%;
  position: absolute;
  top: 0;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
}
.stem-2021 .form-wrapper::before {
  left: 0;
  background-image: url("/wp-content/uploads/2021/09/form-skirt-left.svg");
}
.stem-2021 .form-wrapper::after {
  right: 0;
  background-image: url("/wp-content/uploads/2021/09/form-skirt-right.svg");
}
.stem-2021 .form-wrapper form {
  text-align: left;
  margin-top: 50px;
}
@media (max-width: 700px) {
  .stem-2021 .form-wrapper form div[class^=col-], .stem-2021 .form-wrapper form div[class*=" col-"] {
    width: 100% !important;
  }
}
.stem-2021 .office-hours-title-outer {
  position: relative;
  padding-top: 75px;
  padding-bottom: 75px;
}
.stem-2021 .office-hours-title-outer .office-hours-title {
  position: relative;
  padding-top: 75px;
  padding-bottom: 75px;
}
.stem-2021 .office-hours-title-outer .office-hours-title::before {
  content: "";
  height: 100%;
  width: 150%;
  background: #099EDA;
  display: block;
  left: 50%;
  top: 50%;
  position: absolute;
  transform: rotate(-4deg) translate(-50%, -50%);
  transform-origin: bottom left;
}
.stem-2021 .office-hours-title-outer .office-hours-title .office-hours-title-inner {
  position: relative;
  z-index: 2;
}
.stem-2021 .office-hours-title-outer .office-hours-title .office-hours-title-inner * {
  color: #ffffff;
}
.stem-2021 .office-hours-title-outer .office-hours-title .office-hours-title-inner *:first-child {
  margin-top: 0;
}
.stem-2021 .office-hours-title-outer .office-hours-title .office-hours-title-inner *:last-child {
  margin-bottom: 0;
}
@media (max-width: 900px) {
  .stem-2021 .form-wrapper::before, .stem-2021 .form-wrapper::after {
    display: none;
  }
}
.stem-2021 .webinar-callouts {
  display: block;
  width: 100%;
  position: relative;
  margin-top: 2vw;
}
.stem-2021 .webinar-callouts .webinar-intro {
  display: block;
  position: relative;
  width: 100%;
  max-width: 800px;
  margin: 0 auto 90px;
  padding: 0 15px;
  box-sizing: border-box;
}
.stem-2021 .webinar-callouts .webinar-intro h2 {
  color: #000000;
  font-size: 32px;
  line-height: 36px;
  position: relative;
  padding-top: 20px;
  font-weight: bold;
}
.stem-2021 .webinar-callouts .webinar-intro h2 span {
  font-size: 20px;
  line-height: 24px;
  display: block;
}
.stem-2021 .webinar-callouts .webinar-row {
  display: block;
  width: 100%;
  position: relative;
  margin: 50px 0 115px;
}
.stem-2021 .webinar-callouts .webinar-row::before {
  content: "";
  height: 60%;
  width: 100%;
  position: absolute;
  background-repeat: repeat;
  background-image: url("/wp-content/themes/kids-in-tech-2/img/pattern-dots.svg");
  background-position: center center;
  top: 50%;
  left: 0;
  transform: translate(0, -65%);
  z-index: -1;
}
.stem-2021 .webinar-callouts .webinar-row .webinar-row-inner {
  display: block;
  width: 100%;
  max-width: 1000px;
  padding: 0 15px;
  margin: 0 auto;
  box-sizing: border-box;
  position: relative;
  white-space: nowrap;
}
.stem-2021 .webinar-callouts .webinar-row .webinar-row-inner .session-callout {
  display: inline-block;
  position: relative;
  vertical-align: top;
  white-space: normal;
  width: calc(50% - 30px);
  margin: 15px;
}
.stem-2021 .webinar-callouts .webinar-row .webinar-row-inner .session-callout .session-callout-inner {
  display: block;
  position: relative;
  width: calc(100% - 30px);
  margin: 0 auto;
  background: #ffffff;
  border: 5px solid #F4F4F4;
  padding: 50px 15px 30px;
}
.stem-2021 .webinar-callouts .webinar-row .webinar-row-inner .session-callout .session-callout-inner::before {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  width: calc(100% + 40px);
  height: 100%;
  background: #EF402F;
  z-index: -1;
  transform: translate(-50%, calc(-50% - 20px));
}
.stem-2021 .webinar-callouts .webinar-row .webinar-row-inner .session-callout .session-callout-inner .session-bubble {
  height: 115px;
  width: 115px;
  color: #EF402F;
  border-radius: 100%;
  background: #ffffff;
  padding: 13px 0 0;
  position: absolute;
  left: 50%;
  top: 0;
  transform: translate(-50%, calc(-50% - 10px));
  border: 5px solid #F4F4F4;
  text-align: center;
  font-family: "uDIN1451MittelschriftRegular", "Trebuchet MS";
}
.stem-2021 .webinar-callouts .webinar-row .webinar-row-inner .session-callout .session-callout-inner .session-bubble .bubble-title {
  display: block;
  position: relative;
  width: 100%;
  font-size: 18px;
}
.stem-2021 .webinar-callouts .webinar-row .webinar-row-inner .session-callout .session-callout-inner .session-bubble .bubble-number {
  display: block;
  position: relative;
  width: 100%;
  font-size: 48px;
  line-height: 48px;
}
.stem-2021 .webinar-callouts .webinar-row .webinar-row-inner .session-callout .session-callout-inner h3 {
  font-weight: bold;
  font-size: 24px;
  line-height: 26px;
}
.stem-2021 .webinar-callouts .webinar-row .webinar-row-inner .session-callout .session-callout-inner .webinar-btn {
  position: absolute;
  background: #EF402F;
  padding: 20px 30px;
  color: #ffffff;
  left: 50%;
  bottom: 0;
  transform: translate(-50%, 50%);
  font-weight: bold;
  transition: background 0.3s ease 0s;
  white-space: nowrap;
}
.stem-2021 .webinar-callouts .webinar-row .webinar-row-inner .session-callout .session-callout-inner .webinar-btn:hover {
  background: #C11D0E;
}
.stem-2021 .webinar-callouts .webinar-row .webinar-row-inner .session-callout.session-blue .session-callout-inner::before {
  background: #099EDA;
}
.stem-2021 .webinar-callouts .webinar-row .webinar-row-inner .session-callout.session-blue .session-callout-inner .session-bubble {
  color: #099EDA;
}
.stem-2021 .webinar-callouts .webinar-row .webinar-row-inner .session-callout.session-blue .session-callout-inner .webinar-btn {
  background: #099EDA;
}
.stem-2021 .webinar-callouts .webinar-row .webinar-row-inner .session-callout.session-blue .session-callout-inner .webinar-btn:hover {
  background: #0B77A2;
}
.stem-2021 .webinar-callouts .webinar-row .webinar-row-inner .session-callout.session-yellow .session-callout-inner::before {
  background: #FACE41;
}
.stem-2021 .webinar-callouts .webinar-row .webinar-row-inner .session-callout.session-yellow .session-callout-inner .session-bubble {
  color: #FACE41;
}
.stem-2021 .webinar-callouts .webinar-row .webinar-row-inner .session-callout.session-yellow .session-callout-inner .webinar-btn {
  background: #FACE41;
}
.stem-2021 .webinar-callouts .webinar-row .webinar-row-inner .session-callout.session-yellow .session-callout-inner .webinar-btn:hover {
  background: #E5AE00;
}
@media (max-width: 700px) {
  .stem-2021 .webinar-callouts .webinar-row {
    margin: 0;
  }
  .stem-2021 .webinar-callouts .webinar-row .webinar-row-inner {
    white-space: normal;
  }
  .stem-2021 .webinar-callouts .webinar-row .webinar-row-inner .session-callout {
    width: 100%;
    margin: 20px 0 85px;
  }
}

/*--------------------------------------------------------------
# Widgets
--------------------------------------------------------------*/
.widget {
  margin: 0 0 1.5em;
  /* Make sure select elements fit in widgets. */
}
.widget select {
  max-width: 100%;
}

/*--------------------------------------------------------------
# Content
--------------------------------------------------------------*/
/*--------------------------------------------------------------
## Posts and pages
--------------------------------------------------------------*/
.sticky {
  display: block;
}

.post {
  margin: 0 0 1.5em;
}

.updated:not(.published) {
  display: none;
}

.page-content,
.entry-content,
.entry-summary {
  margin: 0;
}

.page-links {
  clear: both;
  margin: 0 0 1.5em;
}

/*--------------------------------------------------------------
## Comments
--------------------------------------------------------------*/
.comment-content a {
  word-wrap: break-word;
}

.bypostauthor {
  display: block;
}

/*--------------------------------------------------------------
# Infinite scroll
--------------------------------------------------------------*/
/* Globally hidden elements when Infinite Scroll is supported and in use. */
.infinite-scroll .posts-navigation,
.infinite-scroll.neverending .site-footer {
  /* Theme Footer (when set to scrolling) */
  display: none;
}

/* When Infinite Scroll has reached its end we need to re-display elements that were hidden (via .neverending) before. */
.infinity-end.neverending .site-footer {
  display: block;
}

/*--------------------------------------------------------------
# Media
--------------------------------------------------------------*/
.page-content .wp-smiley,
.entry-content .wp-smiley,
.comment-content .wp-smiley {
  border: none;
  margin-bottom: 0;
  margin-top: 0;
  padding: 0;
}

/* Make sure embeds and iframes fit their containers. */
embed,
iframe,
object {
  max-width: 100%;
}

/* Make sure logo link wraps around logo image. */
.custom-logo-link {
  display: inline-block;
}

/*--------------------------------------------------------------
## Captions
--------------------------------------------------------------*/
.wp-caption {
  margin-bottom: 1.5em;
  max-width: 100%;
}
.wp-caption img[class*=wp-image-] {
  display: block;
  margin-left: auto;
  margin-right: auto;
}
.wp-caption .wp-caption-text {
  margin: 0.8075em 0;
}

.wp-caption-text {
  text-align: center;
}

/*--------------------------------------------------------------
## Galleries
--------------------------------------------------------------*/
.gallery {
  margin-bottom: 1.5em;
}

.gallery-item {
  display: inline-block;
  text-align: center;
  vertical-align: top;
  width: 100%;
}
.gallery-columns-2 .gallery-item {
  max-width: 50%;
}
.gallery-columns-3 .gallery-item {
  max-width: 33.33%;
}
.gallery-columns-4 .gallery-item {
  max-width: 25%;
}
.gallery-columns-5 .gallery-item {
  max-width: 20%;
}
.gallery-columns-6 .gallery-item {
  max-width: 16.66%;
}
.gallery-columns-7 .gallery-item {
  max-width: 14.28%;
}
.gallery-columns-8 .gallery-item {
  max-width: 12.5%;
}
.gallery-columns-9 .gallery-item {
  max-width: 11.11%;
}

.gallery-caption {
  display: block;
}

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