@charset "UTF-8";
.bg-color-white {
  background-color: #ffffff;
}

.bg-color-black {
  background-color: #000000;
}

.bg-color-orange {
  background-color: #ff6e1e;
}

.bg-color-ltgray {
  background-color: #c8c8c8;
}

.bg-color-midgray {
  background-color: #afafaf;
}

.bg-color-darkergray {
  background-color: #696b73;
}

.bg-color-dkgray {
  background-color: #616265;
}

.bg-color-olivegreen {
  background-color: #a9b734;
}

.bg-color-purple {
  background-color: #95348d;
}

.bg-color-darkteal {
  background-color: #005e5c;
}

html {
  min-height: 100%;
}

body {
  -webkit-font-smoothing: antialiased;
  font-family: Vaud, sans-serif;
  min-height: 100vh;
}

a, a:visited {
  color: inherit;
}

.clearfix:before, .clearfix:after {
  content: "";
  display: table;
}

.clearfix:after {
  clear: both;
}

#skip-link {
  z-index: 1000;
  position: fixed;
}
#skip-link a {
  color: white;
  font-family: Vaud, sans-serif;
}

.sr-only {
  font-size: 15px;
}

#djDebug {
  display: none !important;
}

@media (min-width: 1000px) {
  .responsive-container {
    width: 1000px;
    margin: auto;
  }

  #djDebug {
    display: block !important;
  }
}
a:hover {
  text-decoration: none;
  color: #D14900;
}

.on-campus-only-message {
  padding: 0 50px;
}

/*! normalize.css v3.0.3 | MIT License | github.com/necolas/normalize.css */
/**
 * 1. Set default font family to sans-serif.
 * 2. Prevent iOS and IE text size adjust after device orientation change,
 *    without disabling user zoom.
 */
html {
  font-family: sans-serif;
  /* 1 */
  -ms-text-size-adjust: 100%;
  /* 2 */
  -webkit-text-size-adjust: 100%;
  /* 2 */
}

/**
 * Remove default margin.
 */
body {
  margin: 0;
}

/* HTML5 display definitions
   ========================================================================== */
/**
 * Correct `block` display not defined for any HTML5 element in IE 8/9.
 * Correct `block` display not defined for `details` or `summary` in IE 10/11
 * and Firefox.
 * Correct `block` display not defined for `main` in IE 11.
 */
article,
aside,
details,
figcaption,
figure,
footer,
header,
main,
menu,
nav,
section,
summary {
  display: block;
}

/**
 * 1. Correct `inline-block` display not defined in IE 8/9.
 * 2. Normalize vertical alignment of `progress` in Chrome, Firefox, and Opera.
 */
audio,
canvas,
progress,
video {
  display: inline-block;
  /* 1 */
  vertical-align: baseline;
  /* 2 */
}

/**
 * Prevent modern browsers from displaying `audio` without controls.
 * Remove excess height in iOS 5 devices.
 */
audio:not([controls]) {
  display: none;
  height: 0;
}

/**
 * Address `[hidden]` styling not present in IE 8/9/10.
 * Hide the `template` element in IE 8/9/10/11, Safari, and Firefox < 22.
 */
[hidden],
template {
  display: none;
}

/* Links
   ========================================================================== */
/**
 * Remove the gray background color from active links in IE 10.
 */
a {
  background-color: transparent;
}

/**
 * Improve readability of focused elements when they are also in an
 * active/hover state.
 */
a:active,
a:hover {
  outline: 0;
}

/* Text-level semantics
   ========================================================================== */
/**
 * Address styling not present in IE 8/9/10/11, Safari, and Chrome.
 */
abbr[title] {
  border-bottom: 1px dotted;
}

/**
 * Address style set to `bolder` in Firefox 4+, Safari, and Chrome.
 */
b,
strong {
  font-weight: bold;
}

/**
 * Address styling not present in Safari and Chrome.
 */
dfn {
  font-style: italic;
}

/**
 * Address variable `h1` font-size and margin within `section` and `article`
 * contexts in Firefox 4+, Safari, and Chrome.
 */
h1 {
  font-size: 2em;
  margin: 0.67em 0;
}

/**
 * Address styling not present in IE 8/9.
 */
mark {
  background: #ff0;
  color: #000;
}

/**
 * Address inconsistent and variable font size in all browsers.
 */
small {
  font-size: 80%;
}

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

sup {
  top: -0.5em;
}

sub {
  bottom: -0.25em;
}

/* Embedded content
   ========================================================================== */
/**
 * Remove border when inside `a` element in IE 8/9/10.
 */
img {
  border: 0;
}

/**
 * Correct overflow not hidden in IE 9/10/11.
 */
svg:not(:root) {
  overflow: hidden;
}

/* Grouping content
   ========================================================================== */
/**
 * Address margin not present in IE 8/9 and Safari.
 */
figure {
  margin: 1em 40px;
}

/**
 * Address differences between Firefox and other browsers.
 */
hr {
  box-sizing: content-box;
  height: 0;
}

/**
 * Contain overflow in all browsers.
 */
pre {
  overflow: auto;
}

/**
 * Address odd `em`-unit font size rendering in all browsers.
 */
code,
kbd,
pre,
samp {
  font-family: monospace, monospace;
  font-size: 1em;
}

/* Forms
   ========================================================================== */
/**
 * Known limitation: by default, Chrome and Safari on OS X allow very limited
 * styling of `select`, unless a `border` property is set.
 */
/**
 * 1. Correct color not being inherited.
 *    Known issue: affects color of disabled elements.
 * 2. Correct font properties not being inherited.
 * 3. Address margins set differently in Firefox 4+, Safari, and Chrome.
 */
button,
input,
optgroup,
select,
textarea {
  color: inherit;
  /* 1 */
  font: inherit;
  /* 2 */
  margin: 0;
  /* 3 */
}

/**
 * Address `overflow` set to `hidden` in IE 8/9/10/11.
 */
button {
  overflow: visible;
}

/**
 * Address inconsistent `text-transform` inheritance for `button` and `select`.
 * All other form control elements do not inherit `text-transform` values.
 * Correct `button` style inheritance in Firefox, IE 8/9/10/11, and Opera.
 * Correct `select` style inheritance in Firefox.
 */
button,
select {
  text-transform: none;
}

/**
 * 1. Avoid the WebKit bug in Android 4.0.* where (2) destroys native `audio`
 *    and `video` controls.
 * 2. Correct inability to style clickable `input` types in iOS.
 * 3. Improve usability and consistency of cursor style between image-type
 *    `input` and others.
 */
button,
html input[type=button],
input[type=reset],
input[type=submit] {
  -webkit-appearance: button;
  /* 2 */
  cursor: pointer;
  /* 3 */
}

/**
 * Re-set default cursor for disabled elements.
 */
button[disabled],
html input[disabled] {
  cursor: default;
}

/**
 * Remove inner padding and border in Firefox 4+.
 */
button::-moz-focus-inner,
input::-moz-focus-inner {
  border: 0;
  padding: 0;
}

/**
 * Address Firefox 4+ setting `line-height` on `input` using `!important` in
 * the UA stylesheet.
 */
input {
  line-height: normal;
}

/**
 * It's recommended that you don't attempt to style these elements.
 * Firefox's implementation doesn't respect box-sizing, padding, or width.
 *
 * 1. Address box sizing set to `content-box` in IE 8/9/10.
 * 2. Remove excess padding in IE 8/9/10.
 */
input[type=checkbox],
input[type=radio] {
  box-sizing: border-box;
  /* 1 */
  padding: 0;
  /* 2 */
}

/**
 * Fix the cursor style for Chrome's increment/decrement buttons. For certain
 * `font-size` values of the `input`, it causes the cursor style of the
 * decrement button to change from `default` to `text`.
 */
input[type=number]::-webkit-inner-spin-button,
input[type=number]::-webkit-outer-spin-button {
  height: auto;
}

/**
 * 1. Address `appearance` set to `searchfield` in Safari and Chrome.
 * 2. Address `box-sizing` set to `border-box` in Safari and Chrome.
 */
input[type=search] {
  -webkit-appearance: textfield;
  /* 1 */
  box-sizing: content-box;
  /* 2 */
}

/**
 * Remove inner padding and search cancel button in Safari and Chrome on OS X.
 * Safari (but not Chrome) clips the cancel button when the search input has
 * padding (and `textfield` appearance).
 */
input[type=search]::-webkit-search-cancel-button,
input[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}

/**
 * Define consistent border, margin, and padding.
 */
fieldset {
  border: 1px solid #c0c0c0;
  margin: 0 2px;
  padding: 0.35em 0.625em 0.75em;
}

/**
 * 1. Correct `color` not being inherited in IE 8/9/10/11.
 * 2. Remove padding so people aren't caught out if they zero out fieldsets.
 */
legend {
  border: 0;
  /* 1 */
  padding: 0;
  /* 2 */
}

/**
 * Remove default vertical scrollbar in IE 8/9/10/11.
 */
textarea {
  overflow: auto;
}

/**
 * Don't inherit the `font-weight` (applied by a rule above).
 * NOTE: the default cannot safely be changed in Chrome and Safari on OS X.
 */
optgroup {
  font-weight: bold;
}

/* Tables
   ========================================================================== */
/**
 * Remove most spacing between table cells.
 */
table {
  border-collapse: collapse;
  border-spacing: 0;
}

td,
th {
  padding: 0;
  vertical-align: top;
}

@font-face {
  font-family: "KievitSlabMedium";
  src: url("../fonts/KievitSlabWebPro-Medium.eot?#iefix") format("embedded-opentype"), url("../fonts/KievitSlabWebPro-Medium.woff") format("woff");
  font-weight: normal;
  font-style: normal;
}
@font-face {
  font-family: "KievitSlabRegular";
  src: url("../fonts/KievitSlabWebPro.woff") format("woff");
  font-weight: normal;
  font-style: normal;
}
@font-face {
  font-family: "Vaud";
  src: url("../fonts/VaudBook-webfont.eot?#iefix") format("embedded-opentype"), url("../fonts/VaudBook-webfont.woff") format("woff"), url("../fonts/VaudBook-webfont.ttf") format("truetype"), url("../fonts/VaudBook-webfont.svg#vaudregular") format("svg");
  font-weight: normal;
  font-style: normal;
}
@font-face {
  font-family: "Vaud";
  src: url("../fonts/VaudBookIt-webfont.eot?#iefix") format("embedded-opentype"), url("../fonts/VaudBookIt-webfont.woff") format("woff"), url("../fonts/VaudBookIt-webfont.ttf") format("truetype"), url("../fonts/VaudBookIt-webfont.svg#vauditalic") format("svg");
  font-weight: normal;
  font-style: italic;
}
@font-face {
  font-family: "Vaud";
  src: url("../fonts/VaudUltra-webfont.eot?#iefix") format("embedded-opentype"), url("../fonts/VaudUltra-webfont.woff") format("woff"), url("../fonts/VaudUltra-webfont.ttf") format("truetype"), url("../fonts/VaudUltra-webfont.svg#vaudregular") format("svg");
  font-weight: bold;
  font-style: normal;
}
@font-face {
  font-family: "VaudItalic";
  src: url("../fonts/VaudUltraIt-webfont.eot?#iefix") format("embedded-opentype"), url("../fonts/VaudUltraIt-webfont.woff") format("woff"), url("../fonts/VaudUltraIt-webfont.ttf") format("truetype"), url("../fonts/VaudUltraIt-webfont.svg#vauditalic") format("svg");
  font-weight: bold;
  font-style: italic;
}
@font-face {
  font-family: "VaudMedium";
  src: url("../fonts/VaudExtraBold-webfont.eot?#iefix") format("embedded-opentype"), url("../fonts/VaudExtraBold-webfont.woff") format("woff"), url("../fonts/VaudExtraBold-webfont.ttf") format("truetype"), url("../fonts/VaudExtraBold-webfont.svg#vaudregular") format("svg");
  font-weight: normal;
  font-style: normal;
}
@font-face {
  font-family: "VaudMedium";
  src: url("../fonts/VaudExtraBoldIt-webfont.eot?#iefix") format("embedded-opentype"), url("../fonts/VaudExtraBoldIt-webfont.woff") format("woff"), url("../fonts/VaudExtraBoldIt-webfont.ttf") format("truetype"), url("../fonts/VaudExtraBoldIt-webfont.svg#vaudregular") format("svg");
  font-weight: normal;
  font-style: italic;
}
@font-face {
  font-family: "wagtail";
  src: url("../../wagtailadmin/fonts/wagtail.woff") format("woff");
  font-weight: normal;
  font-style: normal;
}
@media screen and (-webkit-min-device-pixel-ratio: 0) {
  @font-face {
    font-family: "wagtail";
    src: url("../../wagtailadmin/fonts/wagtail.svg#wagtail") format("svg");
  }
}
.ribbon {
  height: 30px;
  background-color: #696b73;
  position: relative;
  z-index: 501;
}
.ribbon__content {
  position: relative;
  height: 100%;
}
.ribbon__breadcrumbs {
  position: absolute;
  left: 10px;
  right: 10px;
  top: 50%;
  transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  color: #ffffff;
  font-family: VaudMedium, sans-serif;
  font-size: 12px;
  line-height: 14px;
  display: none;
}
.ribbon__breadcrumbs a, .ribbon__breadcrumbs a:visited {
  color: #CCCCCC;
}
.ribbon__breadcrumbs a:hover {
  text-decoration: underline;
}
.ribbon__breadcrumbs .active {
  color: #ffffff;
}

@media (min-width: 768px) {
  .ribbon__breadcrumbs {
    display: block;
  }
}
@media (min-width: 1000px) {
  .ribbon__breadcrumbs {
    left: 0;
  }
}
body.bare-page .ribbon {
  display: none !important;
}

.ribbon__search-control {
  display: none;
  font-family: VaudMedium, sans-serif;
  font-size: 12px;
}

.ribbon__search-form {
  width: 100%;
}
.ribbon__search-form.visible {
  display: block;
}
.ribbon__search-form__text {
  width: 80%;
  border: 2px solid #cfcfcf;
  line-height: 26px;
  outline: 0;
  padding: 0 10px;
  -webkit-border-radius: 0;
  -webkit-appearance: none;
}
.ribbon__search-form__submit {
  width: 20%;
  height: 30px;
  border-radius: 0;
  background-color: #F0F0F0;
  padding: 0;
}

@media (min-width: 768px) {
  .ribbon__search-control {
    display: block;
    position: absolute;
    top: 50%;
    right: 5px;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    height: 100%;
    cursor: pointer;
    line-height: 30px;
    color: white;
  }
  .ribbon__search-control img {
    width: 15px;
    vertical-align: middle;
  }

  .ribbon__search-form {
    position: absolute;
    right: 0;
    top: 30px;
    z-index: 500;
    width: 320px;
    padding: 0 10px 10px 10px;
    background-color: #696b73;
    border-bottom-left-radius: 10px;
    opacity: 0;
    display: none;
  }
  .ribbon__search-form.visible {
    display: block;
  }
  .ribbon__search-form__text {
    width: 225px;
    margin-right: 10px;
  }
  .ribbon__search-form__submit {
    width: 65px;
  }
}
@media (min-width: 1000px) {
  .ribbon__search-form {
    border-bottom-right-radius: 10px;
  }
}
.header {
  position: relative;
  margin: 1em 10px 1.5em;
}
.header__wordmark-link {
  display: inline-block;
  width: 60px;
}
.header__wordmark-link img {
  width: 100%;
}
.header__site-title {
  font-family: KievitSlabMedium, Times, serif;
  line-height: 1.2;
  width: 100%;
  margin: 0;
  font-size: 21px;
}
.header__site-title--multiline {
  font-size: 18px;
}
.header__site-title a, .header__site-title a:visited {
  color: black;
  text-decoration: none;
}

@media (min-width: 768px) {
  .header {
    margin: 25px 10px 1.5em;
  }
  .header__wordmark-link {
    width: 185px;
    padding-right: 15px;
  }
  .header__wordmark-link img {
    vertical-align: baseline;
    margin-bottom: -1px;
  }
  .header__site-title {
    font-size: 35px;
  }
  .header__site-title--multiline {
    font-size: 23px;
  }

  body.header-style-full .header__site-title {
    display: inline-block;
    width: calc(100% - 185px);
  }

  body.header-style-half .header__wordmark-link,
body.header-style-sidebar .header__wordmark-link {
    width: 110px;
    display: block;
  }
  body.header-style-half .header__site-title,
body.header-style-sidebar .header__site-title {
    padding-top: 10px;
    padding-right: 15px;
  }

  body.header-style-half .ct-scroller-inner {
    float: left;
    width: 50%;
  }
}
@media (min-width: 1000px) {
  .header {
    margin: 25px 0 1.5em;
  }
  .header__wordmark-link {
    margin-left: 0;
  }
}
body.bare-page .header {
  display: none !important;
}

.main-menu {
  display: none;
}

.one-level-menu {
  font-family: KievitSlabMedium, Times, serif;
  font-size: 0;
}
.one-level-menu__menu-level-1 {
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  flex-wrap: wrap;
}
.one-level-menu__item {
  line-height: 38px;
  font-size: 20px;
  padding: 0 10px;
  background-image: url("/static/caltech_sites/img/orange-pixel.png");
  background-position: bottom;
  background-repeat: repeat-x;
}
.one-level-menu__item:first-child {
  padding-left: 0;
}
.one-level-menu__item.active-trail, .one-level-menu__item:hover {
  background-repeat: no-repeat;
  background-position: center bottom;
  background-image: url("/static/caltech_sites/img/menu-pointer.png");
}
.one-level-menu__item__link {
  white-space: nowrap;
  display: block;
}
.one-level-menu__item__link, .one-level-menu__item__link:visited, .one-level-menu__item__link:active, .one-level-menu__item__link:hover, .one-level-menu__item__link:focus {
  text-decoration: none;
}
.one-level-menu__item__link, .one-level-menu__item__link:visited, .one-level-menu__item__link:active, .one-level-menu__item__link:hover, .one-level-menu__item__link:focus {
  color: #696b73;
}
.one-level-menu__filler--level-1 {
  background-image: url("/static/caltech_sites/img/orange-pixel.png");
  background-position: bottom;
  background-repeat: repeat-x;
  font-size: 20px;
  line-height: 38px;
}
.one-level-menu__filler--level-1 + .one-level-menu__item {
  padding-left: 0;
}

.two-panel-dropdown-menu {
  position: relative;
  z-index: 1000;
}
.two-panel-dropdown-menu__menu-level-1 {
  position: relative;
  width: 100%;
}
.two-panel-dropdown-menu__menu-level-1 {
  margin: 0;
  padding: 0;
  list-style: none;
}
.two-panel-dropdown-menu__menu-level-2 {
  margin: 0;
  padding: 0;
  list-style: none;
  position: absolute;
  left: 0;
  top: 36px;
  border-bottom: 1px solid #ffb084;
  background-color: #f3f3f3;
  width: 1000px;
}
.two-panel-dropdown-menu__menu-level-3 {
  margin: 0;
  padding: 0;
  list-style: none;
  position: absolute;
  left: 300px;
  top: 20px;
}
.two-panel-dropdown-menu__item:not(.open) .menu-level-2, .two-panel-dropdown-menu__item:not(.open) .menu-level-3 {
  display: none;
}
.two-panel-dropdown-menu__item--level-1 {
  display: table-cell;
  background-image: url("/static/caltech_sites/img/orange-pixel.png");
  background-position: bottom;
  background-repeat: repeat-x;
  padding: 0 16px 8px 16px;
}
.two-panel-dropdown-menu__item--level-1:first-child {
  padding-left: 0;
}
.two-panel-dropdown-menu__item--level-1.active-trail, .two-panel-dropdown-menu__item--level-1:hover {
  background-repeat: no-repeat;
  background-position: center bottom;
  background-image: url("/static/caltech_sites/img/menu-pointer.png");
}
.two-panel-dropdown-menu__item__link--level-1 {
  display: block;
  font-size: 18px;
  height: 28px;
  white-space: nowrap;
  font-family: KievitSlabMedium, Times, serif;
  font-weight: normal;
}
.two-panel-dropdown-menu__item__link--level-1, .two-panel-dropdown-menu__item__link--level-1:visited, .two-panel-dropdown-menu__item__link--level-1:active, .two-panel-dropdown-menu__item__link--level-1:hover, .two-panel-dropdown-menu__item__link--level-1:focus {
  text-decoration: none;
}
.two-panel-dropdown-menu__item__link--level-1, .two-panel-dropdown-menu__item__link--level-1:visited, .two-panel-dropdown-menu__item__link--level-1:active, .two-panel-dropdown-menu__item__link--level-1:hover, .two-panel-dropdown-menu__item__link--level-1:focus {
  color: #696b73;
}
.two-panel-dropdown-menu__item__link--level-1:hover {
  border-bottom: 2px solid;
}
.two-panel-dropdown-menu__item--level-2 {
  min-height: 10px;
  width: 275px;
  border-right: 1px solid #ffb084;
}
.two-panel-dropdown-menu__item__link--level-2 {
  display: block;
  padding: 5px 20px;
  font-size: 16px;
  line-height: 18px;
  font-weight: normal;
}
.two-panel-dropdown-menu__item__link--level-2, .two-panel-dropdown-menu__item__link--level-2:visited, .two-panel-dropdown-menu__item__link--level-2:active, .two-panel-dropdown-menu__item__link--level-2:hover, .two-panel-dropdown-menu__item__link--level-2:focus {
  text-decoration: none;
}
.two-panel-dropdown-menu__item__link--level-2, .two-panel-dropdown-menu__item__link--level-2:visited, .two-panel-dropdown-menu__item__link--level-2:active, .two-panel-dropdown-menu__item__link--level-2:hover, .two-panel-dropdown-menu__item__link--level-2:focus {
  color: #696b73;
}
.two-panel-dropdown-menu__item__link--level-2.open {
  background-color: #ffb084;
  color: black;
}
.two-panel-dropdown-menu__item--level-3 {
  line-height: 20px;
  padding: 0 3px;
}
.two-panel-dropdown-menu__item--level-3:hover {
  background-color: #ffb084;
}
.two-panel-dropdown-menu__item__link--level-3 {
  font-size: 16px;
}
.two-panel-dropdown-menu__item__link--level-3, .two-panel-dropdown-menu__item__link--level-3:visited, .two-panel-dropdown-menu__item__link--level-3:active, .two-panel-dropdown-menu__item__link--level-3:hover, .two-panel-dropdown-menu__item__link--level-3:focus {
  text-decoration: none;
}
.two-panel-dropdown-menu__item__link--level-3, .two-panel-dropdown-menu__item__link--level-3:visited, .two-panel-dropdown-menu__item__link--level-3:active, .two-panel-dropdown-menu__item__link--level-3:hover, .two-panel-dropdown-menu__item__link--level-3:focus {
  color: #696b73;
}
.two-panel-dropdown-menu__item__link--level-3:hover {
  color: #ffffff;
}
.two-panel-dropdown-menu__filler--level-1 {
  display: table-cell;
  background-image: url("/static/caltech_sites/img/orange-pixel.png");
  background-position: bottom;
  background-repeat: repeat-x;
}
.two-panel-dropdown-menu__filler--level-2 {
  min-height: 10px;
  width: 275px;
  border-right: 1px solid #ffb084;
}

.application-style-menu {
  position: relative;
  z-index: 1000;
}
.application-style-menu__menu-level-1 {
  position: relative;
  width: 100%;
}
.application-style-menu__menu-level-1 {
  margin: 0;
  padding: 0;
  list-style: none;
}
.application-style-menu__menu-level-2 {
  margin: 0;
  padding: 0;
  list-style: none;
  position: absolute;
  left: 0;
  top: 36px;
  border-bottom: 1px solid #ffb084;
  background-color: #f3f3f3;
}
.application-style-menu__item:not(.open) .menu-level-2 {
  display: none;
}
.application-style-menu__item--level-1 {
  display: table-cell;
  background-image: url("/static/caltech_sites/img/orange-pixel.png");
  background-position: bottom;
  background-repeat: repeat-x;
  padding: 0 16px 8px 16px;
  position: relative;
}
.application-style-menu__item--level-1:first-child {
  padding-left: 0;
}
.application-style-menu__item--level-1.active-trail, .application-style-menu__item--level-1:hover {
  background-repeat: no-repeat;
  background-position: center bottom;
  background-image: url("/static/caltech_sites/img/menu-pointer.png");
}
.application-style-menu__item__link--level-1 {
  display: block;
  font-size: 18px;
  height: 28px;
  white-space: nowrap;
  font-family: KievitSlabMedium, Times, serif;
  font-weight: normal;
}
.application-style-menu__item__link--level-1, .application-style-menu__item__link--level-1:visited, .application-style-menu__item__link--level-1:active, .application-style-menu__item__link--level-1:hover, .application-style-menu__item__link--level-1:focus {
  text-decoration: none;
}
.application-style-menu__item__link--level-1, .application-style-menu__item__link--level-1:visited, .application-style-menu__item__link--level-1:active, .application-style-menu__item__link--level-1:hover, .application-style-menu__item__link--level-1:focus {
  color: #696b73;
}
.application-style-menu__item__link--level-1:hover {
  border-bottom: 2px solid;
}
.application-style-menu__item--level-2 {
  min-height: 10px;
}
.application-style-menu__item__link--level-2 {
  display: block;
  padding: 5px 20px;
  font-size: 16px;
  line-height: 18px;
  font-weight: normal;
  white-space: nowrap;
}
.application-style-menu__item__link--level-2, .application-style-menu__item__link--level-2:visited, .application-style-menu__item__link--level-2:active, .application-style-menu__item__link--level-2:hover, .application-style-menu__item__link--level-2:focus {
  text-decoration: none;
}
.application-style-menu__item__link--level-2, .application-style-menu__item__link--level-2:visited, .application-style-menu__item__link--level-2:active, .application-style-menu__item__link--level-2:hover, .application-style-menu__item__link--level-2:focus {
  color: #696b73;
}
.application-style-menu__item__link--level-2.open {
  background-color: #ffb084;
  color: black;
}
.application-style-menu__filler--level-1 {
  display: table-cell;
  background-image: url("/static/caltech_sites/img/orange-pixel.png");
  background-position: bottom;
  background-repeat: repeat-x;
}
.application-style-menu__filler--level-2 {
  min-height: 10px;
}

.secondary-menu {
  display: none;
}
.secondary-menu__row {
  font-size: 1em;
  padding: 0 20px;
  margin: 0;
  list-style: none;
  display: flex;
  flex-wrap: wrap;
}
.secondary-menu__row:nth-child(even) {
  background-color: #76777b;
  color: #ffffff;
}
.secondary-menu__row:nth-child(even) a {
  border-bottom-color: #76777b;
}
.secondary-menu__row:nth-child(even) a, .secondary-menu__row:nth-child(even) a:visited, .secondary-menu__row:nth-child(even) a:active, .secondary-menu__row:nth-child(even) a:hover, .secondary-menu__row:nth-child(even) a:focus {
  color: #ffffff;
}
.secondary-menu__row:nth-child(odd) {
  background-color: #c8c8c8;
  color: #000000;
}
.secondary-menu__row:nth-child(odd) a {
  border-bottom-color: #c8c8c8;
}
.secondary-menu__row:nth-child(odd) a, .secondary-menu__row:nth-child(odd) a:visited, .secondary-menu__row:nth-child(odd) a:active, .secondary-menu__row:nth-child(odd) a:hover, .secondary-menu__row:nth-child(odd) a:focus {
  color: #000000;
}
.secondary-menu__item {
  white-space: nowrap;
  line-height: 34px;
  padding-right: 0.7em;
  position: relative;
}
.secondary-menu__item::after {
  content: "|";
  color: white;
  font-weight: normal;
  margin-left: 0.4em;
}
.secondary-menu__item:first-child {
  padding-left: 0;
}
.secondary-menu__item:last-child {
  background: none;
}
.secondary-menu__item:last-child::after {
  display: none;
}
.secondary-menu__item.active-trail {
  font-weight: bold;
}
.secondary-menu__item__link, .secondary-menu__item__link:visited, .secondary-menu__item__link:active, .secondary-menu__item__link:hover, .secondary-menu__item__link:focus {
  text-decoration: none;
}
.secondary-menu__item__link:hover {
  border-radius: 3px;
  border-bottom-width: 10px;
  border-bottom-style: solid;
}

body.header-style-half.single-level-menu .one-level-menu {
  margin-top: 24px;
}
body.header-style-half.single-level-menu .secondary-menu {
  float: left;
  clear: both;
  width: 100%;
}

@media (min-width: 768px) {
  body.header-style-half .main-menu,
body.header-style-sidebar .main-menu {
    width: 50%;
    float: left;
  }

  .main-menu {
    display: block;
    margin: 0 10px;
  }

  .secondary-menu {
    display: block;
    margin: 0 10px;
  }

  .one-level-menu {
    margin-top: 30px;
  }
}
@media (min-width: 1000px) {
  .main-menu {
    margin-right: 0;
    margin-left: 0;
  }

  .secondary-menu {
    margin: 0;
  }
}
.ct-scroller {
  height: 100%;
  position: relative;
}

.ct-pusher {
  position: relative;
  left: 0;
  min-height: 100vh;
}

.ct-menu {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 1;
  width: 300px;
  height: 100vh;
  transform: translateX(-100%);
}
.ct-menu a, .ct-menu a:visited {
  color: white;
}
.ct-menu ul {
  overflow-y: auto;
  margin: 0;
  padding: 0;
  list-style: none;
  position: relative;
}

.sidebar-menu-burger {
  display: none;
  z-index: 1;
}

.ct-level {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #515258;
  transform: translateX(-100%);
  overflow-y: auto;
}

.ct-has-children {
  float: right;
  padding-left: 0.5em;
  padding-right: 0.5em;
  display: inline-block;
}
.ct-has-children::after {
  content: "    ";
  font-family: FontAwesome;
}

.ct-back {
  text-align: right;
  background: #44464b;
  text-transform: uppercase;
  font-weight: 600;
}

.ct-menu ul li > a.ct-back {
  font-size: 1em;
}

.back-arrow {
  display: inline-block;
  margin-left: -1em;
  float: left;
}
.back-arrow::before {
  content: "";
  font-family: FontAwesome;
}

/* overlays for pusher and for level that gets covered */
.ct-pusher::after,
.ct-level::after,
.ct-level::before {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 0;
  height: 0;
  opacity: 0;
}

.ct-pusher::after,
.ct-level::after {
  background: rgba(0, 0, 0, 0.3);
  transition: opacity 0.3s, width 0.1s 0.3s, height 0.1s 0.3s;
}

.ct-level::after {
  z-index: -1;
}

.ct-pusher.ct-pushed::after,
.ct-level.ct-level-overlay::after {
  width: 100%;
  height: 100%;
  opacity: 1;
  transition: opacity 0.3s;
}

.ct-level.ct-level-overlay {
  cursor: pointer;
}

.ct-level.ct-level-overlay.ct-level::before {
  width: 100%;
  height: 100%;
  background: transparent;
  opacity: 1;
}

.ct-pusher,
.ct-level,
.ct-pushable,
.ct-menu {
  transition: all 0.5s;
}

/* overlap */
.ct-overlap .ct-level.ct-level-open {
  box-shadow: 1px 0 2px rgba(0, 0, 0, 0.2);
  transform: translateX(-40px);
  height: 100vw;
}

/* First level */
.ct-menu > .ct-level,
.ct-menu > .ct-level.ct-level-open,
.ct-menu.ct-overlap > .ct-level,
.ct-menu.ct-overlap > .ct-level.ct-level-open {
  box-shadow: none;
  transform: translateX(0);
}

.ct-menu .ct-level.ct-level-open {
  transform: translateX(0);
}

.ct-menu .ct-level.ct-level-open > ul > li > .ct-level:not(.ct-level-open) {
  transform: translateX(-100%);
}

.ct-menu h2 {
  margin: 0;
  padding: 1em;
  color: rgba(0, 0, 0, 0.4);
  text-shadow: 0 0 1px rgba(0, 0, 0, 0.1);
  font-weight: 300;
  font-size: 2em;
}

.ct-menu.ct-overlap h2::before {
  position: absolute;
  top: 0;
  right: 0;
  margin-right: 8px;
  font-size: 75%;
  line-height: 1.8;
  opacity: 0;
  transform: translateX(-100%);
  transition: opacity 0.3s, transform 0.1s 0.3s;
}

.ct-menu h2 {
  text-transform: uppercase;
  letter-spacing: 1px;
  font-weight: 700;
  font-size: 1em;
}

.ct-overlap .ct-level.ct-level-overlay > h2::before {
  opacity: 1;
  transform: translateX(0);
  transition: transform 0.3s, opacity 0.3s;
}

.ct-menu ul li > a,
.ct-menu ul li.title {
  display: block;
  padding: 0.7em 1em 0.7em 1.8em;
  outline: none;
  box-shadow: inset 0 -1px rgba(0, 0, 0, 0.2);
  text-shadow: 0 0 1px rgba(255, 255, 255, 0.1);
  font-size: 1.3em;
  transition: background 0.3s, box-shadow 0.3s;
}

.ct-menu ul li.title {
  font-family: KievitSlabMedium, Times, serif;
  color: white;
  background: #44464b;
}

.ct-menu ul li::before {
  position: absolute;
  left: 10px;
  z-index: -1;
  color: rgba(0, 0, 0, 0.2);
  line-height: 3.5;
}

.ct-level > ul > li:first-child > a {
  box-shadow: inset 0 -1px rgba(0, 0, 0, 0.2), inset 0 1px rgba(0, 0, 0, 0.2);
}

.ct-menu ul li a:hover,
.ct-level > ul > li:first-child > a:hover {
  background: rgba(0, 0, 0, 0.2);
  box-shadow: inset 0 -1px rgba(0, 0, 0, 0);
}

.ct-menu .ct-level.ct-level-overlay > ul > li > a,
.ct-level.ct-level-overlay > ul > li:first-child > a {
  box-shadow: inset 0 -1px rgba(0, 0, 0, 0);
}

.ct-level > ul > li:first-child > a:hover,
.ct-level.ct-level-overlay > ul > li:first-child > a {
  box-shadow: inset 0 -1px rgba(0, 0, 0, 0), inset 0 1px rgba(0, 0, 0, 0);
}

/* seems like Chrome 34.0.1847.131 needs the second shadow otherwise the transition breaks */
/* Fallback example for browsers that don't support 3D transforms (and no JS fallback) */
/* We'll show the first level only */
.no-csstransforms3d .ct-pusher,
.no-js .ct-pusher {
  padding-left: 300px;
}

.no-csstransforms3d .ct-menu .ct-level,
.no-js .ct-menu .ct-level {
  display: none;
}

.no-csstransforms3d .ct-menu > .ct-level,
.no-js .ct-menu > .ct-level {
  display: block;
}

body.header-style-sidebar-right .ct-menu {
  right: 0;
  left: auto;
  transform: translateX(100%);
}

@media (min-width: 768px) {
  .sidebar-menu-burger {
    display: block;
    position: fixed;
    top: 53px;
  }
  .sidebar-menu-burger img {
    height: 25px;
    width: 25px;
  }
  .sidebar-menu-burger.secondary {
    display: none;
  }

  body.header-style-sidebar.header-style-sidebar-left {
    overflow-x: hidden;
  }
  body.header-style-sidebar.header-style-sidebar-left .sidebar-menu-burger {
    display: none;
  }
  body.header-style-sidebar.header-style-sidebar-left .sidebar-menu-burger.secondary {
    display: block;
    right: 20px;
  }
  body.header-style-sidebar.header-style-sidebar-right .sidebar-menu-burger {
    right: 320px;
  }
  body.header-style-sidebar .ct-scroller-inner {
    float: none;
    width: 100%;
  }
}
@media (min-width: 1100px) {
  body.header-style-sidebar.header-style-sidebar-left .sidebar-menu-burger {
    display: block;
    left: 310px;
  }
  body.header-style-sidebar.header-style-sidebar-left .sidebar-menu-burger.secondary {
    display: none;
  }
}
body.bare-page .ct-scroller {
  display: none !important;
}

.menu-burger-wrapper {
  position: absolute;
  top: 0;
  right: 10px;
  margin: 0;
}

.mobile-menu-burger, .mobile-menu-close {
  height: 18px;
  width: 18px;
}

.mobile-menu-close {
  display: none;
}

.explorer {
  pointer-events: none;
  width: 100%;
  position: relative;
  top: 0;
  left: 0;
  display: none;
  z-index: 500;
}
.explorer ul {
  background: #333;
  padding: 0;
  margin: 0;
  list-style: none;
  -webkit-transform-style: preserve-3d;
  transform-style: preserve-3d;
}
.explorer li {
  position: relative;
  border-top: 1px solid #404040;
}
.explorer li:first-child {
  border-top: 0;
}
.explorer a {
  text-decoration: none;
  padding: 0.9em;
  color: #fff;
  display: block;
  position: relative;
  outline: none;
  white-space: nowrap;
  text-overflow: ellipsis;
  overflow: hidden;
}
.explorer a:before {
  margin-right: 0.5em;
  font-size: 1.5em;
}
.explorer a:hover {
  background: #246060;
  color: #fff;
}
.explorer .has-children a {
  padding-right: 5em;
}
.explorer .children {
  position: absolute;
  z-index: 501;
  right: 0;
  top: 0;
  width: 4em;
  text-align: center;
  height: 100%;
  color: #fff;
  background-color: #333;
  cursor: pointer;
  border-left: 1px solid rgba(255, 255, 255, 0.2);
}
.explorer .children:before {
  padding: 0.55em 0;
  display: block;
  width: 100%;
  text-align: center;
  font-size: 1.7em;
}
.explorer .children:hover {
  background: #246060;
}
.explorer .dl-subviewopen > .children,
.explorer .dl-subview > .children {
  display: none;
}
.explorer .dl-menu {
  position: relative;
  width: 100%;
  opacity: 0;
  pointer-events: none;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}
.explorer .dl-menu.dl-menuopen {
  opacity: 1;
  pointer-events: auto;
}
.explorer li .dl-submenu {
  display: none;
}
.explorer .dl-menu.dl-subview li,
.explorer .dl-menu.dl-subview li.dl-subviewopen > a,
.explorer .dl-menu.dl-subview li.dl-subview > a {
  display: none;
}
.explorer .dl-menu.dl-subview li.dl-subview,
.explorer .dl-menu.dl-subview li.dl-subview .dl-submenu,
.explorer .dl-menu.dl-subview li.dl-subviewopen,
.explorer .dl-menu.dl-subview li.dl-subviewopen > .dl-submenu,
.explorer .dl-menu.dl-subview li.dl-subviewopen > .dl-submenu > li {
  display: block;
}
.explorer > .dl-submenu {
  position: absolute;
  width: 100%;
  top: 0;
  left: 0;
}
body.explorer-open .explorer {
  display: block;
}

.dl-menu.dl-animate-out-1 {
  -webkit-animation: MenuAnimOut1 0.4s;
  animation: MenuAnimOut1 0.4s;
}

.dl-menu.dl-animate-out-2 {
  -webkit-animation: MenuAnimOut2 0.3s ease-in-out;
  animation: MenuAnimOut2 0.3s ease-in-out;
}

.dl-menu.dl-animate-out-3 {
  -webkit-animation: MenuAnimOut3 0.4s ease;
  animation: MenuAnimOut3 0.4s ease;
}

.dl-menu.dl-animate-out-4 {
  -webkit-animation: MenuAnimOut4 0.4s ease;
  animation: MenuAnimOut4 0.4s ease;
}

.dl-menu.dl-animate-out-5 {
  -webkit-animation: MenuAnimOut5 0.4s ease;
  animation: MenuAnimOut5 0.4s ease;
}

@-webkit-keyframes MenuAnimOut1 {
  50% {
    -webkit-transform: translateZ(-250px) rotateY(30deg);
  }
  75% {
    -webkit-transform: translateZ(-372.5px) rotateY(15deg);
    opacity: 0.5;
  }
  100% {
    -webkit-transform: translateZ(-500px) rotateY(0deg);
    opacity: 0;
  }
}
@-webkit-keyframes MenuAnimOut2 {
  100% {
    -webkit-transform: translateX(-100%);
    opacity: 0;
  }
}
@-webkit-keyframes MenuAnimOut3 {
  100% {
    -webkit-transform: translateZ(300px);
    opacity: 0;
  }
}
@-webkit-keyframes MenuAnimOut4 {
  100% {
    -webkit-transform: translateZ(-300px);
    opacity: 0;
  }
}
@-webkit-keyframes MenuAnimOut5 {
  100% {
    -webkit-transform: translateY(40%);
    opacity: 0;
  }
}
@keyframes MenuAnimOut1 {
  50% {
    -webkit-transform: translateZ(-250px) rotateY(30deg);
    transform: translateZ(-250px) rotateY(30deg);
  }
  75% {
    -webkit-transform: translateZ(-372.5px) rotateY(15deg);
    transform: translateZ(-372.5px) rotateY(15deg);
    opacity: 0.5;
  }
  100% {
    -webkit-transform: translateZ(-500px) rotateY(0deg);
    transform: translateZ(-500px) rotateY(0deg);
    opacity: 0;
  }
}
@keyframes MenuAnimOut2 {
  100% {
    -webkit-transform: translateX(-100%);
    transform: translateX(-100%);
    opacity: 0;
  }
}
@keyframes MenuAnimOut3 {
  100% {
    -webkit-transform: translateZ(300px);
    transform: translateZ(300px);
    opacity: 0;
  }
}
@keyframes MenuAnimOut4 {
  100% {
    -webkit-transform: translateZ(-300px);
    transform: translateZ(-300px);
    opacity: 0;
  }
}
@keyframes MenuAnimOut5 {
  100% {
    -webkit-transform: translateY(40%);
    transform: translateY(40%);
    opacity: 0;
  }
}
.dl-menu.dl-animate-in-1 {
  -webkit-animation: MenuAnimIn1 0.3s;
  animation: MenuAnimIn1 0.3s;
}

.dl-menu.dl-animate-in-2 {
  -webkit-animation: MenuAnimIn2 0.3s ease-in-out;
  animation: MenuAnimIn2 0.3s ease-in-out;
}

.dl-menu.dl-animate-in-3 {
  -webkit-animation: MenuAnimIn3 0.4s ease;
  animation: MenuAnimIn3 0.4s ease;
}

.dl-menu.dl-animate-in-4 {
  -webkit-animation: MenuAnimIn4 0.4s ease;
  animation: MenuAnimIn4 0.4s ease;
}

.dl-menu.dl-animate-in-5 {
  -webkit-animation: MenuAnimIn5 0.4s ease;
  animation: MenuAnimIn5 0.4s ease;
}

@-webkit-keyframes MenuAnimIn1 {
  0% {
    -webkit-transform: translateZ(-500px) rotateY(0deg);
    opacity: 0;
  }
  20% {
    -webkit-transform: translateZ(-250px) rotateY(30deg);
    opacity: 0.5;
  }
  100% {
    -webkit-transform: translateZ(0) rotateY(0deg);
    opacity: 1;
  }
}
@-webkit-keyframes MenuAnimIn2 {
  0% {
    -webkit-transform: translateX(-100%);
    opacity: 0;
  }
  100% {
    -webkit-transform: translateX(0);
    opacity: 1;
  }
}
@-webkit-keyframes MenuAnimIn3 {
  0% {
    -webkit-transform: translateZ(300px);
    opacity: 0;
  }
  100% {
    -webkit-transform: translateZ(0);
    opacity: 1;
  }
}
@-webkit-keyframes MenuAnimIn4 {
  0% {
    -webkit-transform: translateZ(-300px);
    opacity: 0;
  }
  100% {
    -webkit-transform: translateZ(0);
    opacity: 1;
  }
}
@-webkit-keyframes MenuAnimIn5 {
  0% {
    -webkit-transform: translateY(40%);
    opacity: 0;
  }
  100% {
    -webkit-transform: translateY(0);
    opacity: 1;
  }
}
@keyframes MenuAnimIn1 {
  0% {
    -webkit-transform: translateZ(-500px) rotateY(0deg);
    transform: translateZ(-500px) rotateY(0deg);
    opacity: 0;
  }
  20% {
    -webkit-transform: translateZ(-250px) rotateY(30deg);
    transform: translateZ(-250px) rotateY(30deg);
    opacity: 0.5;
  }
  100% {
    -webkit-transform: translateZ(0) rotateY(0deg);
    transform: translateZ(0) rotateY(0deg);
    opacity: 1;
  }
}
@keyframes MenuAnimIn2 {
  0% {
    -webkit-transform: translateX(-100%);
    transform: translateX(-100%);
    opacity: 0;
  }
  100% {
    -webkit-transform: translateX(0);
    transform: translateX(0);
    opacity: 1;
  }
}
@keyframes MenuAnimIn3 {
  0% {
    -webkit-transform: translateZ(300px);
    transform: translateZ(300px);
    opacity: 0;
  }
  100% {
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
    opacity: 1;
  }
}
@keyframes MenuAnimIn4 {
  0% {
    -webkit-transform: translateZ(-300px);
    transform: translateZ(-300px);
    opacity: 0;
  }
  100% {
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
    opacity: 1;
  }
}
@keyframes MenuAnimIn5 {
  0% {
    -webkit-transform: translateY(40%);
    transform: translateY(40%);
    opacity: 0;
  }
  100% {
    -webkit-transform: translateY(0);
    transform: translateY(0);
    opacity: 1;
  }
}
.explorer > .dl-submenu.dl-animate-in-1 {
  -webkit-animation: SubMenuAnimIn1 0.4s ease;
  animation: SubMenuAnimIn1 0.4s ease;
}
.explorer > .dl-submenu.dl-animate-in-2 {
  -webkit-animation: SubMenuAnimIn2 0.3s ease-in-out;
  animation: SubMenuAnimIn2 0.3s ease-in-out;
}
.explorer > .dl-submenu.dl-animate-in-3 {
  -webkit-animation: SubMenuAnimIn3 0.4s ease;
  animation: SubMenuAnimIn3 0.4s ease;
}
.explorer > .dl-submenu.dl-animate-in-4 {
  -webkit-animation: SubMenuAnimIn4 0.4s ease;
  animation: SubMenuAnimIn4 0.4s ease;
}
.explorer > .dl-submenu.dl-animate-in-5 {
  -webkit-animation: SubMenuAnimIn5 0.4s ease;
  animation: SubMenuAnimIn5 0.4s ease;
}

@-webkit-keyframes SubMenuAnimIn1 {
  0% {
    -webkit-transform: translateX(50%);
    opacity: 0;
  }
  100% {
    -webkit-transform: translateX(0);
    opacity: 1;
  }
}
@-webkit-keyframes SubMenuAnimIn2 {
  0% {
    -webkit-transform: translateX(100%);
    opacity: 0;
  }
  100% {
    -webkit-transform: translateX(0);
    opacity: 1;
  }
}
@-webkit-keyframes SubMenuAnimIn3 {
  0% {
    -webkit-transform: translateZ(-300px);
    opacity: 0;
  }
  100% {
    -webkit-transform: translateZ(0);
    opacity: 1;
  }
}
@-webkit-keyframes SubMenuAnimIn4 {
  0% {
    -webkit-transform: translateZ(300px);
    opacity: 0;
  }
  100% {
    -webkit-transform: translateZ(0);
    opacity: 1;
  }
}
@-webkit-keyframes SubMenuAnimIn5 {
  0% {
    -webkit-transform: translateZ(-200px);
    opacity: 0;
  }
  100% {
    -webkit-transform: translateZ(0);
    opacity: 1;
  }
}
@keyframes SubMenuAnimIn1 {
  0% {
    -webkit-transform: translateX(50%);
    transform: translateX(50%);
    opacity: 0;
  }
  100% {
    -webkit-transform: translateX(0);
    transform: translateX(0);
    opacity: 1;
  }
}
@keyframes SubMenuAnimIn2 {
  0% {
    -webkit-transform: translateX(100%);
    transform: translateX(100%);
    opacity: 0;
  }
  100% {
    -webkit-transform: translateX(0);
    transform: translateX(0);
    opacity: 1;
  }
}
@keyframes SubMenuAnimIn3 {
  0% {
    -webkit-transform: translateZ(-300px);
    transform: translateZ(-300px);
    opacity: 0;
  }
  100% {
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
    opacity: 1;
  }
}
@keyframes SubMenuAnimIn4 {
  0% {
    -webkit-transform: translateZ(300px);
    transform: translateZ(300px);
    opacity: 0;
  }
  100% {
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
    opacity: 1;
  }
}
@keyframes SubMenuAnimIn5 {
  0% {
    -webkit-transform: translateZ(-200px);
    transform: translateZ(-200px);
    opacity: 0;
  }
  100% {
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
    opacity: 1;
  }
}
.explorer > .dl-submenu.dl-animate-out-1 {
  -webkit-animation: SubMenuAnimOut1 0.4s ease;
  animation: SubMenuAnimOut1 0.4s ease;
}
.explorer > .dl-submenu.dl-animate-out-2 {
  -webkit-animation: SubMenuAnimOut2 0.3s ease-in-out;
  animation: SubMenuAnimOut2 0.3s ease-in-out;
}
.explorer > .dl-submenu.dl-animate-out-3 {
  -webkit-animation: SubMenuAnimOut3 0.4s ease;
  animation: SubMenuAnimOut3 0.4s ease;
}
.explorer > .dl-submenu.dl-animate-out-4 {
  -webkit-animation: SubMenuAnimOut4 0.4s ease;
  animation: SubMenuAnimOut4 0.4s ease;
}
.explorer > .dl-submenu.dl-animate-out-5 {
  -webkit-animation: SubMenuAnimOut5 0.4s ease;
  animation: SubMenuAnimOut5 0.4s ease;
}

@-webkit-keyframes SubMenuAnimOut1 {
  0% {
    -webkit-transform: translateX(0%);
    opacity: 1;
  }
  100% {
    -webkit-transform: translateX(50%);
    opacity: 0;
  }
}
@-webkit-keyframes SubMenuAnimOut2 {
  0% {
    -webkit-transform: translateX(0%);
    opacity: 1;
  }
  100% {
    -webkit-transform: translateX(100%);
    opacity: 0;
  }
}
@-webkit-keyframes SubMenuAnimOut3 {
  0% {
    -webkit-transform: translateZ(0);
    opacity: 1;
  }
  100% {
    -webkit-transform: translateZ(-300px);
    opacity: 0;
  }
}
@-webkit-keyframes SubMenuAnimOut4 {
  0% {
    -webkit-transform: translateZ(0);
    opacity: 1;
  }
  100% {
    -webkit-transform: translateZ(300px);
    opacity: 0;
  }
}
@-webkit-keyframes SubMenuAnimOut5 {
  0% {
    -webkit-transform: translateZ(0);
    opacity: 1;
  }
  100% {
    -webkit-transform: translateZ(-200px);
    opacity: 0;
  }
}
@keyframes SubMenuAnimOut1 {
  0% {
    -webkit-transform: translateX(0%);
    transform: translateX(0%);
    opacity: 1;
  }
  100% {
    -webkit-transform: translateX(50%);
    transform: translateX(50%);
    opacity: 0;
  }
}
@keyframes SubMenuAnimOut2 {
  0% {
    -webkit-transform: translateX(0%);
    transform: translateX(0%);
    opacity: 1;
  }
  100% {
    -webkit-transform: translateX(100%);
    transform: translateX(100%);
    opacity: 0;
  }
}
@keyframes SubMenuAnimOut3 {
  0% {
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
    opacity: 1;
  }
  100% {
    -webkit-transform: translateZ(-300px);
    transform: translateZ(-300px);
    opacity: 0;
  }
}
@keyframes SubMenuAnimOut4 {
  0% {
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
    opacity: 1;
  }
  100% {
    -webkit-transform: translateZ(300px);
    transform: translateZ(300px);
    opacity: 0;
  }
}
@keyframes SubMenuAnimOut5 {
  0% {
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
    opacity: 1;
  }
  100% {
    -webkit-transform: translateZ(-200px);
    transform: translateZ(-200px);
    opacity: 0;
  }
}
body.ready .children {
  transition: all 0.2s linear;
}
body.ready .dl-menu.dl-menu-toggle {
  transition: all 0.3s ease;
}

.explorer-close {
  display: none;
  padding: 0.9em;
  border-bottom: 1px solid rgba(200, 200, 200, 0.1);
  cursor: pointer;
}
body.explorer-open .explorer-close {
  display: block;
}

.icon:before,
.icon:after {
  font-family: "wagtail";
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  speak: none;
  text-decoration: none;
  width: 1.3em;
  line-height: 1em;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-align: left;
  vertical-align: middle;
  margin-right: 0.2em;
}

.icon:after {
  text-align: right;
}

.icon-arrow-right:before {
  content: "n";
}

.icon-arrow-left:before {
  content: "z";
}

@media (min-width: 768px) {
  .explorer, .menu-burger-wrapper {
    display: none;
  }
}
.custom-menu {
  list-style: none;
  padding: 0;
  margin: 0;
  position: absolute;
  top: 0;
  display: none;
}
.custom-menu li {
  height: 100%;
  padding: 0 5px;
  display: table-cell;
  vertical-align: middle;
  font-family: VaudMedium, sans-serif;
}
.custom-menu span, .custom-menu a {
  color: white;
}

.ribbon__custom-menu {
  right: 30px;
  height: 100%;
}
.ribbon__custom-menu li {
  text-transform: uppercase;
  font-size: 11px;
}
.ribbon__custom-menu a:hover {
  text-decoration: none;
}

.footer__custom-menu {
  right: 10px;
}
.footer__custom-menu li:last-child {
  padding-right: 0;
}
.footer__custom-menu a {
  color: #EEE;
  text-decoration: underline;
}

@media (min-width: 500px) {
  .footer__custom-menu {
    display: block;
    top: 10px;
  }
  .footer__custom-menu + .footer__login-status {
    top: 28px;
  }
}
@media (min-width: 768px) {
  .ribbon__custom-menu {
    display: table;
  }
}
.content {
  overflow-x: hidden;
}
.content:before, .content:after {
  content: "";
  display: table;
}
.content:after {
  clear: both;
}
@media (min-width: 1025px) {
  .content {
    overflow-x: unset;
  }
}
@media (min-width: 768px) {
  .content {
    margin-top: 30px;
    margin-bottom: 75px;
  }
}
.content a, .content a:visited {
  color: #D14900;
  text-decoration: none;
}
.content .container, .content .container-fluid {
  padding: 0;
}
.content h1.title, .content__title {
  margin-top: 0;
  font-size: 26px;
  font-weight: bold;
  line-height: 30px;
  color: #616265;
  padding: 0 10px;
}
@media (min-width: 1000px) {
  .content h1.title, .content__title {
    padding: 0;
  }
}
.content__subtitle {
  font-size: 14px;
  font-weight: normal;
  color: #76777b;
  margin: 10px 0 0 0;
  padding: 0 10px;
}
@media (min-width: 1000px) {
  .content__subtitle {
    padding: 0;
  }
}
@media (min-width: 500px) {
  .content__sidebar {
    width: 50%;
    padding-left: 50px;
    margin-bottom: 50px;
    float: right;
  }
}
.content__sidebar img {
  width: 100%;
  height: auto;
  display: block;
}
.content__sidebar .caption {
  margin-top: 15px;
  width: 90%;
  font-size: 12px;
}
.content__sidebar .photo-credit {
  margin-top: 5px;
  width: 90%;
  font-size: 11px;
  font-style: italic;
  color: #616265;
}
.content__title-subtitle-container {
  margin-bottom: 10px;
  padding: 0 10px;
}
@media (min-width: 1000px) {
  .content__title-subtitle-container {
    padding: 0;
  }
  .content__title-subtitle-container--has-sidebar {
    float: left;
    width: 500px;
    margin-bottom: 30px;
    padding: 0;
  }
}
.content__archives-link {
  display: block;
  padding: 0 10px 10px 10px;
  text-align: right;
  text-transform: lowercase;
}
.content .content__archives-link, .content .content__archives-link:visited, .content .content__archives-link:active, .content .content__archives-link:hover, .content .content__archives-link:focus {
  color: #7a303f;
}

@media (min-width: 1000px) {
  .page-content--has-sidebar {
    width: 800px;
    clear: left;
  }
}

table {
  width: 100%;
  max-width: 100%;
}
table a {
  word-wrap: break-word;
}

table.stripy tr:nth-child(odd) {
  background-color: #eee;
}

.scrollable-table {
  overflow-x: auto;
}
@media (min-width: 1000px) {
  .scrollable-table {
    overflow-x: initial;
  }
}

.messages {
  list-style: none;
  padding: 0;
}
.messages li {
  border: 1px solid #888;
  border-radius: 3px;
  margin-bottom: 5px;
  padding: 5px;
}
.messages li.info {
  background: #CCC;
  color: #1C1C1C;
  border-color: #999;
}
.messages li.success {
  background: #AFA;
  color: green;
  border-color: green;
}
.messages li.error {
  color: red;
  background: #FCC;
  border-color: red;
}
.messages li.warning {
  color: #F90;
  background: #FFC;
  border-color: #F90;
}

.rich-text {
  line-height: 1.7;
}
.rich-text:before, .rich-text:after {
  content: "";
  display: table;
}
.rich-text:after {
  clear: both;
}
.rich-text ol, .rich-text ul {
  margin: 1em 0;
  padding: 0 0 0 40px;
  overflow: auto;
}
.rich-text li {
  display: list-item;
}
.rich-text ul li {
  list-style-type: disc;
}
.rich-text ol li {
  list-style-type: decimal;
}
.rich-text p + ul, .rich-text p + ol {
  margin-top: -20px;
  margin-bottom: 30px;
}
.rich-text h2, .rich-text h3, .rich-text h4, .rich-text h5 {
  line-height: 1.4;
  font-weight: bold;
}
.rich-text h2 {
  font-size: 22px;
}
.rich-text h3 {
  font-size: 19px;
  letter-spacing: 0;
}
.rich-text h4 {
  font-size: 16px;
}
.rich-text h5 {
  font-size: 14px;
}
.rich-text h3, .rich-text h4, .rich-text h5 {
  margin-top: 10px;
  margin-bottom: 10px;
}
.rich-text h2:first-child,
.rich-text h3:first-child,
.rich-text h4:first-child,
.rich-text h5:first-child,
.rich-text ol:first-child,
.rich-text ul:first-child,
.rich-text p:first-child {
  margin-top: 0;
}
.rich-text hr {
  border-bottom: 1px solid #ccc;
  border-top: 0;
  border-left: 0;
}
.rich-text .richtext-image {
  margin-top: 3px;
  margin-bottom: 1em;
  width: 100%;
  height: auto;
}
.rich-text .richtext-image.small {
  max-width: 45%;
}
.rich-text .richtext-image.left {
  float: left;
  margin-right: 16px;
}
.rich-text .richtext-image.right {
  float: right;
  margin-left: 16px;
}
@media (min-width: 768px) {
  .rich-text .richtext-image {
    width: auto;
    margin-bottom: 0;
  }
}
.rich-text .richtext-image img {
  width: 100%;
}
.rich-text .richtext-image figcaption {
  display: block;
  width: 100%;
  text-align: left;
  margin-top: 16px;
  margin-bottom: 16px;
}
.rich-text table td, .rich-text table th {
  padding: 10px;
}

#djDebug {
  display: none !important;
}

.element-invisible {
  position: absolute !important;
  clip: rect(1px, 1px, 1px, 1px);
  overflow: hidden;
  height: 1px;
}

.element-invisible.element-focusable:active,
.element-invisible.element-focusable:focus {
  position: static !important;
  clip: auto;
  overflow: visible;
  height: auto;
}

.rich-text img {
  max-width: 100%;
  height: auto;
}

.responsive-object {
  padding-bottom: 0 !important;
  text-align: center;
}

.responsive-object iframe,
.responsive-object object,
.responsive-object embed {
  max-width: 100%;
  max-height: 100%;
}

.paginator {
  margin: 1em 0;
}

.content-404 form input[type=text] {
  width: 200px;
}

.footer {
  z-index: 500;
  background-color: #696b73;
}
.footer__content-wrapper {
  padding: 10px;
  position: relative;
  line-height: 1.4;
  font-size: 12px;
  font-family: VaudMedium, sans-serif;
  color: #EEE;
}
.footer__link, .footer__link:visited, .footer__link:active, .footer__link:hover, .footer__link:focus {
  color: #ff5c05;
}
.footer__login-status {
  position: absolute;
  bottom: 15px;
  right: 10px;
  text-align: right;
}
.footer__login-status__logged-in-as {
  display: none;
}
.footer__login-status a {
  text-transform: uppercase;
  text-decoration: underline;
  color: #BBB;
}
.footer__phone, .footer__fax {
  padding-right: 10px;
}
.footer__email {
  display: block;
}
.footer__copyright a, .footer__copyright a:visited, .footer__copyright a:active, .footer__copyright a:hover, .footer__copyright a:focus {
  color: #EEE;
}

@media (max-width: 374px) {
  .footer {
    font-size: 10px;
  }
}
@media (min-width: 475px) {
  .footer__email {
    display: inline;
  }
}
@media (min-width: 500px) {
  .footer__login-status__logged-in-as {
    display: block;
  }
}
@media (min-width: 768px) {
  .footer {
    font-size: 13px;
    position: fixed;
    bottom: 0;
    width: 100%;
  }
  .footer__content-wrapper {
    height: 75px;
  }
  .footer__name {
    position: absolute;
    top: 0;
    left: 0;
    color: #ff5c05;
  }
  .footer__copyright {
    position: absolute;
    bottom: 0;
  }
}
body.bare-page .footer {
  display: none !important;
}

.content--social-media-footer {
  margin-bottom: 55px;
}

.footer--social-media-footer {
  height: 55px;
}
.footer--social-media-footer.open {
  height: 280px;
}

.social-media-footer {
  display: none;
}
@media (min-width: 768px) {
  .social-media-footer {
    display: block;
  }
}
.social-media-footer__top {
  height: 55px;
  position: relative;
}
.social-media-footer__connect-with {
  float: left;
  font-size: 35px;
  color: #EEE;
  letter-spacing: -1px;
  white-space: nowrap;
  text-transform: uppercase;
  padding-top: 5px;
}
.social-media-footer__social-media-links {
  padding: 0;
  margin: 0;
  float: left;
  padding-top: 15px;
  padding-left: 20px;
  list-style: none;
}
.social-media-footer__social-media-links li {
  display: inline;
  padding: 0 10px;
}
.social-media-footer__social-media-links li:first-child {
  padding-left: 0;
}
.social-media-footer__menu-button {
  position: absolute;
  top: 15px;
  right: 10px;
  width: 24px;
  cursor: pointer;
}
.social-media-footer__middle {
  background-color: #f3f3f3;
  height: 150px;
}
.social-media-footer__carousel-wrapper {
  font-size: 12px;
  line-height: 1.4;
  position: relative;
}

.social-media-carousel a, .social-media-carousel a:visited, .social-media-carousel a:active, .social-media-carousel a:hover, .social-media-carousel a:focus {
  color: #D14900;
}
.social-media-carousel__element {
  float: left;
  width: 250px;
  height: 110px;
  margin: 20px 0;
  border-right: 1px solid black;
  padding-top: 10px;
}
.social-media-carousel__element:last-child {
  border: 0;
}
.social-media-carousel__element__flickr-thumb {
  display: block;
  width: 75px;
  margin: 0 auto;
}
.social-media-carousel__element__flickr-text {
  text-align: center;
}
.social-media-carousel__element--twitter {
  padding-right: 25px;
  padding-left: 25px;
}
.social-media-carousel__element__youtube-wrapper {
  position: relative;
  margin: 0 auto;
}
.social-media-carousel__element__youtube-title {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: url("/static/caltech_sites/img/video-play-button.png");
}
.social-media-carousel__element__youtube-duration {
  position: absolute;
  right: 0;
  bottom: 0;
  margin: 4px;
  padding: 2px;
  background-color: #111111;
  opacity: 0.8;
  color: white;
  font-family: VaudMedium, sans-serif;
  font-size: 11px;
  border-radius: 2px;
}
.social-media-carousel__carousel-control {
  width: 30px;
  background: none;
  color: black;
  opacity: 1;
}
.social-media-carousel__carousel-control__icon {
  height: 40px;
  width: auto;
}
.social-media-carousel__carousel-control.carousel-control-prev {
  left: -30px;
}
.social-media-carousel__carousel-control.carousel-control-next {
  right: -30px;
}

/* These styles are for the Theme 6 PublicationsBlock NOT the publication listings on the people pages */
.caltech-authors-publications span {
  padding-right: 0.24em;
}
.caltech-authors-publications .unknown-year {
  display: none;
}
.caltech-authors-publications .year-heading {
  padding-bottom: 1.2rem;
}
.caltech-authors-publications .jump-list {
  overflow-wrap: break-word;
}
.caltech-authors-publications .jump-list-label {
  padding-right: 1rem;
  margin-right: 1rem;
  border-right: solid 0.12em black;
}
.caltech-authors-publications .jump-list-label:last-child {
  border-right: none;
}

.caltech-data-video__caption {
  margin-top: 1rem;
}
.caltech-data-video__caption p {
  margin-bottom: 0;
}

.campus-announcement__release-date {
  font-family: KievitSlabMedium, Times, serif;
  font-weight: bold;
  font-size: 12px;
  color: #616265;
  margin-bottom: 2em;
}
@media (min-width: 768px) {
  .campus-announcement__body {
    max-width: 700px;
  }
}

.campus-announcement-listing__title__rss-link {
  font-size: 0.875rem;
  font-weight: normal;
}
.campus-announcement-listing__title__rss-link img {
  vertical-align: baseline;
}
.campus-announcement-listing__body {
  padding: 0 10px;
  max-width: 700px;
}
@media (min-width: 1000px) {
  .campus-announcement-listing__body {
    padding: 0;
  }
}

.campus-announcement-entry {
  margin-bottom: 5px;
}

.campus-announcement-listing {
  position: relative;
  height: 100%;
  overflow: hidden;
  padding: 10px;
  background-position: center;
  background-size: cover;
}
.campus-announcement-listing--background-img {
  padding: 0;
}
.campus-announcement-listing--background-img .listing-block-content {
  position: absolute;
  top: 20px;
  left: 10px;
  width: calc(100% - 20px);
}
.campus-announcement-listing .listing-block-item {
  padding: 10px 0;
  border-bottom: 1px solid #000000;
  font-size: 15px;
}
.campus-announcement-listing .listing-block-item:last-child {
  border-bottom: none;
}
.campus-announcement-listing--light-theme {
  background-color: #616265;
}
.campus-announcement-listing--light-theme .listing-block-title {
  color: #ffffff;
}
.campus-announcement-listing--light-theme .listing-block-item {
  border-color: #ffffff;
  color: #ffffff;
}
.campus-announcement-listing--light-theme .listing-block-entry1 {
  color: #c8c8c8;
}
.campus-announcement-listing--light-theme .listing-block-entry2 {
  color: #ffffff;
}
.content .campus-announcement-listing--light-theme .listing-block-entry2, .content .campus-announcement-listing--light-theme .listing-block-entry2:visited, .content .campus-announcement-listing--light-theme .listing-block-entry2:active, .content .campus-announcement-listing--light-theme .listing-block-entry2:hover, .content .campus-announcement-listing--light-theme .listing-block-entry2:focus {
  color: #ffffff;
}
.content .campus-announcement-listing--light-theme .listing-block-archives-link, .content .campus-announcement-listing--light-theme .listing-block-archives-link:visited, .content .campus-announcement-listing--light-theme .listing-block-archives-link:active, .content .campus-announcement-listing--light-theme .listing-block-archives-link:hover, .content .campus-announcement-listing--light-theme .listing-block-archives-link:focus {
  color: #ffffff;
}
.campus-announcement-listing--dark-theme .listing-block-entry1 {
  color: #616265;
}
.campus-announcement-listing__title {
  font-family: KievitSlabMedium, Times, serif;
  font-size: 18px;
}
@media (min-width: 768px) {
  .campus-announcement-listing__title {
    font-size: 22px;
  }
}
.content .campus-announcement-listing__announcement__title, .content .campus-announcement-listing__announcement__title:visited, .content .campus-announcement-listing__announcement__title:active, .content .campus-announcement-listing__announcement__title:hover, .content .campus-announcement-listing__announcement__title:focus {
  color: #000000;
}
.campus-announcement-listing__announcement__title:hover {
  text-decoration: underline;
}
.campus-announcement-listing__archives-link {
  display: block;
  float: right;
  clear: both;
  padding: 10px;
  text-align: right;
  text-transform: lowercase;
}
.content .campus-announcement-listing__archives-link, .content .campus-announcement-listing__archives-link:visited, .content .campus-announcement-listing__archives-link:active, .content .campus-announcement-listing__archives-link:hover, .content .campus-announcement-listing__archives-link:focus {
  color: #7a303f;
}

.basic-page__title {
  margin: 0;
}
.basic-page__page-content {
  padding: 0 10px;
}
.basic-page__page-content .rich-text p {
  font-size: 14px;
  line-height: 24px;
  margin: 14px 0 14px 0;
}
@media (min-width: 768px) {
  .basic-page__sidebar {
    width: 350px;
  }
}
@media (min-width: 1000px) {
  .basic-page__page-content {
    padding: 0;
  }
}

.course-index-page {
  padding: 0 10px;
}
@media (min-width: 1000px) {
  .course-index-page {
    padding: 0;
  }
}
.course-index-page__toggle-filters {
  display: block;
}
@media (min-width: 768px) {
  .course-index-page__toggle-filters {
    display: none;
  }
}
.course-index-page__up-link + .course-index-page__toggle-filters {
  margin: 20px 0;
}
.course-index-page__title {
  margin-top: 0.67em;
  padding: 0;
  color: #333;
}
.course-index-page__title__edition {
  white-space: nowrap;
}
.course-index-page__main {
  padding-bottom: 40px;
}
@media (min-width: 768px) {
  .course-index-page__main {
    width: 70%;
    padding-right: 40px;
    float: left;
  }
}
.course-index-page__sidebar {
  margin-bottom: 20px;
  display: none;
}
@media (min-width: 768px) {
  .course-index-page__sidebar {
    display: block;
    font-size: 16px;
    width: 30%;
    float: right;
  }
}
.course-index-page__sidebar.js-displayed {
  display: block;
}
.course-index-page__sidebar__filter {
  font-size: 18px;
  font-weight: bold;
}
@media (min-width: 768px) {
  .course-index-page__sidebar__filter {
    margin-top: 40px;
  }
}

.course-filter-links {
  margin: 0;
  padding: 0;
  list-style: none;
}
.course-filter-links__item {
  padding-left: 5px;
  margin-bottom: 3px;
}
.course-filter-links__item--active a {
  background-color: #ddd;
}
.course-filter-links__item--active a, .course-filter-links__item--active a:visited, .course-filter-links__item--active a:active, .course-filter-links__item--active a:hover, .course-filter-links__item--active a:focus {
  color: #666;
}

@media (min-width: 768px) {
  .course-description {
    font-size: 16px;
  }
}
.course-description:not(:first-child) {
  margin-top: 20px;
}
.course-description--not-offered {
  color: #767775;
}
.course-description__label {
  font-weight: bold;
}
.course-description__title {
  font-weight: bold;
}
.course-description__units, .course-description__prerequisites {
  font-style: italic;
}
.course-description__terms {
  font-style: italic;
}

.catalog-disclaimer {
  margin-top: 3rem;
}
.catalog-disclaimer p {
  font-style: italic;
}

.person-index-page {
  display: flex;
  flex-wrap: wrap;
}
.person-index-page__back-link {
  order: 1;
  flex: 1 1 auto;
  width: 100%;
  padding: 0 10px;
}
@media (min-width: 768px) {
  .person-index-page__back-link {
    margin-bottom: 10px;
  }
}
@media (min-width: 1000px) {
  .person-index-page__back-link {
    padding: 0;
  }
}
.person-index-page__toggle-filters {
  order: 2;
  flex: 1 1 auto;
  width: 100%;
  padding: 0 10px;
  margin: 20px 0;
  color: #D14900;
}
@media (min-width: 768px) {
  .person-index-page__toggle-filters {
    display: none;
  }
}
.person-index-page__title {
  order: 4;
  flex: 1 1 auto;
  width: 100%;
}
@media (min-width: 768px) {
  .person-index-page__title {
    order: 2;
  }
}
.person-index-page .block-PersonListingBlock {
  order: 5;
  flex: 1 1 auto;
  width: 100%;
}
@media (min-width: 768px) {
  .person-index-page .block-PersonListingBlock {
    order: 3;
    flex: 1 1 auto;
    width: 75%;
    padding-left: 10px;
  }
}
@media (min-width: 1000px) {
  .person-index-page .block-PersonListingBlock {
    padding: 0;
  }
}
@media (min-width: 768px) {
  .person-index-page .person-listing--names-only {
    padding: 0 50px;
  }
}

.person-index-sidebar {
  order: 3;
  display: none;
  padding: 0 10px;
  margin-bottom: 40px;
}
.person-index-sidebar.js-displayed {
  display: block;
}
@media (min-width: 768px) {
  .person-index-sidebar {
    order: 4;
    padding-left: 25px;
    display: block;
    flex: 1 1 auto;
    width: 25%;
  }
}
.person-index-sidebar__category:nth-child(2) {
  margin-top: 40px;
}
.person-index-sidebar__category__title {
  font-size: 18px;
  font-weight: bold;
}
.person-index-sidebar__category__title:first-child {
  margin-top: 0;
}
.person-index-sidebar__category__name--heading {
  text-transform: uppercase;
  margin-top: 10px;
}
.person-index-sidebar__category__name--non-heading::before {
  content: "• ";
  color: #D14900;
}

.person-listing__block-title {
  margin-top: 0;
  font-family: KievitSlabMedium, Times, serif;
  font-size: 22px;
}
.person-listing__person-row {
  position: relative;
}
.person-listing__person-row:before, .person-listing__person-row:after {
  content: "";
  display: table;
}
.person-listing__person-row:after {
  clear: both;
}
.person-listing__person-row:nth-child(odd) {
  background-color: #f3f1f1;
}
.person-listing__person-row__wrapper-link .wrapper-expander {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  z-index: 100;
}
.person-listing__summary {
  padding: 10px;
  width: calc(100% - 75px);
  float: left;
  position: relative;
}
.person-listing__summary--widen-on-mobile {
  width: 100%;
}
@media (min-width: 500px) {
  .person-listing__summary {
    padding: 15px 30px 15px 50px;
    width: calc(100% - 180px);
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    max-height: 180px;
  }
}
@media (min-width: 500px) {
  .person-listing__summary__title {
    display: inline;
    font-size: 14px;
    font-weight: bold;
  }
  .person-listing__summary__title, .person-listing__summary__title:visited, .person-listing__summary__title:active, .person-listing__summary__title:hover, .person-listing__summary__title:focus {
    color: #000000;
  }
}
@media (min-width: 500px) and (min-width: 768px) {
  .person-listing__summary__title {
    font-size: 16px;
  }
}
.person-listing__summary__email {
  overflow-wrap: break-word;
}
@media (min-width: 500px) {
  .person-listing__summary__email {
    position: relative;
    z-index: 101;
    float: right;
  }
}
.person-listing__summary__faculty-title {
  flex: 1 1 auto;
  width: 100%;
  font-style: italic;
  font-weight: bold;
}
.person-listing__summary__faculty-title--disappear-on-mobile {
  display: none;
}
@media (min-width: 500px) {
  .person-listing__summary__faculty-title {
    display: block;
  }
}
@media (min-width: 768px) {
  .person-listing__summary__faculty-title {
    font-weight: normal;
  }
}
.person-listing__summary__research-summary, .person-listing__summary__category-two {
  display: none;
  flex: 1 1 auto;
  width: 100%;
  margin: 12px 0;
  font-size: 12px;
}
@media (min-width: 768px) {
  .person-listing__summary__research-summary, .person-listing__summary__category-two {
    display: block;
  }
}
.person-listing__headshot {
  float: left;
}
.person-listing__headshot--disappear-on-mobile {
  display: none;
}
@media (min-width: 500px) {
  .person-listing__headshot {
    display: block;
  }
}
.person-listing--names-only {
  padding: 10px 10px 10px 16px;
}
.person-listing--names-only.text-color-white {
  color: #ffffff;
}
.person-listing--names-only.text-color-white a, .person-listing--names-only.text-color-white a:visited, .person-listing--names-only.text-color-white a:active, .person-listing--names-only.text-color-white a:hover, .person-listing--names-only.text-color-white a:focus {
  color: #ffffff;
}
.person-listing--names-only.text-color-dkgray {
  color: #616265;
}
.person-listing--names-only.text-color-dkgray a, .person-listing--names-only.text-color-dkgray a:visited, .person-listing--names-only.text-color-dkgray a:active, .person-listing--names-only.text-color-dkgray a:hover, .person-listing--names-only.text-color-dkgray a:focus {
  color: #616265;
}
.person-listing--names-only.text-color-black {
  color: #000000;
}
.person-listing--names-only.text-color-black a, .person-listing--names-only.text-color-black a:visited, .person-listing--names-only.text-color-black a:active, .person-listing--names-only.text-color-black a:hover, .person-listing--names-only.text-color-black a:focus {
  color: #000000;
}
.person-listing--names-only__title:hover {
  text-decoration: underline;
}

.person-listing-gallery {
  display: flex;
  flex-wrap: wrap;
  flex-direction: row;
}
@media (min-width: 768px) {
  .person-listing-gallery--gutter-12px {
    margin: 0 -6px;
  }
  .person-listing-gallery--gutter-20px {
    margin: 0 -10px;
  }
  .person-listing-gallery--gutter-30px {
    margin: 0 -15px;
  }
  .person-listing-gallery--gutter-40px {
    margin: 0 -20px;
  }
}
@media (min-width: 500px) {
  .person-listing-gallery__item--gutter-12px {
    padding: 0 6px 12px 6px;
  }
  .person-listing-gallery__item--gutter-20px {
    padding: 0 10px 20px 10px;
  }
  .person-listing-gallery__item--gutter-30px {
    padding: 0 15px 30px 15px;
  }
  .person-listing-gallery__item--gutter-40px {
    padding: 0 20px 40px 20px;
  }
  .person-listing-gallery__item--col-2 {
    width: 16.6666%;
  }
  .person-listing-gallery__item--col-3 {
    width: 25%;
  }
  .person-listing-gallery__item--col-4 {
    width: 33.3333%;
  }
  .person-listing-gallery__item--col-6 {
    width: 50%;
  }
}
.person-listing-gallery__item__link {
  display: block;
}
.person-listing-gallery__item__info {
  font-size: 12px;
  padding: 10px;
}
@media (min-width: 1000px) {
  .person-listing-gallery__item__info {
    padding: 16px;
  }
}
.person-listing-gallery__item__title {
  font-weight: bold;
  font-size: 16px;
}
.person-listing-gallery__item__title a, .person-listing-gallery__item__title a:visited, .person-listing-gallery__item__title a:active, .person-listing-gallery__item__title a:hover, .person-listing-gallery__item__title a:focus {
  color: #000000;
}
.person-listing-gallery__item__title a:hover {
  text-decoration: underline;
}
.person-listing-gallery__item__email {
  padding-bottom: 5px;
  overflow-wrap: break-word;
}
.person-listing-gallery__item__faculty-title {
  padding-bottom: 5px;
}
.person-listing-gallery__item img {
  max-width: 100%;
  display: block;
}
@media (min-width: 1025px) {
  .person-listing-gallery--rollover .person-listing-gallery__item__wrapper {
    position: relative;
    overflow: hidden;
  }
  .person-listing-gallery--rollover .person-listing-gallery__item:hover .person-listing-gallery__item__info {
    top: 0;
  }
  .person-listing-gallery--rollover .person-listing-gallery__item__info {
    width: 100%;
    height: 100%;
    position: absolute;
    background-color: rgba(0, 0, 0, 0.65);
    color: #FFFFFF;
    top: 70%;
    transition: top 0.5s ease-in-out 0.5s;
    padding: 0 15px;
  }
  .person-listing-gallery--rollover .person-listing-gallery__item__title {
    position: relative;
    margin: 0;
    height: 30%;
    font-family: KievitSlabMedium, Times, serif;
    font-weight: normal;
    font-size: 16px;
  }
  .person-listing-gallery--rollover .person-listing-gallery__item__title__link {
    position: absolute;
    left: 0;
    bottom: 10px;
  }
  .person-listing-gallery--rollover .person-listing-gallery__item__title__link, .person-listing-gallery--rollover .person-listing-gallery__item__title__link:visited, .person-listing-gallery--rollover .person-listing-gallery__item__title__link:active, .person-listing-gallery--rollover .person-listing-gallery__item__title__link:hover, .person-listing-gallery--rollover .person-listing-gallery__item__title__link:focus {
    color: #ffffff;
  }
}

@media (min-width: 768px) {
  .person-page {
    margin-top: 50px;
  }
}
@media (min-width: 500px) {
  .person-page__title-wrapper {
    width: 65%;
    float: left;
    padding-right: 20px;
  }
}
@media (min-width: 768px) {
  .person-page__title-wrapper {
    padding-right: 100px;
  }
}
@media (min-width: 1000px) {
  .person-page__title-wrapper {
    padding-right: 200px;
  }
}
.person-page__title {
  margin-bottom: 30px;
}
.person-page__faculty-title {
  font-size: 16px;
  margin: 0 0 20px 0;
  padding: 0 10px;
  line-height: 1.2;
}
@media (min-width: 1000px) {
  .person-page__faculty-title {
    padding: 0;
  }
}
.person-page__sidebar {
  margin-bottom: 2em;
}
@media (min-width: 500px) {
  .person-page__sidebar {
    width: 35%;
    float: right;
  }
}
.person-page__sidebar__headshot {
  width: 100%;
  height: auto;
  display: block;
  margin-bottom: 25px;
}
.person-page__sidebar__admin-assistant-title {
  background-color: #e5e5e5;
  margin-top: 25px;
  padding: 5px;
  font-weight: bold;
}
.person-page__sidebar__admin-assistant-link {
  background-color: #f3f1f1;
  padding: 5px;
  border-top: 1px solid #ffffff;
}
.person-page__sidebar__links {
  margin: 30px 0;
}
.person-page__sidebar__links:before, .person-page__sidebar__links:after {
  content: "";
  display: table;
}
.person-page__sidebar__links:after {
  clear: both;
}
.person-page__sidebar__links__link {
  background-color: #e5e5e5;
  padding: 10px;
  text-align: center;
  text-transform: uppercase;
  font-weight: bold;
  font-size: 12px;
  margin-right: 10px;
  display: block;
  float: left;
}
.person-page__body {
  margin-bottom: 40px;
  padding: 0 10px;
}
@media (min-width: 500px) {
  .person-page__body {
    width: 65%;
    float: left;
    padding-right: 20px;
  }
}
@media (min-width: 768px) {
  .person-page__body {
    padding-right: 100px;
  }
}
@media (min-width: 1000px) {
  .person-page__body {
    padding-right: 200px;
  }
}
@media (min-width: 1000px) {
  .person-page__body {
    padding-left: 0;
  }
}
.person-page__body__faculty-bio {
  font-style: italic;
  margin-bottom: 20px;
}
.person-page__body__section-title {
  color: #000000;
  font-size: 14px;
  font-weight: bold;
  text-transform: uppercase;
  margin: 18px 0;
}
@media (min-width: 768px) {
  .person-page__body__section-title--large {
    font-size: 18px;
    font-weight: normal;
  }
}
.person-page__body__cv-link__image {
  vertical-align: sub;
}
.person-page__body__category-twos {
  margin-top: 40px;
}
.person-page__body__category-twos ul {
  list-style: none;
  padding: 0;
}
.person-page__body__courses .course-description {
  font-size: 14px;
}

.person-contact-info {
  padding: 0;
  width: 100%;
}
.person-contact-info__row {
  border-bottom: 1px solid white;
}
.person-contact-info__label {
  background-color: #e5e5e5;
  font-weight: bold;
  width: 90px;
  padding: 0 5px;
  height: 30px;
  vertical-align: middle;
}
.person-contact-info__datum {
  background-color: #f3f1f1;
  padding: 0 5px;
  height: 30px;
  vertical-align: middle;
}
.person-contact-info__datum--email {
  overflow-wrap: break-word;
}

.person-subpages {
  padding: 0 10px;
}
@media (min-width: 768px) {
  .person-subpages {
    padding: 0;
  }
}
.person-subpages__list {
  list-style: none;
  padding: 0;
}

.working-paper-listing__header {
  border-bottom: 2px solid #c8c8c8;
}
.working-paper-listing__heading a, .working-paper-listing__heading a:visited, .working-paper-listing__heading a:active, .working-paper-listing__heading a:hover, .working-paper-listing__heading a:focus {
  color: #000000;
}
.working-paper-listing__heading a.active-asc::after {
  content: url("/static/caltech_sites/img/arrow-asc.png");
  margin-left: 10px;
}
.working-paper-listing__heading a.active-desc::after {
  content: url("/static/caltech_sites/img/arrow-desc.png");
  margin-left: 10px;
}
.working-paper-listing__heading--paper-number {
  width: 11%;
}
.working-paper-listing__heading--paper-authors {
  width: 22%;
}
.working-paper-listing__datum {
  padding: 5px;
}
.working-paper-listing__paginator {
  text-align: center;
}
.working-paper-listing__back-link {
  padding-top: 25px;
}

.working-paper__label {
  font-weight: bold;
  width: 100px;
  display: inline-block;
  vertical-align: top;
}
.working-paper__authors__list {
  display: inline-block;
}
.working-paper__back-link {
  padding-top: 25px;
}

span.richtext-image,
form img.richtext-image {
  display: inline-block;
}
span.richtext-image.Left,
form img.richtext-image.Left {
  float: left;
  left: 0;
  margin: 0 30px 0 0;
}
span.richtext-image.Middle,
form img.richtext-image.Middle {
  margin: auto;
  display: table;
}
span.richtext-image.Right,
form img.richtext-image.Right {
  right: 0;
  float: right;
  margin: 0 0 30px 30px;
}
span.richtext-image.Small,
form img.richtext-image.Small {
  width: 22%;
}
span.richtext-image.Medium,
form img.richtext-image.Medium {
  width: 47%;
}
span.richtext-image.Large,
form img.richtext-image.Large {
  width: 72%;
}
span.richtext-image.fullwidth,
form img.richtext-image.fullwidth {
  width: 100%;
  float: left;
}
span.richtext-image .image-details,
form img.richtext-image .image-details {
  margin-top: 10px;
}
span.richtext-image .image-details .image-caption,
form img.richtext-image .image-details .image-caption {
  font-size: 12px;
}
span.richtext-image .image-details .image-credit,
form img.richtext-image .image-details .image-credit {
  font-size: 11px;
  font-style: italic;
}

.rich-text .responsive-object iframe {
  margin-bottom: 30px;
  margin-top: 30px;
}

.news-container:before, .news-container:after {
  content: "";
  display: table;
}
.news-container:after {
  clear: both;
}
.news-container__title--block {
  margin-top: 0;
  font-family: KievitSlabMedium, Times, serif;
  font-size: 22px;
}
.news-container__loading {
  text-align: center;
  margin: 1em 0;
}
@media (min-width: 768px) {
  .news-container__loading {
    width: 700px;
  }
}
.news-container__rss-link {
  font-size: 0.875rem;
  font-weight: normal;
  padding-left: 15px;
}
.news-container__rss-link img {
  vertical-align: baseline;
}

.news-teaser {
  font-size: 11px;
  display: block;
  color: inherit;
  height: 75px;
  line-height: 1.4;
  position: relative;
}
.news-teaser:before, .news-teaser:after {
  content: "";
  display: table;
}
.news-teaser:after {
  clear: both;
}
@media (min-width: 500px) {
  .news-teaser {
    font-size: 14px;
    height: 150px;
  }
}
@media (min-width: 1000px) {
  .news-teaser {
    width: 700px;
  }
  .news-teaser--headline {
    width: 100%;
    height: 300px;
  }
  .news-teaser--headline .news-teaser__left {
    padding-top: 30px;
    width: calc(100% - 300px);
  }
  .news-teaser--headline .news-teaser__title {
    font-size: 26px;
  }
}
.news-teaser:nth-child(odd) {
  background: #f3f1f1;
}
.news-teaser__wrapper-link .wrapper-expander {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  z-index: 100;
}
.news-teaser__left {
  float: left;
  width: calc(100% - 75px);
  padding: 10px;
  height: 100%;
  overflow: hidden;
}
@media (min-width: 500px) {
  .news-teaser__left {
    width: calc(100% - 150px);
    padding: 15px;
  }
}
@media (min-width: 768px) {
  .news-teaser__left {
    padding: 15px 30px 15px 30px;
  }
}
.news-teaser__publish-date {
  color: #666666;
}
@media (min-width: 500px) {
  .news-teaser__publish-date {
    font-size: 11px;
  }
}
.news-teaser__title {
  font-size: 1.4em;
  margin: 0;
}
@media (min-width: 500px) {
  .news-teaser__title {
    font-size: 16px;
    color: #000000;
  }
}
.news-teaser__writer {
  display: none;
  font-size: 12px;
}
@media (min-width: 500px) {
  .news-teaser__writer {
    display: block;
  }
}
.news-teaser__summary {
  display: none;
  padding-top: 15px;
}
@media (min-width: 500px) {
  .news-teaser__summary {
    display: block;
  }
}
.news-teaser__right {
  float: left;
  background: white;
}
.news-teaser__right img {
  height: 100%;
}

.title-and-body-news-container__title__rss-link {
  font-size: 0.875rem;
  font-weight: normal;
}
.title-and-body-news-container__title__rss-link img {
  vertical-align: baseline;
}
.title-and-body-news-container__listing {
  padding: 0 10px;
}
@media (min-width: 1000px) {
  .title-and-body-news-container__listing {
    width: 600px;
    padding: 0;
  }
}
.title-and-body-news-container__loading {
  text-align: center;
  margin: 1em 0;
}

.textual-news-listing-item__title {
  font-size: 20px;
  font-weight: bold;
}

@media (min-width: 768px) {
  .site-news-page {
    margin-top: 65px;
  }
}
.site-news-page__post-date {
  color: #76777b;
}
.site-news-page__title {
  padding: 0;
}
.site-news-page__subtitle {
  padding: 0;
}
.site-news-page__page-content {
  padding: 0 10px;
}
@media (min-width: 1000px) {
  .site-news-page__page-content {
    padding: 0;
  }
}
.site-news-page__page-content p:first-child {
  font-size: 17px;
}
.site-news-page__sidebar__tags {
  padding: 0 10px;
  margin-bottom: 15px;
}
@media (min-width: 1000px) {
  .site-news-page__sidebar__tags {
    padding: 0;
  }
}
.site-news-page__sidebar__tag-title {
  font-weight: bold;
}

.news-contact {
  margin-bottom: 2em;
}
.news-contact__label {
  vertical-align: top;
  margin-right: 5em;
  font-weight: bold;
}
.news-contact__info {
  display: inline-block;
}

.mixed-media-carousel .video-thumb {
  position: relative;
  height: 100%;
}
.mixed-media-carousel .video-thumb .video-thumb-overlay {
  position: absolute;
  top: 0;
  width: 100%;
  height: 100%;
  background: url(/static/core/img/video-play.png) no-repeat center;
  background-size: 20px 20px;
}
.mixed-media-carousel .video-thumb img {
  height: 100%;
}
.mixed-media-carousel__carousel-indicators {
  width: 100%;
  margin: 15px 0;
  position: static;
}
.mixed-media-carousel__carousel-indicators .mixed-media-carousel__carousel-indicators__item {
  width: 75px;
  height: 75px;
  margin-left: 5px;
  margin-right: 5px;
}
.mixed-media-carousel__carousel-indicators .mixed-media-carousel__carousel-indicators__item::before, .mixed-media-carousel__carousel-indicators .mixed-media-carousel__carousel-indicators__item::after {
  display: none;
}
.mixed-media-carousel img {
  max-width: 100%;
}

.news-listing-block:before, .news-listing-block:after {
  content: "";
  display: table;
}
.news-listing-block:after {
  clear: both;
}
@media (min-width: 1000px) {
  .news-listing-block .news-teaser {
    width: 100%;
  }
}
.news-listing-block__archives-link {
  display: block;
  float: right;
  clear: both;
  padding: 10px;
  text-align: right;
  text-transform: lowercase;
  text-transform: none;
}
.content .news-listing-block__archives-link, .content .news-listing-block__archives-link:visited, .content .news-listing-block__archives-link:active, .content .news-listing-block__archives-link:hover, .content .news-listing-block__archives-link:focus {
  color: #7a303f;
}

.news-blog-traditional__title {
  margin-top: 0;
  font-family: KievitSlabMedium, Times, serif;
  font-size: 22px;
}
.news-blog-traditional__rss-link-wrapper:before, .news-blog-traditional__rss-link-wrapper:after {
  content: "";
  display: table;
}
.news-blog-traditional__rss-link-wrapper:after {
  clear: both;
}
.news-blog-traditional__rss-link {
  float: right;
}
.content .news-blog-traditional__rss-link, .content .news-blog-traditional__rss-link:visited, .content .news-blog-traditional__rss-link:active, .content .news-blog-traditional__rss-link:hover, .content .news-blog-traditional__rss-link:focus {
  color: #000000;
}
.news-blog-traditional__article {
  border-bottom: 1px solid #e5e5e5;
  margin-bottom: 30px;
}
.news-blog-traditional__article:last-of-type {
  margin: 0;
  border: 0;
}
.news-blog-traditional__article__title {
  font-weight: bold;
  margin-top: 20px;
}
.content .news-blog-traditional__article__title__link, .content .news-blog-traditional__article__title__link:visited, .content .news-blog-traditional__article__title__link:active, .content .news-blog-traditional__article__title__link:hover, .content .news-blog-traditional__article__title__link:focus {
  color: #000000;
}
@media (min-width: 768px) {
  .news-blog-traditional__article__writer {
    display: inline;
  }
}
.news-blog-traditional__article__writer-separator {
  display: none;
}
@media (min-width: 768px) {
  .news-blog-traditional__article__writer-separator {
    display: inline;
    color: #666666;
  }
}
.news-blog-traditional__article__publish-date {
  color: #666666;
}
.news-blog-traditional__article__content {
  margin-top: 10px;
  margin-bottom: 30px;
}
.news-blog-traditional__article__content:before, .news-blog-traditional__article__content:after {
  content: "";
  display: table;
}
.news-blog-traditional__article__content:after {
  clear: both;
}
.news-blog-traditional__article__teaser-image {
  width: 100%;
}
@media (min-width: 768px) {
  .news-blog-traditional__article__teaser-image {
    width: 250px;
    float: left;
  }
}
.news-blog-traditional__article__snippet {
  padding-top: 15px;
}
@media (min-width: 768px) {
  .news-blog-traditional__article__snippet {
    width: calc(100% - 250px);
    float: left;
    padding: 0 10px 0 15px;
  }
}

.news-slider__placeholder-wrapper {
  background-color: #616265;
  text-align: center;
}
.news-slider__placeholder-image {
  display: inline;
}

.simple-news-listing {
  overflow: hidden;
}
.simple-news-listing--bg-color {
  padding: 10px;
}
.simple-news-listing__content-wrapper:before, .simple-news-listing__content-wrapper:after {
  content: "";
  display: table;
}
.simple-news-listing__content-wrapper:after {
  clear: both;
}
.simple-news-listing__title {
  margin-top: 0;
  font-family: KievitSlabMedium, Times, serif;
  font-size: 22px;
}
.simple-news-listing__rss-link-wrapper:before, .simple-news-listing__rss-link-wrapper:after {
  content: "";
  display: table;
}
.simple-news-listing__rss-link-wrapper:after {
  clear: both;
}
.simple-news-listing__article--titles-only {
  padding: 10px 0;
  border-bottom: 1px solid #333333;
}
.simple-news-listing__article__publish-date {
  color: #616265;
}
.simple-news-listing__article__title--date-and-titles-only {
  font-size: 18px;
}
.simple-news-listing__article__title--titles-only {
  font-size: 15px;
}
.content .simple-news-listing__article__title__link, .content .simple-news-listing__article__title__link:visited, .content .simple-news-listing__article__title__link:active, .content .simple-news-listing__article__title__link:hover, .content .simple-news-listing__article__title__link:focus {
  color: #333333;
}
.content .simple-news-listing__article__title__link:hover {
  text-decoration: underline;
}
.simple-news-listing__rss-link {
  float: right;
}
.content .simple-news-listing__rss-link, .content .simple-news-listing__rss-link:visited, .content .simple-news-listing__rss-link:active, .content .simple-news-listing__rss-link:hover, .content .simple-news-listing__rss-link:focus {
  color: #333333;
}
.simple-news-listing__archives-link {
  padding: 10px;
  float: right;
}
.content .simple-news-listing__archives-link, .content .simple-news-listing__archives-link:visited, .content .simple-news-listing__archives-link:active, .content .simple-news-listing__archives-link:hover, .content .simple-news-listing__archives-link:focus {
  color: #7a303f;
}
.simple-news-listing--text-color-white .simple-news-listing__title {
  color: #ffffff;
}
.simple-news-listing--text-color-white .simple-news-listing__rss-link, .simple-news-listing--text-color-white .simple-news-listing__rss-link:visited, .simple-news-listing--text-color-white .simple-news-listing__rss-link:active, .simple-news-listing--text-color-white .simple-news-listing__rss-link:hover, .simple-news-listing--text-color-white .simple-news-listing__rss-link:focus {
  color: #ffffff;
}
.simple-news-listing--text-color-white .simple-news-listing__article {
  border-color: #ffffff;
}
.simple-news-listing--text-color-white .simple-news-listing__article__publish-date {
  color: #e5e5e5;
}
.simple-news-listing--text-color-white .simple-news-listing__article__title__link, .simple-news-listing--text-color-white .simple-news-listing__article__title__link:visited, .simple-news-listing--text-color-white .simple-news-listing__article__title__link:active, .simple-news-listing--text-color-white .simple-news-listing__article__title__link:hover, .simple-news-listing--text-color-white .simple-news-listing__article__title__link:focus {
  color: #ffffff;
}
.simple-news-listing--text-color-white .simple-news-listing__archives-link, .simple-news-listing--text-color-white .simple-news-listing__archives-link:visited, .simple-news-listing--text-color-white .simple-news-listing__archives-link:active, .simple-news-listing--text-color-white .simple-news-listing__archives-link:hover, .simple-news-listing--text-color-white .simple-news-listing__archives-link:focus {
  color: #ffffff;
}
.simple-news-listing--text-color-black .simple-news-listing__title {
  color: #000000;
}
.simple-news-listing--text-color-black .simple-news-listing__rss-link, .simple-news-listing--text-color-black .simple-news-listing__rss-link:visited, .simple-news-listing--text-color-black .simple-news-listing__rss-link:active, .simple-news-listing--text-color-black .simple-news-listing__rss-link:hover, .simple-news-listing--text-color-black .simple-news-listing__rss-link:focus {
  color: #000000;
}
.simple-news-listing--text-color-black .simple-news-listing__article {
  border-color: #000000;
}
.simple-news-listing--text-color-black .simple-news-listing__article__publish-date {
  color: #616265;
}
.simple-news-listing--text-color-black .simple-news-listing__article__title__link, .simple-news-listing--text-color-black .simple-news-listing__article__title__link:visited, .simple-news-listing--text-color-black .simple-news-listing__article__title__link:active, .simple-news-listing--text-color-black .simple-news-listing__article__title__link:hover, .simple-news-listing--text-color-black .simple-news-listing__article__title__link:focus {
  color: #000000;
}
.simple-news-listing--text-color-black .simple-news-listing__archives-link, .simple-news-listing--text-color-black .simple-news-listing__archives-link:visited, .simple-news-listing--text-color-black .simple-news-listing__archives-link:active, .simple-news-listing--text-color-black .simple-news-listing__archives-link:hover, .simple-news-listing--text-color-black .simple-news-listing__archives-link:focus {
  color: #000000;
}
.simple-news-listing--text-color-dkgray .simple-news-listing__title {
  color: #616265;
}
.simple-news-listing--text-color-dkgray .simple-news-listing__rss-link, .simple-news-listing--text-color-dkgray .simple-news-listing__rss-link:visited, .simple-news-listing--text-color-dkgray .simple-news-listing__rss-link:active, .simple-news-listing--text-color-dkgray .simple-news-listing__rss-link:hover, .simple-news-listing--text-color-dkgray .simple-news-listing__rss-link:focus {
  color: #616265;
}
.simple-news-listing--text-color-dkgray .simple-news-listing__article {
  border-color: #616265;
}
.simple-news-listing--text-color-dkgray .simple-news-listing__article__publish-date {
  color: #c8c8c8;
}
.simple-news-listing--text-color-dkgray .simple-news-listing__article__title__link, .simple-news-listing--text-color-dkgray .simple-news-listing__article__title__link:visited, .simple-news-listing--text-color-dkgray .simple-news-listing__article__title__link:active, .simple-news-listing--text-color-dkgray .simple-news-listing__article__title__link:hover, .simple-news-listing--text-color-dkgray .simple-news-listing__article__title__link:focus {
  color: #616265;
}
.simple-news-listing--text-color-dkgray .simple-news-listing__archives-link, .simple-news-listing--text-color-dkgray .simple-news-listing__archives-link:visited, .simple-news-listing--text-color-dkgray .simple-news-listing__archives-link:active, .simple-news-listing--text-color-dkgray .simple-news-listing__archives-link:hover, .simple-news-listing--text-color-dkgray .simple-news-listing__archives-link:focus {
  color: #616265;
}

/*************** Image Caption ***************/
.image-details {
  margin-top: 10px;
  display: block;
  color: #333;
  padding-left: 10px;
  padding-right: 10px;
}
@media (min-width: 768px) {
  .image-details {
    padding: 0;
  }
}
.image-details__caption {
  font-size: 12px;
  display: block;
}
.image-details__credit {
  font-size: 11px;
  font-style: italic;
  display: block;
}

.simple-calendar {
  padding: 0 10px;
}
@media (min-width: 1000px) {
  .simple-calendar {
    padding: 0;
  }
}
.simple-calendar__title__page-num {
  font-size: 0.5em;
}
@media (min-width: 1000px) {
  .simple-calendar__table {
    width: 70%;
  }
}
.simple-calendar__table__row:nth-child(odd) {
  background-color: #f3f1f1;
}
.simple-calendar__table__datum {
  padding: 10px 0;
}
@media (min-width: 1000px) {
  .simple-calendar__table__datum {
    padding: 20px 0;
  }
}
.simple-calendar__table__time {
  width: 100px;
  padding-left: 10px;
  padding-right: 20px;
}
@media (min-width: 1000px) {
  .simple-calendar__table__time {
    padding-left: 20px;
  }
}
.simple-calendar__table__date {
  white-space: nowrap;
}
@media (min-width: 768px) {
  .simple-calendar__table__times {
    white-space: nowrap;
  }
}
.simple-calendar__table__event-location {
  font-style: italic;
  color: #777766;
}
.simple-calendar__table__seminar-title {
  font-family: VaudMedium, sans-serif;
  padding: 5px 0;
}
.simple-calendar__table__speakers {
  list-style: none;
  padding: 0;
  margin: 0;
  color: #777766;
}
.simple-calendar__table__ical-feed {
  padding-right: 10px;
  padding-left: 10px;
}
@media (min-width: 1000px) {
  .simple-calendar__table__ical-feed {
    padding-right: 20px;
  }
}

.simple-calendar-body .secondary-menu {
  display: block;
  margin: 0 10px 30px;
}
@media (min-width: 768px) {
  .simple-calendar-body .secondary-menu {
    margin-bottom: 0;
  }
}
@media (min-width: 1000px) {
  .simple-calendar-body .secondary-menu {
    margin: 0;
  }
}
.simple-calendar-body .secondary-menu__row {
  padding: 0 10px;
}
@media (min-width: 768px) {
  .simple-calendar-body .secondary-menu__row {
    padding: 0 20px;
  }
}

.master-calendar {
  padding: 0 10px;
  display: flex;
  flex-wrap: wrap;
}
@media (min-width: 1000px) {
  .master-calendar {
    padding: 0;
  }
}
.master-calendar__title-wrapper:before, .master-calendar__title-wrapper:after {
  content: "";
  display: table;
}
.master-calendar__title-wrapper:after {
  clear: both;
}
.master-calendar__filter-categories {
  margin-top: -10px;
}
@media (min-width: 768px) {
  .master-calendar__filter-categories {
    font-size: 18px;
  }
}
.master-calendar__toggle-filters {
  order: 1;
  flex: 1 1 auto;
  width: 100%;
  margin: 20px 0;
  color: #D14900;
}
@media (min-width: 768px) {
  .master-calendar__toggle-filters {
    display: none;
  }
}
.master-calendar__sidebar {
  order: 2;
  flex: 1 1 auto;
  width: 100%;
  margin: 20px 0;
  display: none;
  padding-bottom: 40px;
}
.master-calendar__sidebar.js-displayed {
  display: block;
}
@media (min-width: 768px) {
  .master-calendar__sidebar {
    order: 3;
    flex: 1 1 auto;
    width: 30%;
    display: block;
    padding-left: 20px;
    margin: 0 -1px;
  }
}
.master-calendar__sidebar__listing-links {
  display: table;
  width: 100%;
  margin-bottom: 10px;
}
.master-calendar__sidebar__listing-links__link {
  font-size: 12px;
  text-transform: uppercase;
  display: table-cell;
  text-align: center;
  width: 25%;
  line-height: 1.4;
}
.master-calendar__sidebar__listing-links__link:first-child {
  text-align: left;
}
.master-calendar__sidebar__listing-links__link:nth-child(3) {
  width: 30%;
}
.master-calendar__sidebar__listing-links__link:last-child {
  text-align: right;
  width: 20%;
}
.master-calendar__sidebar__search-form {
  margin-bottom: 30px;
}
.master-calendar__sidebar__search-field {
  height: 30px;
  width: 100%;
  border: 2px solid #cfcfcf;
  border-radius: 0;
  padding-left: 5px;
}
.master-calendar__sidebar__search-field__label {
  margin: 0;
  width: 70%;
}
.master-calendar__sidebar__submit {
  vertical-align: bottom;
  border: solid 0 #000000;
  width: 30px;
  height: 30px;
  border-radius: 0;
}
.master-calendar__sidebar__radio-label {
  padding-right: 5px;
  font-weight: normal;
}
.master-calendar__sidebar__radio {
  margin: 5px;
  vertical-align: sub;
}
.master-calendar__sidebar__search-radios {
  border: 0;
  padding: 0;
  margin: 0;
}
.master-calendar__sidebar__search-radios__legend {
  margin: 0;
}
.master-calendar__main {
  order: 3;
  flex: 1 1 auto;
  width: 100%;
}
@media (min-width: 768px) {
  .master-calendar__main {
    order: 2;
    flex: 1 1 auto;
    width: 70%;
    padding-right: 20px;
  }
}
.master-calendar__title-wrapper {
  margin-bottom: 20px;
  position: relative;
}
.master-calendar__title {
  font-weight: normal;
  text-align: center;
  font-size: 22px;
}
.master-calendar__title--filter-title {
  text-align: left;
}
@media (min-width: 768px) {
  .master-calendar__title {
    font-size: 28px;
  }
}
.master-calendar__nav {
  text-transform: uppercase;
  font-weight: bold;
}
.master-calendar__nav--prev {
  float: left;
}
.master-calendar__nav--next {
  float: right;
}
@media (min-width: 1000px) {
  .master-calendar__nav {
    float: none;
    position: absolute;
    top: 30px;
  }
  .master-calendar__nav--prev {
    left: 0;
  }
  .master-calendar__nav--next {
    right: 0;
  }
}
.master-calendar__table {
  margin-bottom: 30px;
}
.master-calendar__table__header {
  text-transform: uppercase;
  font-weight: normal;
  padding-bottom: 15px;
}
.master-calendar__table__time {
  width: 100px;
  padding-right: 20px;
  padding-left: 10px;
}
@media (min-width: 500px) {
  .master-calendar__table__time {
    width: 150px;
  }
}
@media (min-width: 1000px) {
  .master-calendar__table__time {
    width: 175px;
  }
}
.master-calendar__table__day {
  display: block;
}
@media (min-width: 500px) {
  .master-calendar__table__day {
    display: inline;
  }
}
.master-calendar__table__event-info {
  padding-bottom: 10px;
}
.master-calendar__table__event-location {
  font-style: italic;
  color: #777766;
}
.master-calendar__table__speakers {
  list-style: none;
  padding: 0;
  margin: 0;
  color: #777766;
}
.master-calendar__table__ical-feed {
  box-sizing: content-box;
  width: 40px;
  text-align: right;
}

.mini-calendar {
  margin-bottom: 30px;
}
.mini-calendar__pager {
  margin-bottom: 10px;
  display: flex;
  line-height: 25px;
}
.mini-calendar__pager:before, .mini-calendar__pager:after {
  content: "";
  display: table;
}
.mini-calendar__pager:after {
  clear: both;
}
.mini-calendar__pager a.mini-calendar__nav, .mini-calendar__pager a.mini-calendar__nav:visited, .mini-calendar__pager a.mini-calendar__nav:active, .mini-calendar__pager a.mini-calendar__nav:hover, .mini-calendar__pager a.mini-calendar__nav:focus {
  color: #000000;
}
.mini-calendar__nav {
  flex: 25px;
  height: 25px;
  background: #c8c8c8;
  text-align: center;
  font-weight: bold;
}
.mini-calendar__nav--prev {
  border-radius: 5px 0 0 5px;
}
.mini-calendar__nav--next {
  border-radius: 0 5px 5px 0;
}
.mini-calendar__current {
  flex: 1 1 auto;
  width: calc(100% - 50px);
  font-size: 16px;
  text-align: center;
  text-transform: uppercase;
}
.mini-calendar__table__datum {
  text-align: right;
  line-height: 20px;
}
.mini-calendar__table__datum:first-child {
  width: 20px;
  text-align: left;
}
.mini-calendar__table a.mini-calendar__table__day-link {
  text-decoration: underline;
}
.mini-calendar__table__week-link {
  font-size: 11px;
}

.events-filter__title {
  font-size: 14px;
  text-transform: uppercase;
}
.events-filter .fancytree-container {
  font-size: 12px;
  white-space: normal;
  border: none;
}
.events-filter .fancytree-node {
  padding-bottom: 5px;
}
.events-filter__clear-selection {
  margin-bottom: 5px;
}

body.caltech-sites .events-filter .fancytree-expander {
  display: none;
}
body.caltech-sites .events-filter .fancytree-title {
  width: calc(100% - 19px - 3px);
}

.event-listing {
  position: relative;
  height: 100%;
  overflow: hidden;
  padding: 10px;
  background-position: center;
  background-size: cover;
  padding: 0;
}
.event-listing--background-img {
  padding: 0;
}
.event-listing--background-img .listing-block-content {
  position: absolute;
  top: 20px;
  left: 10px;
  width: calc(100% - 20px);
}
.event-listing .listing-block-item {
  padding: 10px 0;
  border-bottom: 1px solid #000000;
  font-size: 15px;
}
.event-listing .listing-block-item:last-child {
  border-bottom: none;
}
.event-listing--light-theme {
  background-color: #616265;
}
.event-listing--light-theme .listing-block-title {
  color: #ffffff;
}
.event-listing--light-theme .listing-block-item {
  border-color: #ffffff;
  color: #ffffff;
}
.event-listing--light-theme .listing-block-entry1 {
  color: #c8c8c8;
}
.event-listing--light-theme .listing-block-entry2 {
  color: #ffffff;
}
.content .event-listing--light-theme .listing-block-entry2, .content .event-listing--light-theme .listing-block-entry2:visited, .content .event-listing--light-theme .listing-block-entry2:active, .content .event-listing--light-theme .listing-block-entry2:hover, .content .event-listing--light-theme .listing-block-entry2:focus {
  color: #ffffff;
}
.content .event-listing--light-theme .listing-block-archives-link, .content .event-listing--light-theme .listing-block-archives-link:visited, .content .event-listing--light-theme .listing-block-archives-link:active, .content .event-listing--light-theme .listing-block-archives-link:hover, .content .event-listing--light-theme .listing-block-archives-link:focus {
  color: #ffffff;
}
.event-listing--dark-theme .listing-block-entry1 {
  color: #616265;
}
.event-listing__title {
  font-family: KievitSlabMedium, Times, serif;
  font-size: 18px;
}
@media (min-width: 768px) {
  .event-listing__title {
    font-size: 22px;
  }
}
.event-listing__event__date {
  text-transform: uppercase;
  color: #7a303f;
  font-family: KievitSlabMedium, Times, serif;
  padding-right: 10px;
}
.content .event-listing__event__title, .content .event-listing__event__title:visited, .content .event-listing__event__title:active, .content .event-listing__event__title:hover, .content .event-listing__event__title:focus {
  color: #000000;
}
.event-listing__event__title:hover {
  text-decoration: underline;
}
.event-listing__event__lecture-series {
  margin-top: 1em;
}
.event-listing__separator {
  font-style: normal;
}
.event-listing__separator:last-of-type {
  display: none;
}
.event-listing__archives-link {
  display: block;
  float: right;
  clear: both;
  padding: 10px;
  text-align: right;
  text-transform: lowercase;
  text-transform: none;
}
.content .event-listing__archives-link, .content .event-listing__archives-link:visited, .content .event-listing__archives-link:active, .content .event-listing__archives-link:hover, .content .event-listing__archives-link:focus {
  color: #7a303f;
}

.event-listing--division-style .event-listing__content-wrapper {
  top: 0;
  left: 0;
  width: 100%;
}
.event-listing--division-style .event-listing__title-banner {
  position: relative;
  background-color: rgba(0, 0, 0, 0.3);
  z-index: 5;
  height: 42px;
}
.event-listing--division-style .event-listing__title {
  position: absolute;
  margin: 10px 0 10px 15px;
  color: #ffffff;
  font-family: Vaud, sans-serif;
  font-weight: normal;
  font-size: 1.17em;
  text-transform: uppercase;
}
.event-listing--division-style .event-listing__title::after {
  content: ":";
}
@media (min-width: 1000px) {
  .event-listing--division-style .event-listing__title {
    margin-left: 35px;
  }
}
.event-listing--division-style .event-listing__event {
  border-bottom: none;
  padding: 0;
  margin: 10px 15px 20px 15px;
  font-size: 14px;
}
@media (min-width: 1000px) {
  .event-listing--division-style .event-listing__event {
    margin: 10px 35px 20px 35px;
  }
}
.event-listing--division-style .event-listing__event__date {
  font-family: Vaud, sans-serif;
  font-weight: bold;
  padding-right: 0;
  color: #ffffff;
}
.event-listing--division-style .event-listing__event__location {
  color: #ffffff;
}
.event-listing--division-style .event-listing__event__title {
  font-weight: bold;
  margin-bottom: 10px;
  display: block;
}
.content .event-listing--division-style .event-listing__event__title, .content .event-listing--division-style .event-listing__event__title:visited, .content .event-listing--division-style .event-listing__event__title:active, .content .event-listing--division-style .event-listing__event__title:hover, .content .event-listing--division-style .event-listing__event__title:focus {
  color: #ff6e1e;
}
.event-listing--division-style .event-listing__event__lecture-series {
  margin: 10px 0;
  font-style: italic;
}
.event-listing--division-style .event-listing__event__speakers {
  color: #ffffff;
}
.event-listing--division-style .event-listing__archives-link {
  position: absolute;
  bottom: 15px;
  right: 15px;
  padding: 0;
  text-transform: none;
  font-size: 16px;
  font-weight: bold;
}
.event-listing--division-style .event-listing__archives-link:hover, .event-listing--division-style .event-listing__archives-link:active, .event-listing--division-style .event-listing__archives-link:focus {
  text-decoration: none;
}
.event-listing--division-style .event-listing__archives-link .icon {
  color: #D14900;
}
.event-listing--division-style .event-listing__archives-link .icon:before {
  font-size: 24px;
  font-weight: bold;
  margin: 0;
  vertical-align: top;
}
.event-listing--division-style.event-listing--dark-theme .event-listing__event__speakers, .event-listing--division-style.event-listing--dark-theme .event-listing__event__lecture-series {
  color: #000000;
}

.seminar-speaker__separator {
  font-style: normal;
}
.seminar-speaker__separator:last-of-type {
  display: none;
}

.event {
  padding: 0 10px;
}
@media (min-width: 1000px) {
  .event {
    padding: 0;
  }
}
.event__day {
  font-size: 16px;
  color: #000;
}
.event__times {
  font-weight: bold;
  color: #616265;
}
.event__title {
  margin: 0.67em 0;
  padding: 0;
}
.event__lecture_series {
  margin-top: 1.5em;
}
.event__seminar-title {
  font-size: 18px;
  margin-top: 1em;
}
.event .seminar-speaker {
  font-weight: bold;
  margin-top: 1.5em;
}
.event .seminar-speaker__bio {
  margin-top: 1.5em;
}
.event .seminar-speaker__separator {
  font-weight: bold;
}
.event__description {
  margin-top: 1.5em;
}
.event__sponsors {
  margin-top: 25px;
}
@media (min-width: 500px) {
  .event__sponsors {
    display: table;
  }
}
.event__sponsors__label {
  font-weight: bold;
  padding-right: 10px;
}
@media (min-width: 500px) {
  .event__sponsors__label {
    display: table-cell;
    vertical-align: top;
  }
}
.event__sponsors__list {
  padding-left: 25px;
}
@media (min-width: 500px) {
  .event__sponsors__list {
    display: inline-block;
    list-style: none;
    padding: 0;
    margin: 0;
  }
}
.event__contact {
  margin-top: 1.5em;
}
.event__fee {
  margin-top: 1.5em;
}
.event .ical-feed-link {
  margin-top: 20px;
}

.ical-feed-link {
  font-size: 12px;
  margin-bottom: 30px;
}

#search-results {
  margin-top: 2em;
}
#search-results mark {
  color: inherit;
  padding: 0;
  background-color: transparent;
  font-weight: bold;
}
#search-results h4 {
  margin-bottom: 0;
}
#search-results .search-result {
  margin-bottom: 1em;
}

.content .hero-image h1, .content .hero-image h2, .content .hero-image h3, .content .hero-image h4, .content .hero-image h5, .content .hero-image h6 {
  font-family: KievitSlabMedium, Times, serif;
}
.content .image-panel-listing__body h4 {
  font-family: KievitSlabMedium, Times, serif;
}
.content .image-panel-rollover__title {
  font-family: KievitSlabMedium, Times, serif;
}
.content .related-links h2,
.content .menu-listing h2 {
  font-family: KievitSlabRegular, Times, serif;
}
.content .section-header {
  font-family: KievitSlabRegular, Times, serif;
}
.content .video-block__title {
  font-family: KievitSlabRegular, Times, serif;
}
.content .block-header {
  font-family: VaudMedium, sans-serif;
}
.content .image-panel-link__title {
  font-family: VaudMedium, sans-serif;
}
.content .callout {
  font-family: VaudMedium, sans-serif;
}
.content .hero-image.bare-sans-serif, .content .hero-image.white-translucent-sans-serif {
  font-family: Vaud, sans-serif;
}
.content .hero-image.bare-sans-serif h1, .content .hero-image.white-translucent-sans-serif h1 {
  font-family: VaudMedium, sans-serif;
}
.content .hero-image.bare-sans-serif h2, .content .hero-image.bare-sans-serif h3, .content .hero-image.bare-sans-serif h4, .content .hero-image.bare-sans-serif h5, .content .hero-image.bare-sans-serif h6, .content .hero-image.white-translucent-sans-serif h2, .content .hero-image.white-translucent-sans-serif h3, .content .hero-image.white-translucent-sans-serif h4, .content .hero-image.white-translucent-sans-serif h5, .content .hero-image.white-translucent-sans-serif h6 {
  font-family: Vaud, sans-serif;
}
.content .image-carousel__banner__header {
  font-family: Vaud, sans-serif;
}
.content .image-carousel__item__text {
  font-family: VaudMedium, sans-serif;
}
.content .block-ImagePanelBlock h1 {
  font-family: VaudMedium, sans-serif;
}
.content .block-ImagePanelBlock h2 {
  font-family: Vaud, sans-serif;
}

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