/**
 *
 * White #EDF2F4
 * Blue  #222233
 * light-blue #0a4863
 * grey #c2c7c8
 *
 */

h1,h2,h3,h4,h5,h6, p {
    font-family: 'Libre Franklin', sans-serif;
}

h1 {
    text-transform: uppercase;
}
h1, h3 {
    font-weight: 900;
}

h2,h4,h5,h6 {
    font-weight: bold;
    color: #222233;
}

main h2 {
        margin-top: 3em;
}

main h3, main h4 {
    margin-top: 1.5em;
    margin-bottom: 0.5em;
}

main h3 ~ h4,
main h2 ~ h4,
main h1 ~ h2,
main h1 ~ h3 {
    margin-top: 0.5em;
}

body {
    background-color:#EDF2F4;
}

header {
    position: relative;
    background-color: #222233;
    background: linear-gradient(-15deg, rgba(255,255,255,0.0), #222233 ),#222233 ;
    max-width:100%;
    min-height: 460px;
    overflow: hidden;

}

.headers {
    font-size:  1.25em;
    margin:  0;
    padding: 1.5em 0 8.5em 1em;
    color: #EDF2F4;
    position: relative;
    z-index: 2;
    background: linear-gradient(-15deg, rgba(255,255,255,0.0)30%, #222233 70%);
}

.headers h1 {
    display: block;
    position: relative;
}

.headers h1:after {
    content: "";
    width: 1em;
    border-bottom: 4px solid #EDF2F4 ;
    position: absolute;
    bottom: -0.25em;
    left: 0;

}

.headers h2 {
    color:  #c2c7c8;
    font-size: 1em;
}


@media screen and (min-width: 48em) {
    .headers {
        font-size:  1.75em;
        padding: 1.5em 0 8.5em 3em;
        max-width: 70%;
    }
}

@media screen and (min-width: 64em) {
    .headers {
        font-size:  2em;
        padding: 1.5em 0 8.5em 3em;
        max-width: 40%;
    }
}




svg {
    width: 100%;
    max-width: 100%;
}

#svg-angles {
    max-width:100%;
    overflow: hidden;
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    max-width: 1440px;
    min-width: 800px;
}

#angles {
    height: 200px;
    position: relative;
    bottom: -1em;
}


#svg-network {
    overflow: hidden;
    position: absolute;
    top: -1em;
    right: -1em;
    width: 70%;
    max-width: 600px;
    min-width: 400px;

}

#network {
    opacity: 0.6;
}

main {
    background-color:#EDF2F4;
    position: relative;
    z-index: 3

}
.primary-content {
    padding: 1em;
    max-width: 55em;
    margin: 0 auto;
}

.button-xlarge {
    font-size: 125%;
}

.right {
    text-align: right;
}

.center {
    text-align: center;
}



.body-figure {
  margin: 1em 0;
  max-width: 18em;
}
.body-figure.large {
    float: none;
    margin-left: 0;
    margin-right: 0;
    max-width: auto;
}

.body-figure.small {
  max-width: 12em;
}

img {
    max-width: 100%;
    height: auto;
}
figcaption {
    font-size: 0.75em;
}

.pure-button{
    box-shadow: 0 2px 2px rgba(34, 34, 51,0.25);
}

.pure-button-primary {
    display: block;
    margin: 1.2em 0;
}

@media only screen and (min-width: 48em) {
    .pure-button-primary {
        display: inline-block;
        margin: 0.5em;
    }
}

@media only screen and (min-width: 64em) {

  main article {
    max-width: 40em;
    margin: 0 auto;
  }


  .body-figure {
      max-width: 35%;
      float: left;
      margin-top: 1em;
      margin-left: -25% ;
      margin-right: 1em;
      margin-bottom: 1em;
  }

 .body-figure:nth-of-type(2n) {
      float: right;
      margin-left: 1em;
      margin-right: -15%;
      max-width: 55%;
  }

  .body-figure.large {
    float:none;
    max-width: 110%;
    width: 110%;
    margin-left: 0;
    margin-right: 0;
  }



  .body-figure:nth-of-type(2n),
  .right {
    margin-right: -25% ;
    margin-left: 1em;
  }

  .box-special,
  blockquote {
    margin-left: -5%;
  }

}







.table-wrapper {
    display: block;
    max-width: 100%;
    overflow-x: scroll;
}

.pure-table-striped tr:nth-child(2n-1) td {
    background-color: #e0e0e0;
}
.pure-table thead{
    color :  #222233 ;
    background-color: #c2c7c8;
}
.thead {
    font-weight: bold;
    color :  #222233 ;
}

.intro {
    font-size:  1.15em;
    margin-top: 0.75em;
    margin-bottom:  0.75em;
    color:  #0a4863;
}


blockquote {
    border-left: 0.5em solid #0a4863;
    padding-left: 1.75em;
    overflow: hidden;
    margin-left: 0;
    position: relative;
    display: block;
}




footer{
    position: relative;
    max-width:100%;
    min-height: 460px;
    overflow: hidden;

}

#svg-angles2 {
    max-width:100%;
    overflow: hidden;
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    min-width: 800px;
}

#angles2 {
    height: 200px;
    position: relative;
    bottom: -1em;
}

hr.separator {
    margin:  1em 0;
    width: 85%;
}
