/**
 * Intentionally empty.
 */
/* How do I get this to run SASS or LESS or something? */
@font-face {
  font-family: "Bebas Neue Regular";
  src: url("/assets/fonts/BebasNeue-Regular.woff2") format("woff2"), url("/assets/fonts/BebasNeue-Regular.woff") format("woff");
  font-weight: bold;
  font-style: normal;
}
@font-face {
  font-family: "Bebas Neue Regular";
  src: url("/assets/fonts/BebasNeue-Regular.woff2") format("woff2"), url("/assets/fonts/BebasNeue-Regular.woff") format("woff");
  font-weight: 200;
  font-style: normal;
}
@font-face {
  font-family: "Bebas Neue Regular";
  src: url("/assets/fonts/BebasNeue-Regular.woff2") format("woff2"), url("/assets/fonts/BebasNeue-Regular.woff") format("woff");
  font-weight: 600;
  font-style: normal;
}
@font-face {
  font-family: "Bebas Neue Regular";
  src: url("/assets/fonts/BebasNeue-Regular.woff2") format("woff2"), url("/assets/fonts/BebasNeue-Regular.woff") format("woff");
  font-weight: normal;
  font-style: normal;
}
@font-face {
  font-family: "Bebas Neue Regular";
  src: url("/assets/fonts/BebasNeue-Regular.woff2") format("woff2"), url("/assets/fonts/BebasNeue-Regular.woff") format("woff");
  font-weight: 100;
  font-style: normal;
}
@font-face {
  font-family: "Lemonmilk";
  src: url("/assets/fonts/lemonmilk/LemonMilkBold-gx2B3.otf") format("opentype");
  font-weight: bold;
  font-style: normal;
}
@font-face {
  font-family: "Lemonmilk";
  src: url("/assets/fonts/lemonmilk/LemonMilkRegular-X3XE2.otf") format("opentype");
  font-weight: normal;
  font-style: normal;
}
@font-face {
  font-family: "Lemonmilk";
  src: url("/assets/fonts/lemonmilk/LemonMilkRegularItalic-L3AEy.otf") format("opentype");
  font-weight: normal;
  font-style: italic;
}
@font-face {
  font-family: "Inter";
  font-style: normal;
  font-weight: 100;
  font-display: swap;
  src: url("/assets/fonts/inter/Inter-Thin.woff2?v=3.15") format("woff2"), url("/assets/fonts/inter/Inter-Thin.woff?v=3.15") format("woff");
}
@font-face {
  font-family: "Inter";
  font-style: italic;
  font-weight: 100;
  font-display: swap;
  src: url("/assets/fonts/inter/Inter-ThinItalic.woff2?v=3.15") format("woff2"), url("/assets/fonts/inter/Inter-ThinItalic.woff?v=3.15") format("woff");
}
@font-face {
  font-family: "Inter";
  font-style: normal;
  font-weight: 200;
  font-display: swap;
  src: url("/assets/fonts/inter/Inter-ExtraLight.woff2?v=3.15") format("woff2"), url("/assets/fonts/inter/Inter-ExtraLight.woff?v=3.15") format("woff");
}
@font-face {
  font-family: "Inter";
  font-style: italic;
  font-weight: 200;
  font-display: swap;
  src: url("/assets/fonts/inter/Inter-ExtraLightItalic.woff2?v=3.15") format("woff2"), url("/assets/fonts/inter/Inter-ExtraLightItalic.woff?v=3.15") format("woff");
}
@font-face {
  font-family: "Inter";
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url("/assets/fonts/inter/Inter-Light.woff2?v=3.15") format("woff2"), url("/assets/fonts/inter/Inter-Light.woff?v=3.15") format("woff");
}
@font-face {
  font-family: "Inter";
  font-style: italic;
  font-weight: 300;
  font-display: swap;
  src: url("/assets/fonts/inter/Inter-LightItalic.woff2?v=3.15") format("woff2"), url("/assets/fonts/inter/Inter-LightItalic.woff?v=3.15") format("woff");
}
@font-face {
  font-family: "Inter";
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("/assets/fonts/inter/Inter-Regular.woff2?v=3.15") format("woff2"), url("/assets/fonts/inter/Inter-Regular.woff?v=3.15") format("woff");
}
@font-face {
  font-family: "Inter";
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url("/assets/fonts/inter/Inter-Italic.woff2?v=3.15") format("woff2"), url("/assets/fonts/inter/Inter-Italic.woff?v=3.15") format("woff");
}
@font-face {
  font-family: "Inter";
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("/assets/fonts/inter/Inter-Medium.woff2?v=3.15") format("woff2"), url("/assets/fonts/inter/Inter-Medium.woff?v=3.15") format("woff");
}
@font-face {
  font-family: "Inter";
  font-style: italic;
  font-weight: 500;
  font-display: swap;
  src: url("/assets/fonts/inter/Inter-MediumItalic.woff2?v=3.15") format("woff2"), url("/assets/fonts/inter/Inter-MediumItalic.woff?v=3.15") format("woff");
}
@font-face {
  font-family: "Inter";
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("/assets/fonts/inter/Inter-SemiBold.woff2?v=3.15") format("woff2"), url("/assets/fonts/inter/Inter-SemiBold.woff?v=3.15") format("woff");
}
@font-face {
  font-family: "Inter";
  font-style: italic;
  font-weight: 600;
  font-display: swap;
  src: url("/assets/fonts/inter/Inter-SemiBoldItalic.woff2?v=3.15") format("woff2"), url("/assets/fonts/inter/Inter-SemiBoldItalic.woff?v=3.15") format("woff");
}
@font-face {
  font-family: "Inter";
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("/assets/fonts/inter/Inter-Bold.woff2?v=3.15") format("woff2"), url("/assets/fonts/inter/Inter-Bold.woff?v=3.15") format("woff");
}
@font-face {
  font-family: "Inter";
  font-style: italic;
  font-weight: 700;
  font-display: swap;
  src: url("/assets/fonts/inter/Inter-BoldItalic.woff2?v=3.15") format("woff2"), url("/assets/fonts/inter/Inter-BoldItalic.woff?v=3.15") format("woff");
}
@font-face {
  font-family: "Inter";
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url("/assets/fonts/inter/Inter-ExtraBold.woff2?v=3.15") format("woff2"), url("/assets/fonts/inter/Inter-ExtraBold.woff?v=3.15") format("woff");
}
@font-face {
  font-family: "Inter";
  font-style: italic;
  font-weight: 800;
  font-display: swap;
  src: url("/assets/fonts/inter/Inter-ExtraBoldItalic.woff2?v=3.15") format("woff2"), url("/assets/fonts/inter/Inter-ExtraBoldItalic.woff?v=3.15") format("woff");
}
@font-face {
  font-family: "Inter";
  font-style: normal;
  font-weight: 900;
  font-display: swap;
  src: url("/assets/fonts/inter/Inter-Black.woff2?v=3.15") format("woff2"), url("/assets/fonts/inter/Inter-Black.woff?v=3.15") format("woff");
}
@font-face {
  font-family: "Inter";
  font-style: italic;
  font-weight: 900;
  font-display: swap;
  src: url("/assets/fonts/inter/Inter-BlackItalic.woff2?v=3.15") format("woff2"), url("/assets/fonts/inter/Inter-BlackItalic.woff?v=3.15") format("woff");
}
/* -------------------------------------------------------
Variable font.
Usage:

  html { font-family: 'Inter', sans-serif; }
  @supports (font-variation-settings: normal) {
    html { font-family: 'Inter var', sans-serif; }
  }
*/
@font-face {
  font-family: "Inter var";
  font-weight: 100 900;
  font-display: swap;
  font-style: normal;
  font-named-instance: "Regular";
  src: url("/assets/fonts/inter/Inter-roman.var.woff2?v=3.15") format("woff2");
}
@font-face {
  font-family: "Inter var";
  font-weight: 100 900;
  font-display: swap;
  font-style: italic;
  font-named-instance: "Italic";
  src: url("/assets/fonts/inter/Inter-italic.var.woff2?v=3.15") format("woff2");
}
/* --------------------------------------------------------------------------
[EXPERIMENTAL] Multi-axis, single variable font.

Slant axis is not yet widely supported (as of February 2019) and thus this
multi-axis single variable font is opt-in rather than the default.

When using this, you will probably need to set font-variation-settings
explicitly, e.g.

  * { font-variation-settings: "slnt" 0deg }
  .italic { font-variation-settings: "slnt" 10deg }

*/
@font-face {
  font-family: "Inter var experimental";
  font-weight: 100 900;
  font-display: swap;
  font-style: oblique 0deg 10deg;
  src: url("/assets/fonts/inter/Inter.var.woff2?v=3.15") format("woff2");
}
/* https://raw.githubusercontent.com/jgthms/minireset.css/master/minireset.min.css */
html {
  font-size: 19.5px;
}

html,
body,
p,
ol,
ul,
li,
dl,
dt,
dd,
blockquote,
figure,
fieldset,
legend,
textarea,
pre,
iframe,
hr,
h1,
h2,
h3,
h4,
h5,
h6 {
  margin: 0;
  padding: 0;
  background-color: inherit;
  color: inherit;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-size: 100%;
  font-weight: normal;
}

ul {
  list-style: none;
}

button,
input,
select,
textarea {
  margin: 0;
}

html {
  box-sizing: border-box;
}

*,
*:before,
*:after {
  box-sizing: inherit;
}

img,
embed,
iframe,
object,
audio,
video {
  height: auto;
  max-width: 100%;
}

iframe {
  border: 0;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

td,
th {
  padding: 0;
  text-align: left;
}

#front-page,
.modern-page {
  font-family: "Inter", "Open Sans", sans-serif;
  font-size: 1rem;
  font-weight: normal;
  line-height: 1.625;
}
#front-page h1,
#front-page h2,
#front-page h3,
#front-page h4,
#front-page h5,
#front-page h6,
.modern-page h1,
.modern-page h2,
.modern-page h3,
.modern-page h4,
.modern-page h5,
.modern-page h6 {
  font-family: "Lemonmilk", "Bebas Neue Regular", "Quando", "Roboto", sans-serif;
}
#front-page h1,
.modern-page h1 {
  font-size: 200%;
}
#front-page h2,
.modern-page h2 {
  font-size: 160%;
}
#front-page h3,
.modern-page h3 {
  font-size: 140%;
}
#front-page h4,
.modern-page h4 {
  font-size: 120%;
}
#front-page h5,
#front-page h6,
.modern-page h5,
.modern-page h6 {
  font-size: 110%;
}
#front-page :last-child,
.modern-page :last-child {
  margin-bottom: 0;
}
#front-page p,
#front-page blockquote,
#front-page .highlight,
#front-page .notice,
#front-page details,
.modern-page p,
.modern-page blockquote,
.modern-page .highlight,
.modern-page .notice,
.modern-page details {
  margin-bottom: 0.5rem;
}
#front-page p.testimonial,
#front-page blockquote.testimonial,
#front-page .highlight.testimonial,
#front-page .notice.testimonial,
#front-page details.testimonial,
.modern-page p.testimonial,
.modern-page blockquote.testimonial,
.modern-page .highlight.testimonial,
.modern-page .notice.testimonial,
.modern-page details.testimonial {
  margin-bottom: 0 !important;
}
#front-page .aside,
#front-page .highlight,
#front-page .notice,
.modern-page .aside,
.modern-page .highlight,
.modern-page .notice {
  margin-top: 1rem;
  margin-bottom: 1rem;
}
#front-page .single-column-layout,
.modern-page .single-column-layout {
  display: grid;
  grid-template-columns: none;
  grid-template-rows: auto;
}
#front-page .topline,
.modern-page .topline {
  background-color: hsl(353, 69%, 65%);
  color: white;
}
#front-page .topline a,
.modern-page .topline a {
  color: inherit;
}
#front-page .topline a:visited,
.modern-page .topline a:visited {
  color: inherit;
}
#front-page .topline,
.modern-page .topline {
  text-align: center;
  padding: 0.5em;
  font-size: 150%;
}
#front-page .centered-text-flow-around, #front-page .body-text-block,
.modern-page .centered-text-flow-around,
.modern-page .body-text-block {
  display: block;
  text-align: center;
  margin: auto;
  margin-top: 1em;
  margin-bottom: 1em;
}
#front-page .embedded-video-container,
.modern-page .embedded-video-container {
  position: relative;
  height: 0;
  padding-bottom: 65%;
}
#front-page .embedded-video-container .embedded-video,
.modern-page .embedded-video-container .embedded-video {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
#front-page .body-text-block,
.modern-page .body-text-block {
  max-width: 90%;
}
#front-page .hero-link,
.modern-page .hero-link {
  font-family: "Bebas Neue Regular";
}
#front-page .hero-link a.jbrains-link .part-1,
.modern-page .hero-link a.jbrains-link .part-1 {
  color: black;
}
#front-page .hero-link a.jbrains-link .part-2,
.modern-page .hero-link a.jbrains-link .part-2 {
  color: hsl(353, 69%, 65%);
}
#front-page .hero-link a.jbrains-link:hover .part-1,
.modern-page .hero-link a.jbrains-link:hover .part-1 {
  color: hsl(353, 69%, 65%);
}
#front-page .hero-link a.jbrains-link:hover .part-2,
.modern-page .hero-link a.jbrains-link:hover .part-2 {
  color: black;
}
#front-page .hero-link a.jbrains-link,
.modern-page .hero-link a.jbrains-link {
  text-decoration: none;
}
#front-page .navigation-button,
.modern-page .navigation-button {
  background-color: hsl(353, 69%, 65%);
  color: white;
}
#front-page .navigation-button:hover,
.modern-page .navigation-button:hover {
  background-color: white;
  color: hsl(353, 69%, 65%);
}
#front-page .navigation-button,
.modern-page .navigation-button {
  text-decoration: none;
}
#front-page .navigation-button .button-headline,
.modern-page .navigation-button .button-headline {
  font-family: "Lemonmilk", "Bebas Neue Regular", "Quando", "Roboto", sans-serif;
  letter-spacing: 0.03em;
}
#front-page .navigation-button .button-details,
.modern-page .navigation-button .button-details {
  font-family: "Inter", "Open Sans", sans-serif;
  font-style: italic;
}
#front-page #shortcuts,
.modern-page #shortcuts {
  display: grid;
  grid-template-columns: none;
  grid-gap: 0em;
}
#front-page .testimonial,
.modern-page .testimonial {
  grid-template-columns: none;
  grid-template-rows: auto;
  grid-gap: 1em;
}
#front-page #testimonials,
.modern-page #testimonials {
  background-color: hsl(353, 69%, 65%);
  color: white;
}
#front-page #testimonials a,
.modern-page #testimonials a {
  color: inherit;
}
#front-page #testimonials a:visited,
.modern-page #testimonials a:visited {
  color: inherit;
}
#front-page .call-to-action,
.modern-page .call-to-action {
  font-weight: bold;
  font-size: 150%;
}
#front-page .service-tile,
.modern-page .service-tile {
  background-color: hsl(353, 69%, 95%);
}
#front-page .callout iframe,
.modern-page .callout iframe {
  display: block;
  width: 100%;
  margin: auto;
}
#front-page .callout,
.modern-page .callout {
  margin-left: auto;
  margin-right: auto;
}
#front-page .service-tile,
.modern-page .service-tile {
  border: 1px solid;
  padding: 1em;
}
#front-page .service-title,
.modern-page .service-title {
  font-family: "Lemonmilk", "Bebas Neue Regular", "Quando", "Roboto", sans-serif;
}
#front-page .service-teaser,
.modern-page .service-teaser {
  font-style: italic;
}
#front-page #copyright,
.modern-page #copyright {
  margin: auto;
}
#front-page .body-text-container h1,
#front-page .body-text-container h2,
#front-page .body-text-container h3,
#front-page .body-text-container h4,
#front-page .body-text-container h5,
#front-page .body-text-container h6,
.modern-page .body-text-container h1,
.modern-page .body-text-container h2,
.modern-page .body-text-container h3,
.modern-page .body-text-container h4,
.modern-page .body-text-container h5,
.modern-page .body-text-container h6 {
  margin-top: 0.7em;
  margin-bottom: 0.3em;
}
#front-page .body-text-container h1,
.modern-page .body-text-container h1 {
  font-size: 250%;
}
#front-page .body-text-container h2,
.modern-page .body-text-container h2 {
  font-size: 187.5%;
}
#front-page .body-text-container h3,
.modern-page .body-text-container h3 {
  font-size: 150%;
}
#front-page .body-text-container .page-title,
.modern-page .body-text-container .page-title {
  margin-top: 1rem !important;
}
#front-page .body-text-container li,
.modern-page .body-text-container li {
  margin-bottom: 0.5rem;
}
#front-page .body-text-container ol,
.modern-page .body-text-container ol {
  list-style-type: decimal;
}
#front-page .body-text-container ul,
.modern-page .body-text-container ul {
  list-style-type: disc;
}
#front-page .body-text-container ol,
#front-page .body-text-container ul,
.modern-page .body-text-container ol,
.modern-page .body-text-container ul {
  margin-left: 2em;
}
#front-page .body-text-container .related-articles,
.modern-page .body-text-container .related-articles {
  display: flex;
  flex-direction: column;
  list-style-type: none;
  margin-left: 0;
}
#front-page .more-information-page figure.featured-logo,
.modern-page .more-information-page figure.featured-logo {
  display: flex;
  flex-flow: row wrap;
  justify-content: center;
  align-content: center;
}
#front-page .more-information-page figure.featured-logo img,
.modern-page .more-information-page figure.featured-logo img {
  max-height: 10em;
}
#front-page .page-container,
.modern-page .page-container {
  grid-gap: 0.5rem;
}
#front-page,
.modern-page {
  background-color: #eeeeee;
  margin: 0 auto 2rem auto;
}
#front-page .footer,
.modern-page .footer {
  margin: 2rem auto 0 auto;
}
#front-page ul,
#front-page ol,
.modern-page ul,
.modern-page ol {
  padding-top: 0.5em;
  padding-bottom: 0.5em;
}
#front-page .callout,
.modern-page .callout {
  margin-top: 1em;
  margin-bottom: 1em;
}
#front-page .twitter-tweet,
.modern-page .twitter-tweet {
  /* Override the 500px fixed width that Twitter sets by Javascript. Bastards. */
  width: auto !important;
}
#front-page .highlight,
#front-page .notice,
#front-page .note,
#front-page .special-offer,
.modern-page .highlight,
.modern-page .notice,
.modern-page .note,
.modern-page .special-offer {
  border: 1px solid;
  padding: 0.5em;
}
#front-page .aside,
.modern-page .aside {
  padding: 1em;
  background-color: hsl(353, 69%, 95%);
}
#front-page details,
.modern-page details {
  border: 1px solid;
  padding: 0.5em;
  background-color: rgb(212.5, 212.5, 212.5);
}
#front-page details[open] summary,
.modern-page details[open] summary {
  margin-bottom: 1em;
}
#front-page #primary-navigation-menu,
.modern-page #primary-navigation-menu {
  display: grid;
  grid-template-columns: none;
  grid-template-rows: auto;
}
#front-page #primary-navigation-buttons,
.modern-page #primary-navigation-buttons {
  display: grid;
  grid-gap: 0.2em;
}
#front-page figure.tweet,
.modern-page figure.tweet {
  margin-left: auto;
  margin-right: auto;
  margin-top: 1rem;
  margin-bottom: 1rem;
}
#front-page details.testimonial,
.modern-page details.testimonial {
  background-color: hsl(353, 69%, 90%);
  border: 1px solid;
  padding: 1em;
}
#front-page details.testimonial .callout,
.modern-page details.testimonial .callout {
  width: 100%;
  max-width: 100%;
}
#front-page details.testimonial summary::before,
.modern-page details.testimonial summary::before {
  content: url(/images/icons/noun_testimonial_1326785-small.png);
}
#front-page .public-course-directory,
.modern-page .public-course-directory {
  display: flex;
}
#front-page .public-course-directory .public-course-poster,
.modern-page .public-course-directory .public-course-poster {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}
#front-page .public-course-directory .public-course-poster a,
#front-page .public-course-directory .public-course-poster a:visited,
.modern-page .public-course-directory .public-course-poster a,
.modern-page .public-course-directory .public-course-poster a:visited {
  color: unset;
}
#front-page form.standard-form,
.modern-page form.standard-form {
  display: flex;
  flex-flow: column wrap;
  align-items: flex-start;
  grid-gap: 1em;
}
#front-page form.standard-form fieldset,
.modern-page form.standard-form fieldset {
  display: flex;
  flex-flow: column wrap;
  grid-gap: 1em;
}
#front-page form.standard-form fieldset,
.modern-page form.standard-form fieldset {
  padding: 1em;
  width: 100%;
  max-width: 50em;
}
#front-page form.standard-form,
.modern-page form.standard-form {
  /* Honeypot fieldset to avoid unwanted submissions */
}
#front-page form.standard-form fieldset#respond,
.modern-page form.standard-form fieldset#respond {
  display: none;
}
#front-page form.standard-form label, #front-page form.standard-form label span,
.modern-page form.standard-form label,
.modern-page form.standard-form label span {
  display: block;
}
#front-page form.standard-form .checkbox-group,
.modern-page form.standard-form .checkbox-group {
  display: flex;
  flex-flow: column wrap;
  grid-gap: 0.2em;
}
#front-page form.standard-form label.labeled-checkbox,
.modern-page form.standard-form label.labeled-checkbox {
  display: flex;
  flex-flow: row nowrap;
  grid-gap: 0.5em;
  align-items: baseline;
}
#front-page form.standard-form label.labeled-checkbox span,
.modern-page form.standard-form label.labeled-checkbox span {
  display: inline;
}
#front-page form.standard-form textarea,
.modern-page form.standard-form textarea {
  background-color: white;
}
#front-page form.standard-form textarea,
.modern-page form.standard-form textarea {
  font-family: inherit;
  font-size: 100%;
}
#front-page form.standard-form textarea, #front-page form.standard-form input[type=text], #front-page form.standard-form input[type=email],
.modern-page form.standard-form textarea,
.modern-page form.standard-form input[type=text],
.modern-page form.standard-form input[type=email] {
  width: 100%;
}
#front-page form.standard-form textarea,
.modern-page form.standard-form textarea {
  max-width: 40em;
}
#front-page form.standard-form input[type=text], #front-page form.standard-form input[type=email],
.modern-page form.standard-form input[type=text],
.modern-page form.standard-form input[type=email] {
  max-width: 30em;
}
#front-page form.standard-form select,
.modern-page form.standard-form select {
  max-width: 20em;
}
#front-page form.standard-form textarea, #front-page form.standard-form input,
.modern-page form.standard-form textarea,
.modern-page form.standard-form input {
  padding: 0.5em;
}
#front-page form.standard-form,
.modern-page form.standard-form {
  /* SMELL I'm forced to mark the parent element as "required" in order to style it. */
}
#front-page form.standard-form label.required span,
.modern-page form.standard-form label.required span {
  font-weight: bold;
}
#front-page form.standard-form label.required,
.modern-page form.standard-form label.required {
  /* ...but not the options in labeled checkboxes. */
}
#front-page form.standard-form label.required .labeled-checkbox span,
.modern-page form.standard-form label.required .labeled-checkbox span {
  font-weight: initial;
}
#front-page form.standard-form .instructions,
.modern-page form.standard-form .instructions {
  font-size: 80%;
}
@media screen and (orientation: portrait) {
  #front-page,
  .modern-page {
    width: 94vw;
    font-size: 0.8rem;
  }
}
@media screen and (orientation: landscape) and (max-width: 800px) {
  #front-page,
  .modern-page {
    width: 85vw;
    font-size: 0.9rem;
  }
}
@media screen and (orientation: landscape) and (min-width: 800px) {
  #front-page,
  .modern-page {
    width: 80vw;
    font-size: 0.9rem;
  }
}
@media screen and (orientation: landscape) and (min-width: 1000px) {
  #front-page,
  .modern-page {
    width: 72vw;
    font-size: 0.9rem;
  }
}
@media screen and (orientation: landscape) and (min-width: 1200px) {
  #front-page,
  .modern-page {
    width: 60vw;
    font-size: 0.9rem;
  }
}
@media screen and (orientation: landscape) and (min-width: 1600px) {
  #front-page,
  .modern-page {
    width: 60vw;
    font-size: 1rem;
  }
  #front-page .callout-text,
  .modern-page .callout-text {
    margin-left: 20%;
    margin-right: 20%;
  }
}
@media screen and (orientation: portrait) {
  #front-page,
  .modern-page {
    margin: 0 auto 2rem auto;
  }
  #front-page .body-text-container h1,
  .modern-page .body-text-container h1 {
    font-size: 180%;
  }
  #front-page .body-text-container h2,
  .modern-page .body-text-container h2 {
    font-size: 135%;
  }
  #front-page .body-text-container h3,
  .modern-page .body-text-container h3 {
    font-size: 108%;
  }
  #front-page .page-container,
  .modern-page .page-container {
    grid-gap: 2rem;
  }
  #front-page #hero-image,
  .modern-page #hero-image {
    display: grid;
    grid-gap: 2rem;
  }
  #front-page .hero-link,
  .modern-page .hero-link {
    text-align: center;
    font-size: 400%;
  }
  #front-page .navigation-header,
  .modern-page .navigation-header {
    margin: auto;
    font-size: 200%;
  }
  #front-page .public-course-directory,
  .modern-page .public-course-directory {
    flex-direction: column;
    align-items: center;
    grid-gap: 2em;
  }
  #front-page .public-course-directory .public-course-poster,
  .modern-page .public-course-directory .public-course-poster {
    max-width: 100%;
  }
  #front-page .public-course-directory .public-course-poster img,
  .modern-page .public-course-directory .public-course-poster img {
    width: 600px;
  }
  #front-page #succinct-banner,
  .modern-page #succinct-banner {
    margin-bottom: 1rem;
    display: grid;
    grid-template-columns: 1fr;
    grid-template-rows: auto;
    grid-row-gap: 1em;
    height: auto;
  }
  #front-page #succinct-banner a,
  .modern-page #succinct-banner a {
    margin-left: auto;
    margin-right: auto;
  }
  #front-page #succinct-banner #logo,
  .modern-page #succinct-banner #logo {
    height: 80px;
    margin-left: auto;
    margin-right: auto;
  }
  #front-page #succinct-banner #banner-shortcuts,
  .modern-page #succinct-banner #banner-shortcuts {
    display: flex;
    flex-direction: column;
    margin: auto;
  }
  #front-page #succinct-banner #banner-shortcuts .navigation-header,
  .modern-page #succinct-banner #banner-shortcuts .navigation-header {
    display: flex;
    flex-direction: row;
    font-size: 100%;
  }
  #front-page #succinct-banner #banner-shortcuts.collapsed .icon-spacer,
  .modern-page #succinct-banner #banner-shortcuts.collapsed .icon-spacer {
    background-image: url(/images/icons/expand.png);
  }
  #front-page #succinct-banner #banner-shortcuts.collapsed .navigation-option,
  .modern-page #succinct-banner #banner-shortcuts.collapsed .navigation-option {
    display: block;
    height: 0;
    visibility: hidden;
  }
  #front-page #succinct-banner #banner-shortcuts.expanded .icon-spacer,
  .modern-page #succinct-banner #banner-shortcuts.expanded .icon-spacer {
    background-image: url(/images/icons/collapse.png);
  }
  #front-page #succinct-banner #banner-shortcuts.expanded .navigation-option,
  .modern-page #succinct-banner #banner-shortcuts.expanded .navigation-option {
    display: block;
    height: auto;
    visibility: visible;
  }
  #front-page #succinct-banner #banner-shortcuts #menu-button .icon-spacer,
  .modern-page #succinct-banner #banner-shortcuts #menu-button .icon-spacer {
    width: 3em;
    background-size: 3em 3em;
    background-repeat: no-repeat;
    background-position: center;
  }
  #front-page #succinct-banner #banner-shortcuts .navigation-option,
  .modern-page #succinct-banner #banner-shortcuts .navigation-option {
    margin-left: 0;
    margin-right: auto;
  }
  #front-page #primary-navigation-buttons,
  .modern-page #primary-navigation-buttons {
    grid-template-columns: repeat(auto-fit, 1fr);
  }
  #front-page .navigation-button,
  .modern-page .navigation-button {
    padding: 0.5em;
  }
  #front-page .navigation-button .button-headline,
  .modern-page .navigation-button .button-headline {
    font-size: 150%;
  }
  #front-page #headline,
  .modern-page #headline {
    display: grid;
    align-items: start;
    grid-gap: 2rem;
  }
  #front-page #describe-jbrains,
  .modern-page #describe-jbrains {
    font-size: 150%;
    font-weight: black;
  }
  #front-page #testimonials,
  .modern-page #testimonials {
    height: 20em;
    overflow-y: scroll;
  }
  #front-page .testimonial,
  .modern-page .testimonial {
    padding: 1em;
  }
  #front-page .service-tile,
  .modern-page .service-tile {
    display: grid;
    grid-gap: 2rem;
  }
  #front-page .service-title,
  .modern-page .service-title {
    font-size: 200%;
  }
  #front-page .service-teaser,
  .modern-page .service-teaser {
    border-bottom: 1px solid;
    font-size: 120%;
  }
  #front-page .ieee-software-callout .featured-image,
  .modern-page .ieee-software-callout .featured-image {
    margin: auto;
    width: 50%;
  }
  #front-page .paragraph-icon,
  #front-page .sidenote,
  .modern-page .paragraph-icon,
  .modern-page .sidenote {
    float: right;
    max-width: 30%;
    border: 0px;
    margin-left: 1em;
    margin-bottom: 2em;
  }
  #front-page .sidenote,
  .modern-page .sidenote {
    font-size: 80%;
  }
  #front-page figure.tweet,
  .modern-page figure.tweet {
    max-width: 90%;
    width: 600px;
  }
  #front-page #request-invoice-options,
  .modern-page #request-invoice-options {
    display: flex;
    flex-direction: column;
    align-items: center;
    grid-gap: 1em;
  }
  #front-page #request-invoice-options .option,
  .modern-page #request-invoice-options .option {
    text-align: center;
    width: 20em;
    max-width: 80%;
  }
  #front-page #request-invoice-options .option .icon,
  .modern-page #request-invoice-options .option .icon {
    width: 20vw;
    margin: -5%;
  }
  #front-page #request-invoice-options .option button,
  .modern-page #request-invoice-options .option button {
    background-color: hsl(353, 69%, 65%);
    color: #ffffff;
    padding: 0.8em;
    margin: 0.8em;
  }
  #front-page #request-invoice-options .option,
  .modern-page #request-invoice-options .option {
    border: 1px solid;
    padding: 0.5em;
  }
  #front-page .training-course-offering,
  .modern-page .training-course-offering {
    display: flex;
    flex-flow: column nowrap;
    grid-gap: 2em;
  }
  #front-page .public-course-poster,
  .modern-page .public-course-poster {
    display: flex;
    flex-flow: column nowrap;
    align-items: center;
  }
  #front-page .public-course-poster img,
  .modern-page .public-course-poster img {
    width: 300px;
    max-width: 100%;
  }
  #front-page blockquote,
  .modern-page blockquote {
    margin-left: 5%;
    border-left: 0.2em solid;
    border-color: hsl(353, 69%, 65%);
    padding-left: 0.6em;
  }
}
@media screen and (orientation: landscape) and (max-width: 800px) {
  #front-page,
  .modern-page {
    margin: 0 auto 2rem auto;
  }
  #front-page .body-text-container h1,
  .modern-page .body-text-container h1 {
    font-size: 180%;
  }
  #front-page .body-text-container h2,
  .modern-page .body-text-container h2 {
    font-size: 135%;
  }
  #front-page .body-text-container h3,
  .modern-page .body-text-container h3 {
    font-size: 108%;
  }
  #front-page .page-container,
  .modern-page .page-container {
    grid-gap: 2rem;
  }
  #front-page #hero-image,
  .modern-page #hero-image {
    display: grid;
    grid-gap: 2rem;
  }
  #front-page .hero-link,
  .modern-page .hero-link {
    text-align: center;
    font-size: 400%;
  }
  #front-page .navigation-header,
  .modern-page .navigation-header {
    margin: auto;
    font-size: 200%;
  }
  #front-page .public-course-directory,
  .modern-page .public-course-directory {
    flex-direction: column;
    align-items: center;
    grid-gap: 2em;
  }
  #front-page .public-course-directory .public-course-poster,
  .modern-page .public-course-directory .public-course-poster {
    max-width: 100%;
  }
  #front-page .public-course-directory .public-course-poster img,
  .modern-page .public-course-directory .public-course-poster img {
    width: 600px;
  }
  #front-page #succinct-banner,
  .modern-page #succinct-banner {
    margin-bottom: 1rem;
    display: grid;
    grid-template-columns: 1fr;
    grid-template-rows: auto;
    grid-row-gap: 1em;
    height: auto;
  }
  #front-page #succinct-banner a,
  .modern-page #succinct-banner a {
    margin-left: auto;
    margin-right: auto;
  }
  #front-page #succinct-banner #logo,
  .modern-page #succinct-banner #logo {
    height: 80px;
    margin-left: auto;
    margin-right: auto;
  }
  #front-page #succinct-banner #banner-shortcuts,
  .modern-page #succinct-banner #banner-shortcuts {
    display: flex;
    flex-direction: column;
    margin: auto;
  }
  #front-page #succinct-banner #banner-shortcuts .navigation-header,
  .modern-page #succinct-banner #banner-shortcuts .navigation-header {
    display: flex;
    flex-direction: row;
    font-size: 100%;
  }
  #front-page #succinct-banner #banner-shortcuts.collapsed .icon-spacer,
  .modern-page #succinct-banner #banner-shortcuts.collapsed .icon-spacer {
    background-image: url(/images/icons/expand.png);
  }
  #front-page #succinct-banner #banner-shortcuts.collapsed .navigation-option,
  .modern-page #succinct-banner #banner-shortcuts.collapsed .navigation-option {
    display: block;
    height: 0;
    visibility: hidden;
  }
  #front-page #succinct-banner #banner-shortcuts.expanded .icon-spacer,
  .modern-page #succinct-banner #banner-shortcuts.expanded .icon-spacer {
    background-image: url(/images/icons/collapse.png);
  }
  #front-page #succinct-banner #banner-shortcuts.expanded .navigation-option,
  .modern-page #succinct-banner #banner-shortcuts.expanded .navigation-option {
    display: block;
    height: auto;
    visibility: visible;
  }
  #front-page #succinct-banner #banner-shortcuts #menu-button .icon-spacer,
  .modern-page #succinct-banner #banner-shortcuts #menu-button .icon-spacer {
    width: 3em;
    background-size: 3em 3em;
    background-repeat: no-repeat;
    background-position: center;
  }
  #front-page #succinct-banner #banner-shortcuts .navigation-option,
  .modern-page #succinct-banner #banner-shortcuts .navigation-option {
    margin-left: 0;
    margin-right: auto;
  }
  #front-page #primary-navigation-buttons,
  .modern-page #primary-navigation-buttons {
    grid-template-columns: repeat(auto-fit, 1fr);
  }
  #front-page .navigation-button,
  .modern-page .navigation-button {
    padding: 0.5em;
  }
  #front-page .navigation-button .button-headline,
  .modern-page .navigation-button .button-headline {
    font-size: 150%;
  }
  #front-page #headline,
  .modern-page #headline {
    display: grid;
    align-items: start;
    grid-gap: 2rem;
  }
  #front-page #describe-jbrains,
  .modern-page #describe-jbrains {
    font-size: 150%;
    font-weight: black;
  }
  #front-page #testimonials,
  .modern-page #testimonials {
    height: 20em;
    overflow-y: scroll;
  }
  #front-page .testimonial,
  .modern-page .testimonial {
    padding: 1em;
  }
  #front-page .service-tile,
  .modern-page .service-tile {
    display: grid;
    grid-gap: 2rem;
  }
  #front-page .service-title,
  .modern-page .service-title {
    font-size: 200%;
  }
  #front-page .service-teaser,
  .modern-page .service-teaser {
    border-bottom: 1px solid;
    font-size: 120%;
  }
  #front-page .ieee-software-callout .featured-image,
  .modern-page .ieee-software-callout .featured-image {
    margin: auto;
    width: 50%;
  }
  #front-page .paragraph-icon,
  #front-page .sidenote,
  .modern-page .paragraph-icon,
  .modern-page .sidenote {
    float: right;
    max-width: 30%;
    border: 0px;
    margin-left: 1em;
    margin-bottom: 2em;
  }
  #front-page .sidenote,
  .modern-page .sidenote {
    font-size: 80%;
  }
  #front-page figure.tweet,
  .modern-page figure.tweet {
    max-width: 90%;
    width: 600px;
  }
  #front-page #request-invoice-options,
  .modern-page #request-invoice-options {
    display: flex;
    flex-direction: column;
    align-items: center;
    grid-gap: 1em;
  }
  #front-page #request-invoice-options .option,
  .modern-page #request-invoice-options .option {
    text-align: center;
    width: 20em;
    max-width: 80%;
  }
  #front-page #request-invoice-options .option .icon,
  .modern-page #request-invoice-options .option .icon {
    width: 20vw;
    margin: -5%;
  }
  #front-page #request-invoice-options .option button,
  .modern-page #request-invoice-options .option button {
    background-color: hsl(353, 69%, 65%);
    color: #ffffff;
    padding: 0.8em;
    margin: 0.8em;
  }
  #front-page #request-invoice-options .option,
  .modern-page #request-invoice-options .option {
    border: 1px solid;
    padding: 0.5em;
  }
  #front-page .training-course-offering,
  .modern-page .training-course-offering {
    display: flex;
    flex-flow: column nowrap;
    grid-gap: 2em;
  }
  #front-page .public-course-poster,
  .modern-page .public-course-poster {
    display: flex;
    flex-flow: column nowrap;
    align-items: center;
  }
  #front-page .public-course-poster img,
  .modern-page .public-course-poster img {
    width: 300px;
    max-width: 100%;
  }
  #front-page blockquote,
  .modern-page blockquote {
    margin-left: 5%;
    border-left: 0.2em solid;
    border-color: hsl(353, 69%, 65%);
    padding-left: 0.6em;
  }
}
@media screen and (orientation: landscape) and (min-width: 800px) {
  #front-page .body-text-block,
  .modern-page .body-text-block {
    max-width: 60%;
  }
  #front-page #hero-image,
  .modern-page #hero-image {
    background: url(/images/2016-WhitmansDeli-Stockholm.jpg);
    background-size: cover;
    display: grid;
    grid-template-columns: 1fr 50%;
    grid-template-rows: auto;
    grid-gap: 0.5em;
    grid-template-areas: "hero-content navigation-menu" "shortcuts shortcuts";
  }
  #front-page #hero-image #shortcuts,
  .modern-page #hero-image #shortcuts {
    grid-area: shortcuts;
  }
  #front-page #hero-image .hero-content,
  .modern-page #hero-image .hero-content {
    grid-area: hero-content;
    display: flex;
    flex-direction: column;
    justify-content: center;
    grid-gap: 0.5em;
    width: 90%;
    margin: 0 auto 0 auto;
  }
  #front-page #hero-image .navigation-menu,
  .modern-page #hero-image .navigation-menu {
    align-self: start;
    grid-area: navigation-menu;
  }
  #front-page #hero-image .hero-link,
  .modern-page #hero-image .hero-link {
    text-align: center;
    font-size: 6vw;
    line-height: 1.3;
  }
  #front-page #hero-image .note,
  .modern-page #hero-image .note {
    margin: 0 auto 0 auto;
    width: 80%;
  }
  #front-page .hero-content,
  .modern-page .hero-content {
    display: block;
    padding: 0;
  }
  #front-page,
  .modern-page {
    /* Already a grid */
  }
  #front-page #primary-navigation-menu,
  .modern-page #primary-navigation-menu {
    grid-template-columns: repeat(auto-fit, minmax(6cm, 1fr));
    grid-template-rows: auto;
  }
  #front-page .navigation-header,
  .modern-page .navigation-header {
    display: none;
  }
  #front-page #shortcuts,
  .modern-page #shortcuts {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(8em, 1fr));
    grid-gap: 0.5em;
    font-size: 80%;
  }
  #front-page #succinct-banner,
  .modern-page #succinct-banner {
    display: grid;
    grid-template-rows: 1fr;
    grid-template-columns: minmax(240px, 1fr) auto;
    grid-template-areas: "logo shortcuts";
    grid-row-gap: 0px;
    grid-column-gap: 1em;
    margin-bottom: 2rem;
  }
  #front-page #succinct-banner #logo,
  .modern-page #succinct-banner #logo {
    height: 80px;
    max-height: 100%;
  }
  #front-page #succinct-banner #banner-shortcuts,
  .modern-page #succinct-banner #banner-shortcuts {
    margin-right: 0;
    margin-left: auto;
    line-height: 2;
  }
  #front-page #succinct-banner #banner-shortcuts .navigation-option,
  .modern-page #succinct-banner #banner-shortcuts .navigation-option {
    text-align: baseline;
    font-size: 90%;
    margin-right: 2em;
    white-space: nowrap;
  }
  #front-page .public-course-directory,
  .modern-page .public-course-directory {
    flex-flow: row wrap;
    grid-gap: 2rem;
  }
  #front-page .public-course-directory .public-course-poster,
  .modern-page .public-course-directory .public-course-poster {
    width: 40%;
  }
  #front-page .public-course-directory img,
  .modern-page .public-course-directory img {
    width: 100%;
  }
  #front-page #primary-navigation-buttons,
  .modern-page #primary-navigation-buttons {
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: auto;
  }
  #front-page .navigation-button,
  .modern-page .navigation-button {
    background-color: hsl(353, 69%, 65%);
    color: white;
  }
  #front-page .navigation-button:hover,
  .modern-page .navigation-button:hover {
    background-color: white;
    color: hsl(353, 69%, 65%);
  }
  #front-page .navigation-button,
  .modern-page .navigation-button {
    text-decoration: none;
  }
  #front-page .navigation-button,
  .modern-page .navigation-button {
    padding: 1em;
  }
  #front-page .navigation-button .button-headline,
  .modern-page .navigation-button .button-headline {
    font-family: "Lemonmilk", "Bebas Neue Regular", "Quando", "Roboto", sans-serif;
    font-size: 120%;
  }
  #front-page .navigation-button .button-details,
  .modern-page .navigation-button .button-details {
    font-family: "Inter", "Open Sans", sans-serif;
    font-style: italic;
    font-size: 90%;
  }
  #front-page #headline,
  .modern-page #headline {
    display: grid;
    align-items: start;
    grid-gap: 2rem;
    grid-template-columns: 3fr minmax(16rem, 2fr);
    grid-template-areas: "describe-jbrains testimonials" "compelling-statement testimonials" "call-to-action testimonials";
    grid-column-gap: 2em;
    grid-row-gap: 1em;
  }
  #front-page #headline #describe-jbrains,
  .modern-page #headline #describe-jbrains {
    grid-area: describe-jbrains;
  }
  #front-page #headline #compelling-statement,
  .modern-page #headline #compelling-statement {
    grid-area: compelling-statement;
  }
  #front-page #headline .call-to-action,
  .modern-page #headline .call-to-action {
    grid-area: call-to-action;
  }
  #front-page #headline #testimonials,
  .modern-page #headline #testimonials {
    grid-area: testimonials;
  }
  #front-page #describe-jbrains,
  .modern-page #describe-jbrains {
    font-family: "HKGroteskBold", "Inter", "Open Sans", sans-serif;
    font-size: 160%;
    font-weight: bold;
  }
  #front-page #compelling-statement,
  .modern-page #compelling-statement {
    column-width: 14em;
    column-gap: 2em;
  }
  #front-page .testimonial,
  .modern-page .testimonial {
    padding: 1em;
  }
  #front-page .service-tile,
  .modern-page .service-tile {
    display: grid;
    grid-template-columns: 1fr 2fr;
    grid-gap: 2em;
    grid-template-rows: auto;
    grid-template-areas: "service-caption service-content" ". service-footer";
  }
  #front-page .service-tile .service-caption,
  .modern-page .service-tile .service-caption {
    grid-area: service-caption;
  }
  #front-page .service-tile .service-content,
  .modern-page .service-tile .service-content {
    grid-area: service-content;
  }
  #front-page .service-tile .block-link,
  .modern-page .service-tile .block-link {
    grid-area: service-footer;
    justify-self: end;
  }
  #front-page .service-tile,
  .modern-page .service-tile {
    background-color: hsl(353, 69%, 95%);
  }
  #front-page .callout-with-iframe,
  .modern-page .callout-with-iframe {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-items: center;
  }
  #front-page .callout-text,
  .modern-page .callout-text {
    margin-left: 10%;
    margin-right: 10%;
    column-width: 14em;
    column-gap: 2em;
    column-width: 20em !important;
  }
  #front-page .service-content,
  .modern-page .service-content {
    column-width: 14em;
    column-gap: 2em;
  }
  #front-page .service-title,
  .modern-page .service-title {
    font-size: 200%;
  }
  #front-page .service-teaser,
  .modern-page .service-teaser {
    font-size: 120%;
  }
  #front-page .ieee-software-callout,
  .modern-page .ieee-software-callout {
    display: grid;
    grid-template-columns: 1fr minmax(140px, 20%);
    grid-template-rows: auto;
    grid-column-gap: 2em;
    align-items: center;
  }
  #front-page .ieee-software-callout .featured-image,
  .modern-page .ieee-software-callout .featured-image {
    grid-column-start: 2;
  }
  #front-page .more-information-page .callout,
  .modern-page .more-information-page .callout {
    max-width: 60%;
    justify-items: center;
    align-items: center;
    margin-left: auto;
    margin-right: auto;
  }
  #front-page .paragraph-icon,
  #front-page .sidenote,
  .modern-page .paragraph-icon,
  .modern-page .sidenote {
    max-width: 20%;
    float: right;
    border: 0px;
    margin-left: 2em;
    margin-bottom: 2em;
  }
  #front-page .sidenote,
  .modern-page .sidenote {
    font-size: 80%;
  }
  #front-page figure.tweet,
  .modern-page figure.tweet {
    width: 60%;
  }
  #front-page .training-course-offering,
  .modern-page .training-course-offering {
    display: flex;
    flex-flow: row wrap;
    justify-content: space-between;
    grid-gap: 1em;
  }
  #front-page .training-course-offering .public-course-poster,
  .modern-page .training-course-offering .public-course-poster {
    float: right;
    margin-left: 2em;
    margin-bottom: 2em;
    max-width: 35%;
    width: 400px;
    display: flex;
    flex-flow: column nowrap;
    align-items: center;
  }
  #front-page .training-course-offering .public-course-poster img,
  .modern-page .training-course-offering .public-course-poster img {
    width: 600px;
    max-width: 100%;
  }
}
@media screen and (orientation: landscape) and (min-width: 1600px) {
  #front-page .body-text-block,
  .modern-page .body-text-block {
    max-width: 60%;
  }
  #front-page #hero-image,
  .modern-page #hero-image {
    background: url(/images/2016-WhitmansDeli-Stockholm.jpg);
    background-size: cover;
    display: grid;
    grid-template-columns: 1fr 50%;
    grid-template-rows: auto;
    grid-gap: 0.5em;
    grid-template-areas: "hero-content navigation-menu" "shortcuts shortcuts";
  }
  #front-page #hero-image #shortcuts,
  .modern-page #hero-image #shortcuts {
    grid-area: shortcuts;
  }
  #front-page #hero-image .hero-content,
  .modern-page #hero-image .hero-content {
    grid-area: hero-content;
    display: flex;
    flex-direction: column;
    justify-content: center;
    grid-gap: 0.5em;
    width: 90%;
    margin: 0 auto 0 auto;
  }
  #front-page #hero-image .navigation-menu,
  .modern-page #hero-image .navigation-menu {
    align-self: start;
    grid-area: navigation-menu;
  }
  #front-page #hero-image .hero-link,
  .modern-page #hero-image .hero-link {
    text-align: center;
    font-size: 6vw;
    line-height: 1.3;
  }
  #front-page #hero-image .note,
  .modern-page #hero-image .note {
    margin: 0 auto 0 auto;
    width: 80%;
  }
  #front-page .hero-content,
  .modern-page .hero-content {
    display: block;
    padding: 0;
  }
  #front-page,
  .modern-page {
    /* Already a grid */
  }
  #front-page #primary-navigation-menu,
  .modern-page #primary-navigation-menu {
    grid-template-columns: repeat(auto-fit, minmax(6cm, 1fr));
    grid-template-rows: auto;
  }
  #front-page .navigation-header,
  .modern-page .navigation-header {
    display: none;
  }
  #front-page #shortcuts,
  .modern-page #shortcuts {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(8em, 1fr));
    grid-gap: 0.5em;
    font-size: 80%;
  }
  #front-page #succinct-banner,
  .modern-page #succinct-banner {
    display: grid;
    grid-template-rows: 1fr;
    grid-template-columns: minmax(240px, 1fr) auto;
    grid-template-areas: "logo shortcuts";
    grid-row-gap: 0px;
    grid-column-gap: 1em;
    margin-bottom: 2rem;
  }
  #front-page #succinct-banner #logo,
  .modern-page #succinct-banner #logo {
    height: 80px;
    max-height: 100%;
  }
  #front-page #succinct-banner #banner-shortcuts,
  .modern-page #succinct-banner #banner-shortcuts {
    margin-right: 0;
    margin-left: auto;
    line-height: 2;
  }
  #front-page #succinct-banner #banner-shortcuts .navigation-option,
  .modern-page #succinct-banner #banner-shortcuts .navigation-option {
    text-align: baseline;
    font-size: 90%;
    margin-right: 2em;
    white-space: nowrap;
  }
  #front-page .public-course-directory,
  .modern-page .public-course-directory {
    flex-flow: row wrap;
    grid-gap: 2rem;
  }
  #front-page .public-course-directory .public-course-poster,
  .modern-page .public-course-directory .public-course-poster {
    width: 40%;
  }
  #front-page .public-course-directory img,
  .modern-page .public-course-directory img {
    width: 100%;
  }
  #front-page #primary-navigation-buttons,
  .modern-page #primary-navigation-buttons {
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: auto;
  }
  #front-page .navigation-button,
  .modern-page .navigation-button {
    background-color: hsl(353, 69%, 65%);
    color: white;
  }
  #front-page .navigation-button:hover,
  .modern-page .navigation-button:hover {
    background-color: white;
    color: hsl(353, 69%, 65%);
  }
  #front-page .navigation-button,
  .modern-page .navigation-button {
    text-decoration: none;
  }
  #front-page .navigation-button,
  .modern-page .navigation-button {
    padding: 1em;
  }
  #front-page .navigation-button .button-headline,
  .modern-page .navigation-button .button-headline {
    font-family: "Lemonmilk", "Bebas Neue Regular", "Quando", "Roboto", sans-serif;
    font-size: 120%;
  }
  #front-page .navigation-button .button-details,
  .modern-page .navigation-button .button-details {
    font-family: "Inter", "Open Sans", sans-serif;
    font-style: italic;
    font-size: 90%;
  }
  #front-page #headline,
  .modern-page #headline {
    display: grid;
    align-items: start;
    grid-gap: 2rem;
    grid-template-columns: 3fr minmax(16rem, 2fr);
    grid-template-areas: "describe-jbrains testimonials" "compelling-statement testimonials" "call-to-action testimonials";
    grid-column-gap: 2em;
    grid-row-gap: 1em;
  }
  #front-page #headline #describe-jbrains,
  .modern-page #headline #describe-jbrains {
    grid-area: describe-jbrains;
  }
  #front-page #headline #compelling-statement,
  .modern-page #headline #compelling-statement {
    grid-area: compelling-statement;
  }
  #front-page #headline .call-to-action,
  .modern-page #headline .call-to-action {
    grid-area: call-to-action;
  }
  #front-page #headline #testimonials,
  .modern-page #headline #testimonials {
    grid-area: testimonials;
  }
  #front-page #describe-jbrains,
  .modern-page #describe-jbrains {
    font-family: "HKGroteskBold", "Inter", "Open Sans", sans-serif;
    font-size: 160%;
    font-weight: bold;
  }
  #front-page #compelling-statement,
  .modern-page #compelling-statement {
    column-width: 14em;
    column-gap: 2em;
  }
  #front-page .testimonial,
  .modern-page .testimonial {
    padding: 1em;
  }
  #front-page .service-tile,
  .modern-page .service-tile {
    display: grid;
    grid-template-columns: 1fr 2fr;
    grid-gap: 2em;
    grid-template-rows: auto;
    grid-template-areas: "service-caption service-content" ". service-footer";
  }
  #front-page .service-tile .service-caption,
  .modern-page .service-tile .service-caption {
    grid-area: service-caption;
  }
  #front-page .service-tile .service-content,
  .modern-page .service-tile .service-content {
    grid-area: service-content;
  }
  #front-page .service-tile .block-link,
  .modern-page .service-tile .block-link {
    grid-area: service-footer;
    justify-self: end;
  }
  #front-page .service-tile,
  .modern-page .service-tile {
    background-color: hsl(353, 69%, 95%);
  }
  #front-page .callout-with-iframe,
  .modern-page .callout-with-iframe {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-items: center;
  }
  #front-page .callout-text,
  .modern-page .callout-text {
    margin-left: 10%;
    margin-right: 10%;
    column-width: 14em;
    column-gap: 2em;
    column-width: 20em !important;
  }
  #front-page .service-content,
  .modern-page .service-content {
    column-width: 14em;
    column-gap: 2em;
  }
  #front-page .service-title,
  .modern-page .service-title {
    font-size: 200%;
  }
  #front-page .service-teaser,
  .modern-page .service-teaser {
    font-size: 120%;
  }
  #front-page .ieee-software-callout,
  .modern-page .ieee-software-callout {
    display: grid;
    grid-template-columns: 1fr minmax(140px, 20%);
    grid-template-rows: auto;
    grid-column-gap: 2em;
    align-items: center;
  }
  #front-page .ieee-software-callout .featured-image,
  .modern-page .ieee-software-callout .featured-image {
    grid-column-start: 2;
  }
  #front-page .more-information-page .callout,
  .modern-page .more-information-page .callout {
    max-width: 60%;
    justify-items: center;
    align-items: center;
    margin-left: auto;
    margin-right: auto;
  }
  #front-page .paragraph-icon,
  #front-page .sidenote,
  .modern-page .paragraph-icon,
  .modern-page .sidenote {
    max-width: 20%;
    float: right;
    border: 0px;
    margin-left: 2em;
    margin-bottom: 2em;
  }
  #front-page .sidenote,
  .modern-page .sidenote {
    font-size: 80%;
  }
  #front-page figure.tweet,
  .modern-page figure.tweet {
    width: 60%;
  }
  #front-page .training-course-offering,
  .modern-page .training-course-offering {
    display: flex;
    flex-flow: row wrap;
    justify-content: space-between;
    grid-gap: 1em;
  }
  #front-page .training-course-offering .public-course-poster,
  .modern-page .training-course-offering .public-course-poster {
    float: right;
    margin-left: 2em;
    margin-bottom: 2em;
    max-width: 35%;
    width: 400px;
    display: flex;
    flex-flow: column nowrap;
    align-items: center;
  }
  #front-page .training-course-offering .public-course-poster img,
  .modern-page .training-course-offering .public-course-poster img {
    width: 600px;
    max-width: 100%;
  }
  #front-page .service-tile,
  .modern-page .service-tile {
    grid-template-columns: 1fr 3fr;
  }
}
#front-page figure.testimonial,
.modern-page figure.testimonial {
  margin-left: auto;
  margin-right: auto;
  max-width: 640px;
}

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