@font-face {
  font-family: "icons";
  src: url("/fonts/icomoon.ttf"); }
@font-face {
  font-family: "Source Sans Pro";
  font-style: normal;
  font-weight: 400;
  src: local("Source Sans Pro"), local("SourceSansPro-Regular"), url("/fonts/SourceSansPro-Regular.woff") format("woff"), url("/fonts/SourceSansPro-Regular.ttf") format("truetype"); }
@font-face {
  font-family: "Source Sans Pro";
  font-style: normal;
  font-weight: 700;
  src: local("Source Sans Pro Bold"), local("SourceSansPro-Bold"), url("/fonts/SourceSansPro-Bold.woff") format("woff"), url("/fonts/SourceSansPro-Bold.ttf") format("truetype"); }
@font-face {
  font-family: "Source Sans Pro";
  font-style: italic;
  font-weight: 400;
  src: local("Source Sans Pro Italic"), local("SourceSansPro-It"), url("/fonts/SourceSansPro-It.woff") format("woff"), url("/fonts/SourceSansPro-It.ttf") format("truetype"); }
@font-face {
  font-family: "Source Sans Pro";
  font-style: italic;
  font-weight: 700;
  src: local("Source Sans Pro Bold Italic"), local("SourceSansPro-BoldIt"), url("/fonts/SourceSansPro-BoldIt.woff") format("woff"), url("/fonts/SourceSansPro-BoldIt.ttf") format("truetype"); }
@media only screen and (max-width: 700px) {
  .s-hidden {
    display: none; } }

@media only screen and (max-width: 958px) {
  .m-hidden {
    display: none; } }

.m-visible {
  display: none; }
  @media only screen and (max-width: 958px) {
    .m-visible {
      display: block; } }

*, *:before, *:after {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box; }

html {
  background: url(/images/LED-Throwies.jpg) no-repeat center center fixed;
  -webkit-background-size: cover;
  -moz-background-size: cover;
  -o-background-size: cover;
  background-size: cover; }
  @media only screen and (max-width: 958px) {
    html {
      background: none; } }

body {
  display: flex;
  flex-direction: column;
  background: #ecf0f1;
  min-height: 100vh;
  width: 100%;
  max-width: 60em;
  font: normal 16px/1.5 "Source Sans Pro", sans-serif;
  color: #222;
  box-shadow: 0 0 30px rgba(0, 0, 0, 0.5);
  margin: 120px auto 0px auto; }
  body audio {
    width: 100%; }
  body a {
    color: #55d400; }
  @media only screen and (max-width: 958px) {
    body {
      margin: 0;
      max-width: 100vw; } }
  body > header {
    position: relative;
    min-height: 60px;
    background: #242424;
    display: flex;
    display: -webkit-flex;
    flex-direction: row;
    -webkit-flex-align: center;
    -webkit-align-items: center;
    align-items: center; }
    @media only screen and (max-width: 958px) {
      body > header {
        display: block; } }
  body > main {
    flex: 1;
    display: block;
    padding: 10px 2em 10px 2em; }
    @media only screen and (max-width: 700px) {
      body > main {
        padding: 10px; } }
  body > footer {
    background: #242424; }
    body > footer nav {
      padding: 5px 10px;
      width: 100%;
      background: #3e3e3e;
      text-align: right; }
    body > footer a {
      padding-left: 10px;
      color: white; }
      body > footer a:hover {
        color: #55d400;
        text-decoration: none; }

.social {
  display: flex;
  display: -webkit-flex;
  display: -ms-flexbox;
  padding: 10px 0; }
  @media only screen and (max-width: 700px) {
    .social {
      display: block;
      text-align: center; } }
  .social a {
    text-align: center;
    width: 33%; }
    .social a i {
      font-size: 4em;
      margin: 0; }
    .social a p {
      margin-top: -1em; }

#slider {
  margin: -10px -2em -10px -2em;
  height: 300px;
  overflow: hidden;
  position: relative; }
  #slider .progress {
    position: absolute;
    bottom: 0px;
    left: 0px;
    background: rgba(255, 255, 255, 0.4);
    height: 5px;
    z-index: 20; }
  #slider .frame {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 100%;
    opacity: 1;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    -o-background-size: cover;
    background-size: cover;
    background-image: url("/images/slider/slide2.jpg");
    -webkit-transition: opacity 1s ease-in-out;
    -moz-transition: opacity 1s ease-in-out;
    transition: opacity 1s ease-in-out; }
  #slider .fade-out {
    opacity: 0; }

#Logo {
  position: absolute;
  top: -100px;
  right: 50px;
  height: 110px;
  width: 130px; }

#Status {
  height: 15px;
  width: 100%;
  background: url("http://status.hasi.it/image/pixel.svg") repeat; }

header > nav {
  width: 100%;
  text-align: right;
  margin-right: 2em;
  font-size: 1rem; }
  @media only screen and (max-width: 958px) {
    header > nav {
      text-align: center; } }
  @media only screen and (max-width: 700px) {
    header > nav {
      margin-right: 0; } }
  header > nav a {
    display: inline-block;
    padding: 6px 13px;
    color: white;
    line-height: 100%; }
    header > nav a:hover {
      background: #1D1717;
      text-decoration: none; }

#heading {
  padding: 0.5em 0 0.5em 2em;
  text-align: left;
  min-width: 14em; }
  @media only screen and (max-width: 958px) {
    #heading {
      width: 100%; } }
  #heading h1 {
    color: white;
    margin: 0;
    font-size: 240%;
    padding: 0;
    line-height: 1; }
  #heading p {
    font-weight: bold;
    margin: 0;
    color: #55d400; }

a {
  text-decoration: none;
  color: #4183c4; }
  a:hover {
    text-decoration: underline; }

h1 a, h2 a, h3 a, h4 a, h5 a, h6 a {
  color: inherit; }

h1 {
  font-size: 1.7rem;
  color: black; }

h2 {
  font-size: 1.5em;
  border-bottom: 1px solid #cccccc;
  color: black;
  clear: left; }

h3 {
  font-size: 1.3rem; }

h4 {
  font-size: 1.2rem; }

h5 {
  font-size: 1.1rem; }

h6 {
  color: #777777;
  font-size: 1rem; }

p {
  font-size: 1rem; }

.flex {
  display: flex;
  clear: left;
  flex-direction: column; }
  .flex section, .flex article {
    flex: 1; }

ul {
  text-indent: 0;
  list-style-type: none;
  margin-left: 0; }
  ul li > p {
    margin: 0; }

.active {
  font-weight: bold; }

.headline {
  padding-top: 2em;
  text-align: center;
  font-weight: bold; }

iframe {
  width: 50%; }

th iframe {
  width: 15%; }

.group:after {
  content: "";
  display: table;
  clear: both; }

.img-left {
  max-width: 40%;
  float: left;
  margin: 0 20px 0 0; }

.img-right {
  max-width: 40%;
  float: right;
  margin: 0 20px 0 0;
  font-size: 4em;
  text-align: center; }

.img-right p {
  margin-top: -1em; }

.img-right a:hover {
  text-decoration: none; }

.full {
  width: 100%; }

.half {
  flex: 1;
  width: 150px;
  margin: 20px;
  height: 400px; }

.hidden {
  opacity: 0; }

input, textarea {
  color: #303030; }

table {
  padding: 0;
  word-wrap: break-word;
  word-break: break-all; }
  table tr {
    margin: 0;
    padding: 0; }
    table tr:nth-child(2n-1) {
      background: rgba(0, 0, 0, 0.05); }
    table tr td, table tr th {
      margin: 0;
      padding: 6px 13px; }
    table tr th {
      font-weight: bold; }
    table tr th :first-child, table tr td :first-child {
      margin-top: 0; }
    table tr th :last-child, table tr td :last-child {
      margin-bottom: 0; }

.code, .line-numbers {
  font-size: 90%; }

code {
  font-size: 90%;
  background-color: #55d400;
  padding: 1px 3px;
  -webkit-border-radius: 3px;
  -moz-border-radius: 3px;
  border-radius: 3px; }

.CodeRay {
  display: block;
  overflow: scroll; }

img {
  max-width: 100%;
  margin: 15px;
  margin-top: -1px; }

.break {
  font-weight: bold; }

.button {
  background: #55d400;
  color: white;
  padding: 3px 10px;
  margin-right: 10px; }
  .button:hover {
    color: white; }

[data-icon]:before {
  font-family: "icons";
  font-style: normal;
  margin-left: 5px;
  content: attr(data-icon);
  -webkit-font-feature-settings: "liga";
  -moz-font-feature-settings: "liga=1";
  -moz-font-feature-settings: "liga";
  -ms-font-feature-settings: "liga" 1;
  -o-font-feature-settings: "liga";
  font-feature-settings: "liga"; }

.paypal {
  border: none;
  background: none;
  font: inherit;
  font-size: 100%;
  line-height: 100%;
  padding: 0;
  -webkit-font-smoothing: antialiased;
  font-family: "Source Sans Pro", sans-serif;
  color: #55d400;
  cursor: pointer; }
  .paypal:hover {
    text-decoration: underline; }
