/*
 * This is a manifest file that'll be compiled into application.css, which will include all the files
 * listed below.
 *
 * Any CSS and SCSS file within this directory, lib/assets/stylesheets, vendor/assets/stylesheets,
 * or vendor/assets/stylesheets of plugins, if any, can be referenced here using a relative path.
 *
 * You're free to add application-wide styles to this file and they'll appear at the top of the
 * compiled file, but it's generally better to create a new file per style scope.
 *


 */

#world {
  /*
  http://www.colourlovers.com/palette/848743/(%E2%97%95_%E2%80%9D_%E2%97%95)
  http://www.colourlovers.com/palette/3443395/sugary
  */ }
  #world .node text {
    font-size: 12px;
    fill: #907F76;
    fill-opacity: 1; }
    #world .node text.text-bg {
      fill: none;
      stroke: #FFF;
      strok-opacity: 1;
      stroke-width: 6;
      stroke-linejoin: round; }
  #world .node use {
    pointer-events: all; }
    #world .node use:hover {
      fill: orange;
      cursor: pointer; }
  #world .node circle {
    cursor: pointer; }
    #world .node circle.focus {
      fill: #1c9edb;
      fill-opacity: 0.1;
      stroke: none; }
    #world .node circle.clicker {
      stroke: none;
      fill-opacity: 0; }
      #world .node circle.clicker:hover {
        fill: orange;
        fill-opacity: 0.2; }
    #world .node circle.icon-bg {
      fill: #FFF;
      stroke: none; }
  #world line {
    stroke: #000;
    stroke-width: 1.5px; }
  #world path.link-connect {
    fill: none;
    stroke: #d3cdca;
    stroke-width: 1.5px;
    stroke-dasharray: 3, 3; }
    #world path.link-connect.public {
      stroke: #A0C55F; }
  #world path.link-focusPath {
    fill: none;
    stroke: #1C9EDB;
    stroke-width: 2px; }
  #world .icon {
    fill: #490A3D; }
    #world .icon.wifi-high {
      fill: #F8CA00; }
    #world .icon.browser-2 {
      fill: #772A53; }
    #world .icon.database {
      fill: #E97F02; }
    #world .icon.software {
      fill: #4EC09F;
      stroke: #39a284;
      stroke-width: 5px; }
    #world .icon.document, #world .icon.filesystem, #world .icon.documents-code, #world .icon.document-html, #world .icon.document-pdf, #world .icon.image, #world .icon.video-2 {
      fill: #8A9B0F; }
    #world .icon.server2 {
      fill: #BD1550; }
    #world .icon.menu {
      fill: #0D6759; }
    #world .icon.endpoint {
      fill: #444; }
    #world .icon.exchange {
      fill: #777; }
  #world .flow-icon {
    fill: #1C9EDB; }
  #world .cross-out {
    fill: #e51c23; }
  #world g.description {
    font-family: inherit;
    font-size: 30px;
    fill: #757575; }

body .sub-description {
  font-size: 14px;
  color: #757575; }
body.landing {
  margin: 0;
  padding: 0;
  text-align: center; }
  body.landing h1, body.landing h2, body.landing h3, body.landing h4, body.landing h5 {
    margin: 0; }
  body.landing h1 {
    font-size: 70px; }
  body.landing h2 {
    font-size: 40px; }
  body.landing h3 {
    font-size: 36px; }
  body.landing h4 {
    font-size: 30px; }
  body.landing a:link {
    color: inherit; }
  body.landing .container {
    width: 50%;
    margin: auto;
    padding: 10px;
    text-align: center; }
  body.landing #banner {
    padding: 60px 20px 100px 20px;
    background: #1c9edb;
    /* IE10 Consumer Preview */
    background-image: url("/assets/media/landing-graphic.svg"), -ms-radial-gradient(right center, ellipse farthest-side, #58BBE9 0%, #1C9EDB 100%);
    /* Mozilla Firefox */
    background-image: url("/assets/media/landing-graphic.svg"), -moz-radial-gradient(right center, ellipse farthest-side, #58BBE9 0%, #1C9EDB 100%);
    /* Opera */
    background-image: url("/assets/media/landing-graphic.svg"), -o-radial-gradient(right center, ellipse farthest-side, #58BBE9 0%, #1C9EDB 100%);
    /* Webkit (Safari/Chrome 10) */
    background-image: url("/assets/media/landing-graphic.svg"), -webkit-gradient(radial, right center, 0, right center, 954, color-stop(0, #58BBE9), color-stop(1, #1C9EDB));
    /* Webkit (Chrome 11+) */
    background-image: url("/assets/media/landing-graphic.svg"), -webkit-radial-gradient(right center, ellipse farthest-side, #58BBE9 0%, #1C9EDB 100%);
    /* W3C Markup, IE10 Release Preview */
    background-image: url("/assets/media/landing-graphic.svg"), radial-gradient(ellipse farthest-side at right center, #58BBE9 0%, #1C9EDB 100%);
    background-repeat: no-repeat;
    background-position-x: 150%;
    background-position-y: center; }
  body.landing #heading {
    margin-bottom: 60px;
    color: #FFF;
    text-shadow: 2px 2px 0px #1780b0; }
  body.landing #tagline {
    font-size: 1.4em;
    margin-bottom: 60px;
    color: #FFF;
    text-shadow: 1px 1px 0px #1780b0; }
  body.landing .heading {
    padding: 20px;
    background-color: #ffd600;
    color: #FFF;
    text-align: center;
    text-shadow: 1px 1px 0px #ffc400; }
  body.landing #courses-wrap .course {
    display: block;
    text-decoration: none;
    background-color: #FFF;
    padding: 20px;
    border-bottom: 2px solid #1c9edb; }
    body.landing #courses-wrap .course:last-child {
      border: 0; }
    body.landing #courses-wrap .course:hover h4 {
      text-decoration: underline; }
    body.landing #courses-wrap .course h4 {
      text-align: center;
      margin: 20px 0;
      color: #424242; }
    body.landing #courses-wrap .course img {
      display: block;
      margin: auto; }
  body.landing #mce-EMAIL {
    width: 200px;
    border: 1px solid #fbe9e7; }
  body.landing #signup-form {
    width: 30%;
    margin: 0 auto;
    border: 2px solid #1780b0;
    border-radius: 5px;
    font-family: inherit;
    text-align: center;
    color: #FFF; }
    body.landing #signup-form input {
      padding: 2px 8px;
      font-size: 14px;
      line-height: 22px; }
    body.landing #signup-form form {
      padding: 20px; }
  body.landing #mc-embedded-subscribe {
    background-color: #1780b0;
    border: 0;
    color: #FFF;
    border-radius: 5px;
    cursor: pointer; }
    body.landing #mc-embedded-subscribe:hover {
      background-color: #FFF;
      color: #212121; }
  body.landing #about-wrap {
    margin-top: 60px;
    background-color: transparent;
    padding-bottom: 30px; }
    body.landing #about-wrap .heading {
      background-color: transparent;
      color: inherit;
      text-shadow: none; }
  body.landing #credits-wrap {
    background-color: transparent;
    padding-bottom: 30px; }
    body.landing #credits-wrap .heading {
      background-color: transparent;
      color: inherit;
      text-shadow: none; }
  body.landing #credits-list {
    list-style: none;
    text-align: center;
    margin: 0;
    padding: 0; }
    body.landing #credits-list li {
      display: inline-block;
      height: 100px;
      width: 200px;
      vertical-align: middle;
      line-height: 100px; }
      body.landing #credits-list li a {
        display: block;
        font-size: 24px;
        font-family: inherit;
        color: inherit; }
      body.landing #credits-list li img {
        display: block;
        margin: auto; }
        body.landing #credits-list li img.heap {
          margin-top: 30px; }

@media only screen and (max-width: 800px) {
  body.landing #signup-form {
    width: 100%;
    height: auto; }
  body.landing #courses-wrap img {
    width: 100%;
    height: auto; }
  body.landing #banner {
    background-position-x: 0;
    background-position-y: center; } }
/*
http://www.google.com/design/spec/style/color.html#color-ui-color-palette
http://www.colorzilla.com/gradient-editor/
*/
html, body {
  margin: 0;
  padding: 0;
  font-family: 'Nunito', "Helvetica Neue", Helvetica, sans-serif;
  font-weight: 300;
  font-size: 15px; }

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

pre {
  font-size: 18px; }

a:link, a:visited {
  color: #000;
  text-decoration: none; }
a:hover {
  color: #666; }

#world {
  margin: auto;
  width: 100%; }

#world svg {
  display: block;
  width: 100%;
  margin: auto;
  overflow: visible;
  font-family: inherit; }

kbd {
  padding: 0.1em 0.6em;
  border: 1px solid #ccc;
  font-size: 11px;
  font-family: Arial,Helvetica,sans-serif;
  background-color: #f7f7f7;
  color: #333;
  -moz-box-shadow: 0 1px 0px rgba(0, 0, 0, 0.2), 0 0 0 2px #ffffff inset;
  -webkit-box-shadow: 0 1px 0px rgba(0, 0, 0, 0.2), 0 0 0 2px #ffffff inset;
  box-shadow: 0 1px 0px rgba(0, 0, 0, 0.2), 0 0 0 2px #ffffff inset;
  -moz-border-radius: 3px;
  -webkit-border-radius: 3px;
  border-radius: 3px;
  display: inline-block;
  margin: 0 0.1em;
  text-shadow: 0 1px 0 #fff;
  line-height: 1.4;
  white-space: nowrap; }

body.visualizer {
  background-color: #FFF; }

#steps-count {
  position: absolute;
  bottom: 10px;
  right: 90px;
  padding: 0 15px 0 35px;
  background-color: #FFF;
  height: 35px;
  line-height: 35px;
  z-index: 21;
  cursor: pointer;
  color: #616161;
  border-radius: 5px;
  background-color: #e0e0e0; }
  #steps-count:hover {
    background-color: #424242;
    color: #eee; }
    #steps-count:hover svg {
      fill: #eee; }
  #steps-count em {
    font-style: normal; }
  #steps-count svg {
    position: absolute;
    left: 0;
    fill: #616161;
    height: 35px;
    width: 35px; }

#table-of-contents {
  position: absolute;
  left: 20%;
  width: 60%;
  top: 0;
  height: 0;
  bottom: 0;
  z-index: 50;
  background-color: rgba(20, 20, 20, 0.9);
  border-right: 1px solid #222;
  border-left: 1px solid #222;
  color: #bdbdbd;
  overflow: auto;
  opacity: 0;
  transition: opacity 0.5s; }
  #table-of-contents.active {
    height: 100%;
    opacity: 1; }
  #table-of-contents h4 {
    display: block;
    margin: 0;
    padding: 8px;
    background-color: rgba(17, 17, 17, 0.6);
    text-align: center;
    color: #757575; }
  #table-of-contents ol {
    padding: 0;
    margin: 0;
    font-size: 0.9em;
    list-style: none;
    counter-reset: chapter;
    min-width: 200px; }
    #table-of-contents ol li {
      border-bottom: 1px solid #111; }
      #table-of-contents ol li:hover a, #table-of-contents ol li.active a {
        background-color: #222; }
      #table-of-contents ol li a {
        display: block;
        padding: 7px 15px;
        line-height: 1.5em;
        text-decoration: none;
        color: inherit;
        font-size: inherit;
        cursor: pointer; }
        #table-of-contents ol li a:before {
          content: counter(chapter) ". ";
          counter-increment: chapter; }
  #table-of-contents .keyboard-info {
    font-size: 12px;
    color: #777;
    margin-top: 20px;
    text-align: center; }

#prev-next-wrap {
  position: absolute;
  bottom: 10px;
  right: 10px; }

#prev-next {
  width: 100%;
  margin: 0;
  position: relative;
  text-align: center; }
  #prev-next svg {
    height: 30px;
    width: 30px;
    cursor: pointer;
    fill: #424242; }
    #prev-next svg:hover {
      fill: #212121; }

#description div {
  font: 16px 'Helvetica Neue';
  color: inherit;
  padding: 15px;
  background-color: inherit; }
  #description div h3 {
    font-size: 16px;
    font-weight: bold;
    margin: 0 0 15px 0; }
  #description div p {
    padding-left: 10%;
    padding-right: 10%;
    margin: 0 0 15px 0;
    line-height: 1.4em; }
  #description div a {
    color: green;
    text-decoration: underline; }
  #description div pre {
    font-size: inherit;
    overflow: auto;
    background-color: #eee;
    color: #777; }
  #description div blockquote {
    color: #777; }
  #description div ul, #description div ol {
    line-height: 1.5em; }
    #description div ul li, #description div ol li {
      margin-bottom: 5px; }
body.visualizer #mce-EMAIL {
  width: 200px;
  border: 1px solid #fbe9e7; }
body.visualizer #signup-form {
  position: absolute;
  bottom: 0;
  left: 25%;
  width: 50%;
  height: 0;
  z-index: 999;
  overflow: hidden;
  background-color: #dd2c00;
  font-family: inherit;
  color: #FFF;
  text-align: center;
  transition: height 0.8s; }
  body.visualizer #signup-form.active {
    height: 100px;
    border: 1px solid #c22700;
    border-bottom: 0; }
  body.visualizer #signup-form input {
    padding: 2px 8px;
    font-size: 14px;
    line-height: 22px; }
  body.visualizer #signup-form form {
    padding: 20px; }
body.visualizer #mc-embedded-subscribe {
  background-color: #c22700;
  color: #fbe9e7;
  border: 1px solid #fbe9e7;
  cursor: pointer; }
  body.visualizer #mc-embedded-subscribe:hover {
    background-color: #b82500; }
@media only screen and (min-width: 900px) and (max-height: 750px) {
  #world {
    width: 90%; } }
@media only screen and (min-width: 900px) and (max-height: 700px) {
  #world {
    width: 80%; } }
@media only screen and (min-width: 900px) and (max-height: 650px) {
  #world {
    width: 70%; } }
@media only screen and (min-width: 900px) and (max-height: 600px) {
  #world {
    width: 60%; } }
@media only screen and (max-width: 1200px) {
  #steps-count {
    right: 60px;
    height: 30px;
    line-height: 30px;
    font-size: 12px;
    border-radius: 2px;
    padding-left: 25px; }
    #steps-count svg {
      width: 30px;
      height: 30px; }

  #prev-next-wrap svg {
    height: 20px;
    width: 20px; }

  #table-of-contents {
    left: 0;
    z-index: 50;
    width: 100%; }

  #signup-form {
    width: 100%;
    left: 0;
    height: 0; } }
/*
http://tobiasahlin.com/spinkit/
*/


.spinner {
  margin: 100px auto 0;
  width: 70px;
  height:200px;
  text-align: center;
}

.spinner > div {
  width: 18px;
  height: 18px;
  background-color: #424242;

  border-radius: 100%;
  display: inline-block;
  -webkit-animation: bouncedelay 1.4s infinite ease-in-out;
  animation: bouncedelay 1.4s infinite ease-in-out;
  /* Prevent first frame from flickering when animation starts */
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both;
}

.spinner .bounce1 {
  -webkit-animation-delay: -0.32s;
  animation-delay: -0.32s;
}

.spinner .bounce2 {
  -webkit-animation-delay: -0.16s;
  animation-delay: -0.16s;
}

@-webkit-keyframes bouncedelay {
  0%, 80%, 100% { -webkit-transform: scale(0.0) }
  40% { -webkit-transform: scale(1.0) }
}

@keyframes bouncedelay {
  0%, 80%, 100% {
    transform: scale(0.0);
    -webkit-transform: scale(0.0);
  } 40% {
    transform: scale(1.0);
    -webkit-transform: scale(1.0);
  }
}
