

@-webkit-keyframes rotating {
    from {
        -webkit-transform: rotate(0)
    }
    to {
        -webkit-transform: rotate(360deg)
    }
}

html {
    font-family: "Open Sans", Helvetica, Arial, sans-serif;
    -webkit-text-size-adjust: 100%;
    -ms-text-size-adjust: 100%
}

body {
    margin: 0
}

    img {
    height: auto;
    max-width: 100%;
}

img {
    border: 0;
}

.container {
    margin-right: auto;
    margin-left: auto;
    padding-left: 15px;
    padding-right: 15px
}

.container:after,
.container:before {
    content: " ";
    display: table
}

.container:after {
    clear: both
}

.post-callout {
    line-height: 1.5rem;
    font-size:1.2rem;
    color: #782693;
}

@media (min-width:768px) {
    .container {
        width: 750px
    }
}

@media (min-width:992px) {
    .container {
        width: 970px
    }
}

@media (min-width:1200px) {
    .container {
        width: 1170px
    }
}

.site-content:after:after,
.site-content:after:before,
.site-content:before:after,
.site-content:before:before,
.site-footer:after:after,
.site-footer:after:before,
.site-footer:before:after,
.site-footer:before:before,
.site-header:after:after,
.site-header:after:before,
.site-header:before:after,
.site-header:before:before {
    content: " ";
    display: table
}
.site-content:after:after,
.site-content:before:after,
.site-footer:after:after,
.site-footer:before:after,
.site-header:after:after,
.site-header:before:after {
    clear: both
}

.site-content:after,
.site-footer:after,
.site-header:after {
    clear: both
}

.site-header {
    position: fixed;
    z-index: 2;
    width: 100%;
    height: 43px;
    min-height: 37px;
    padding-top: 6px;
    top: 0;
    background: #fff;
    -webkit-transition: background 1s ease-in-out;
    transition: background 1s ease-in-out;
    overflow: hidden;
}

.site-header:before {
    background: -webkit-gradient(linear, left top, right top, from(#9fe810), color-stop(#4ed5e6), to(#bf76e7));
    background: linear-gradient(to right, #9fe810, #4ed5e6, #bf76e7);
    height: 6px;
    width: 100%;
    top: 0;
    left: 0;
    display: block;
    position: fixed;
    z-index: 15;
    content: ' '
}

.site-header:after {
    display: block;
    content: ' ';
    border-left: 15px solid transparent;
    border-right: 15px solid transparent;
    border-top: 8.33333px solid #fff;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    width: 30px;
    left: 14px;
    position: absolute;
    top: 43px;
    opacity: 1;
    -webkit-transition: opacity 1s ease-in-out;
    transition: opacity 1s ease-in-out
}

.polygon1 {
  position: absolute;
  left: 50%;
  margin-left: -400px;
  opacity: 0;

  -webkit-transform: translate(0, -100%);
  transform: translate(0, -100%);
  -webkit-transition: -webkit-transform, opacity .5s ease-out;
  transition: -webkit-transform, opacity .5s ease-out;
  transition: transform, opacity .5s ease-out;
  transition: transform, opacity .5s ease-out, -webkit-transform .5s ease-out;
}
.site-header .site-header-backing {
    position: absolute;
    opacity: 0;
    top: 0;
    left: 50%;
    -webkit-transform: translate(-50%, -100%);
    transform: translate(-50%, -100%);
    border-left: 390px solid transparent;
    border-right: 390px solid transparent;
    border-top: 200px solid #fff;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    width: 30px;
    z-index: -1;
    -webkit-transition: -webkit-transform, opacity .5s ease-out;
    transition: -webkit-transform, opacity .5s ease-out;
    transition: transform, opacity .5s ease-out;
    transition: transform, opacity .5s ease-out, -webkit-transform .5s ease-out;
    z-index: 2;
}


.site-header .site-header-backing .logo-text-centered {
    opacity: 1;
    position: absolute;
    left: 50%;
    top: -80px;
    -webkit-transform: translate(-50%, 0);
    transform: translate(-50%, 0);
    display: block;
    width: 90px;
    -webkit-transition: opacity .5s ease-out;
    transition: opacity .5s ease-out;
}

.site-header .site-header-backing .logo-text-centered img {
    height: 40px
}

body.scrolled .site-header .site-header-backing {
    opacity: 1;
    -webkit-transform: translate(-50%, -100%);
    transform: translate(-50%, -100%)
}

body.scrolled .site-header .site-header-backing .logo-text-centered {
    opacity: 0
}

body.home .site-header .site-header-backing {
    border-top: 200px solid transparent
}

.site-header .logo {
    position: absolute;
    top: 10px;
    left: 15px;
    width: 28px;
    height: 41px;
    -webkit-transform: translate(0, 0);
    transform: translate(0, 0);
    -webkit-transition: top .7s ease-in-out, left .7s ease-in-out, width .7s ease-in-out, -webkit-transform .7s ease-in-out;
    transition: top .7s ease-in-out, left .7s ease-in-out, width .7s ease-in-out, -webkit-transform .7s ease-in-out;
    transition: top .7s ease-in-out, left .7s ease-in-out, width .7s ease-in-out, transform .7s ease-in-out;
    transition: top .7s ease-in-out, left .7s ease-in-out, width .7s ease-in-out, transform .7s ease-in-out, -webkit-transform .7s ease-in-out;
    z-index: 3;
}

.site-header .site-title {
    left: 55px;
    top: 17px;
    width: 115px;
    height: 23px;
    position: absolute;
    opacity: 1;
    -webkit-transition: opacity 1s ease-in-out;
    transition: opacity 1s ease-in-out;
    margin: 0;
    font-size: 16px;
    line-height: 23px
}

.site-header .site-header-bg {
    background: #fff;
    position: absolute;
    height: 100%;
    width: 100%;
    z-index: -1
}

.error404 .hero-area {
    position: relative;
    z-index: 1;
    overflow: hidden;
    height: 120px;
    padding: 0px;
}

#page {
  min-height: calc(100vh - 308px);
}

.site-footer {
    padding: 30px 0;
    background: #332a47;
}

.site-footer.sensei-onscreen .site-footer-background {
    -webkit-transform: translateX(0);
    transform: translateX(0);
    opacity: 1
}

.site-footer-content {
    position: relative;
    z-index: 1
}

.site-footer-background {
    background: url(images/background-footer.png) no-repeat right bottom;
    position: absolute;
    height: 100%;
    width: 100%;
    z-index: 0;
    top: 0;
    left: 0;
    opacity: .2;
    -webkit-transform: translateX(30px);
    transform: translateX(30px);
    -webkit-transition: opacity 1s ease-out, -webkit-transform 1s ease-out;
    transition: opacity 1s ease-out, -webkit-transform 1s ease-out;
    transition: transform 1s ease-out, opacity 1s ease-out;
    transition: transform 1s ease-out, opacity 1s ease-out, -webkit-transform 1s ease-out
}

.site-footer-navigation {
    margin: 0;
    padding: 0;
    list-style-type: none
}

.site-footer-navigation .menu-item {
    margin-bottom: 10px;
    text-transform: uppercase;
    font-size: 0
}

.site-footer-info-links li:first-child:after {
    content: none
}

.site-footer-info-links li a {
    color: #fff;
    font-size: 14px;
    text-decoration: none;
    -webkit-transition: all .2s ease-in-out;
    transition: all .2s ease-in-out
}

.site-footer-info-links li a[href]:focus,
.site-footer-info-links li a[href]:hover {
    color: #54d3c3
}

.site-footer-logo {
    text-align: center;
    margin: 40px 0 40px 0
}

.site-footer-logo a {
    position: relative;
    height: 47px;
    display: inline-block;
    padding: 9px 0 0 48px
}

.site-footer-logo a:after {
    height: 45px;
    width: 38px;
    content: ' ';
    position: absolute;
    left: 0;
    top: 0;
    background: url(images/sensei-logo-icon.png) no-repeat 0 0;
    background-size: contain
}

.site-footer-logo-type {
    height: 30px;
    width: 115px
}

.site-footer-contact {
    margin: 20px 0;
    text-align: center
}

.site-footer-email,
.site-footer-telephone {
    border-bottom: 1px solid #bc75e4;
    display: block;
    margin: 0 -15px;
    color: #fff;
    text-decoration: none;
    font-size: 24px;
    line-height: 70px;
    -webkit-transition: all .2s ease-in-out;
    transition: all .2s ease-in-out
}
.site-footer-email:focus,
.site-footer-email:hover,
.site-footer-telephone:focus,
.site-footer-telephone:hover {
    color: #54d3c3
}

.site-footer-telephone {
    border-top: 1px solid #bc75e4;
    text-transform: uppercase;
    font-size: 30px
}

.site-footer-social {
    list-style-type: none;
    margin: 0;
    padding: 0;
    text-align: center
}

.site-footer-social .footer-icon {
    fill: #fff;
    fill-rule: evenodd;
    -webkit-transition: fill .2s ease-out;
    transition: fill .2s ease-out
}

.site-footer-social-item {
    display: inline-block;
    width: 30px;
    height: 30px;
    margin-right: 10px
}

.site-footer-social-item:last-child {
    margin-right: 0
}

.site-footer-social-item:before {
    display: none
}

.site-footer-social-item a {
    color: #fff;
    text-decoration: none;
    -webkit-transition: all .2s ease-in-out;
    transition: all .2s ease-in-out;
    display: block;
    width: 30px;
    height: 30px
}

.site-footer-social-item a:focus .footer-icon,
.site-footer-social-item a:hover .footer-icon {
    fill: #54d3c3
}

.site-footer-social-item a img,
.site-footer-social-item a svg {
    height: inherit;
    width: inherit
}

.content-404 {
  display: flex;
  align-items: center;
  align-content: space-around;
  flex-direction: column;
}

@media (min-width:768px) {
    .site-footer-navigation .menu-item {
        margin-bottom: 7px
    }
    .site-footer-navigation>.menu-item>.sub-menu .sub-menu {
        margin-bottom: 3px;
        margin-top: 0
    }
    .site-footer-navigation>.menu-item>.sub-menu .sub-menu>.menu-item {
        margin-bottom: 3px
    }
     .site-footer-info {
        text-align: left
    }
    .site-footer-info-links {
        display: block
    }

    .site-footer-info-links li:first-child {
        padding: 0 13px 0 0
    }
    .site-footer-logo {
        margin: 0;
        text-align: right;
        padding-bottom: 120px
    }

    .site-footer-contact {
        margin: 0 0 -56px 0;
        text-align: right;
        position: absolute;
        top: 60px;
        padding-top: 30px;
        right: 15px
    }
    .site-footer-contact:before {
        content: ' ';
        height: 1px;
        background: #bc75e4;
        width: 120px;
        position: absolute;
        display: block;
        right: 0;
        top: 0
    }
    .site-footer-email,
    .site-footer-telephone {
        margin: 0;
        font-size: 18px;
        line-height: 1em;
        display: inline-block;
        border-bottom: none
    }

    .site-footer-telephone {
        font-size: 24px;
        border-top: none
    }
    .site-footer-social {
        text-align: right;
        margin-top: 60px
    }
}

@media (min-width:992px) {
    .site-header {
        background: 0 0;
        overflow: initial;
    }
    body.scrolled .site-header {
        background: #fff
    }
    body.scrolled .site-header:after {
        left: 51px
    }

    .site-header:after {
        opacity: 0;
        left: 51px
    }
    body.scrolled .site-header:after {
        opacity: 1
    }

    .polygon1 { 
      opacity: 1;
      -webkit-transform: translate(0, 0);
      transform: translate(0, 0)
    }
    .site-header .site-header-backing {
        opacity: 1;
        -webkit-transform: translate(-50%, 0);
        transform: translate(-50%, 0)
    }
    .site-header .logo {
        top: 55px;
        left: 50%;
        width: 45px;
        -webkit-transform: translate(-50%, 0);
        transform: translate(-50%, 0)
    }
    body.scrolled .site-header .logo {
        top: 10px;
        left: 52px;
        width: 28px;
        -webkit-transform: translate(0, 0);
        transform: translate(0, 0)
    }

    .site-header .site-title {
        opacity: 0;
        left: 90px;
        pointer-events: none
    }

    .error404 .hero-area {
      height: 250px;      
    }
    .post-callout {
      line-height: 1.875rem;
      font-size: 1.5rem;
    }

    body.scrolled .site-header .site-title {
        left: 90px;
        opacity: 1;
        pointer-events: all
    }

    .site-footer-info-links {
        display: inline;
        margin: 0 0 1em 20px
    }

    .site-footer-info-links li:first-child {
        padding: 0 13px 0 15px
    }

    .site-footer-email,
    .site-footer-telephone {
        font-size: 16px
    }
    .site-footer-telephone {
        font-size: 18px
    }
}

@media (max-width:500px) {
    #page {
       min-height: calc(100vh - 331px);
    }
   .site-footer-email, .site-footer-telephone {
      font-size: 1.2rem;
      line-height: 50px;
    }
}