
/******************** FONTS *************************/

@font-face {
    font-family: 'archerpro';
    src:    url("../fonts/ArcherPro-BookItalic.eot?") format("eot"),
            url("../fonts/ArcherPro-BookItalic.otf") format("opentype"),
            url("../fonts/ArcherPro-BookItalic.woff") format("woff"),
            url("../fonts/ArcherPro-BookItalic.ttf") format("truetype"),
            url("../fonts/ArcherPro-BookItalic.svg#ArcherPro-BookItalic") format("svg");
}

@font-face {
    font-family: 'avenir';
    src:    url("../fonts/AvenirLTStd-Light.eot?") format("eot"),
            url("../fonts/AvenirLTStd-Light.otf") format("opentype"),
        url("../fonts/AvenirLTStd-Light.woff") format("woff"),
        url("../fonts/AvenirLTStd-Light.ttf") format("truetype"),
        url("../fonts/AvenirLTStd-Light.svg#AvenirLTStd-Light") format("svg");
}

@font-face {
    font-family: 'avenirheavy';
    src:    url("../fonts/AvenirLTStd-Heavy.eot?") format("eot"),
            url("../fonts/AvenirLTStd-Heavy.otf") format("opentype"),
        url("../fonts/AvenirLTStd-Heavy.woff") format("woff"),
        url("../fonts/AvenirLTStd-Heavy.ttf") format("truetype"),
        url("../fonts/AvenirLTStd-Heavy.svg#AvenirLTStd-Heavy") format("svg");
}

/******************** GENERAL *************************/

html, body {
    overflow-x: hidden;
}

body {
    position: relative;
    font-family:Avenir;
    font-size: 16px;
    line-height: 22px;
    /* Bootstrap injects padding styling via JS that we don't want */
    padding-right: 0px !important;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

h1,h2,h3{
    font-family:archerpro;
}

p {
    font-family:Avenir;
    font-size: 20px;
    line-height: 27px;
    margin: 0px;
}

.wrapper {
    /* Make sure absolute elements can orient themselves at wrapper whn
       the age disclaimer pops down */
    position: relative;
    overflow: hidden;
    margin: 0;
}

.normal-anchor{
    font-size: 15px;
    font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
}

a{
    cursor: pointer;
    color: #79939F;
}

.center-text{
    text-align: center;
}

.right-text{
    text-align: center;
}

.gray-container{
    padding-bottom: 15px;
    padding-left: 3000px;
    margin-left: -3000px;
    padding-right: 3000px;
    margin-right: -3000px;
    background-color: #F5F5F5;
}

.white-container{
    padding-bottom: 30px;
    padding-top: 30px;
    background-color: white;
    padding-left: 3000px;
    margin-left: -3000px;
    padding-right: 3000px;
    margin-right: -3000px;
}

.footer{
    background-color: #2F3642;
    color: white;
    padding: 20px 0;
    padding-left: 3000px;
    margin-left: -3000px;
    padding-right: 3000px;
    margin-right: -3000px;
}

.footer p{
     font-size: 16px;
}

.footer a{
    font-size: 16px;
    line-height: 22px;
}

.disclaimer-link{
    padding-bottom: 20px;
    padding-top: 15px;
}

.disclaimer-link a{
    font-size: 17px;
    font-family:Avenir;
}

.age-link{
    padding-bottom: 20px;
}

.age-link a{
    font-size: 17px;
    font-family:Avenir;
}


.margin-top{
    margin-top: 20px;
}

/******************** HEADER *************************/

.logo-container {
	font-size: 20px;
	text-align: center;
    float: left;
}

.logo-container-small {
    font-size: 20px;
    text-align: center;
    width: 350px;
    height: 50px;
    margin-left: auto;
    margin-right: auto;
}

.logo-container a{
	text-decoration: none;
}

.eth-logo, .cvl_logo{
    width: 200px;
}

.eth-logo-small, .cvl_logo{
    width: 200px;
    float: left;
    margin-right: 10px;
    margin-top: 5px;
}

.blinq-logo{
    width: 107px;
}

.blinq-logo-small{
    width: 107px;
    float: left;
    margin-left: 15px;
}


.plus{
    font-family: archerpro;
    color: black;
}


.plus-small{
    font-family: archerpro;
    color: black;
    float: left
}


.main-title{
    padding-top: 20px;
}

.main-hashtag {
    padding-bottom: 10px;
}

/******************** SHARING *************************/


.socialmediabutton, iframe, .fb-share-button{
    float:left;
    margin-right: 7px;
    margin-bottom: 20px;
    width: 65px;
    /*background-color: red;*/
}

.socialmedia_container{
    display:inline-block;
    height: 25px;
    width: 300px;
    margin: 20px 20px 0px 0px;
}

.whatsAppLink img, .mailLink img{
    vertical-align: super;
}

/* Micro adjustments for sharing buttons */
.fb-send, .fb-share-button {
    margin-top: -2px;
}

/******************** APP STORE *************************/


.btn{
    font-weight: 600;
    font-size: 18px;
    line-height: 25px;
    font-family: "avenirheavy";
    text-transform: uppercase;
}

.btn:hover {
    background-color: #FC3558;
    color: white;
    opacity: .8;
    transition: opacity .15s;
}

.btn-round, button.btn-round {
    width: 50px;
    height: 50px;
    border-radius: 50px;
    background-color: #2E3542;
    opacity: 1;
    color: #fff;
}

.btn-round:hover, button.btn-round:hover {
    color: #fff;
    opacity: .8;
}

.store-btn{
    float: right;
    width: 106px;
    margin-bottom: 20px;
}

.store-btn:hover {
    opacity: .8;
}

.store-btn-container{
    width: 110px;
    float: right;
}

.store-container, .logo-container {
    margin-top: 50px;
}

@media (min-width: 1440px) {
    .no-relative-lg {
        position: static;
    }
    .store-container, .logo-container {
        margin-top: 0;
        top: 20px;
        position: absolute;
    }
    .store-container {
        right: 30px;
    }
    .logo-container {
        left: 30px;
    }
    .store-btn-container{
        width: 260px;
    }
    .store-btn-container a img {
        margin-left: 20px;
    }
}

.store-btn-large-container{
    margin: 0 0 5px 0;
    margin-bottom: 15px;
}

.store-btn-large{
    width: 180px;
    float: left;
    margin-top: 20px;
    margin-bottom: 20px;
    transition: opacity .15s;
}

.store-btn-large:hover {
    opacity: .8;
}

.store-button-large-distance{
    margin-left: 20px;
}



/******************** BUTTONS *************************/


.main-button {
    width: 320px;
    color:white;
    margin-top: 30px;
    padding:15px;
    padding-top: 18px;
    margin:14px 0 12px;
    cursor: pointer;
    border: 0px solid transparent;
}


.upload-button{
    background-color:#FC3558;
    color:white;
}

.upload-button img{
    margin-right: 5px;
    margin-bottom: 3px;
}

#tryPhoto{
    background-color:#79939F;
    border:none;
}

#tryPhoto:after{

    content:"";
    position:absolute;
    border-width:15px 15px 0; /* vary these values to change the angle of the vertex */
    border-style:solid;
    display:block;
    width:0;
    top:0px; /* value = - border-top-width - border-bottom-width */
    right:47%; /* controls horizontal position */
    bottom:auto;
    left:auto;
    border-width:0 15px 15px; /* vary these values to change the angle of the vertex */
    border-color:#79939F transparent;
}

/******************** TEXT *************************/


.title{
    font-size: 50px;
    line-height: 41px;
}

.subtitle{
    margin-bottom: 40px;
}

.main-title{
    font-size: 40px;
    line-height: 46px;
}


/******************** BLINQ *************************/

.research-title{
    padding-top: 50px;
    padding-bottom: 35px;
}

.blinq-title{
    padding-left: 30px;
    padding-top: 30px;
    padding-bottom: 30px;
}

@media (min-width: 993px) and (max-width: 1200px) {
    .blinq-title {
        padding-left: 107px;
    }
}

@media (min-width: 768px) and (max-width: 992px) {
    .blinq-title {
        padding-left: 177px;
    }
    .store-btn-large{
        margin-top: 13px;
    }
}

.what-is{
    margin-top: 20px;
}

@media screen and (max-width: 992px) {
    .what-is{
        margin-top: 30px;
    }
}

.what-is img{
    float:left;
    margin-right: 20px;
}

.what-is p{
    display: flex;
    margin-bottom: 30px;
}

.blinq-phone{
    width: 212px;
    /* Pull up to align with title */
    margin-top: -8.4rem;
    margin-left: auto;
    margin-right: auto;
    display: block;
}

.blinq-icon{
    width: 40px;
    height: 40px;
    margin-top: 5px;
}

.blinq-subtitle{
    font-family: Avenir;
    font-weight: bold;
    font-size: 20px;
    line-height: 27px;
}

.blinq-text{
    font-family: Avenir;
    margin-bottom: 30px;
    font-size: 20px;
    line-height: 27px;
}

/******************** CONTACT *************************/



.contactPhoto{
    display:block;
    margin-left: auto;
    margin-right: auto;
    width: 283px;
    height: 283px;
    background-size: 283px 283px;
}

.contactLinks{
    display:table;
    margin-bottom: 35px;

}

.contactName{
    margin-top: 20px;
    margin-bottom: 10px;
    font-size: 18px;
    font-family: "avenirheavy";
}

.contactLinks a img {
    transition: opacity .15s;
}

.contactLinks a:hover img {
    opacity: .8;
}

.linkedIn{
    margin-right:25px;
}

.linkedIn, .googleScholar{
    width: 50px;
    height: 50px;
    border-radius: 50px;
    background-color:#2E3542;
}

.contactRasmus{
    background-image: url("../img/rasmus_@1x.jpg");
}

.contactRadu{
    background-image: url("../img/radu_@1x.jpg");
}

.contactLuc{
    background-image: url("../img/luc_@1x.jpg");
}

@media
(-webkit-min-device-pixel-ratio: 2),
(min-resolution: 192dpi) {
    .contactRasmus{
        background-image: url("../img/rasmus_@2x.jpg");
    }
    .contactRadu{
        background-image: url("../img/radu_@2x.jpg");
    }
    .contactLuc{
        background-image: url("../img/luc_@2x.jpg");
    }
}

/******************** MODAL *************************/

.progress {
    height: 30px;
}

.progress-bar {
    background-color: #FC3558;
    font-family: 'avenir';
    font-size: 16px;
    line-height: 30px;
}

.modal {
    /* Bootstrap injects padding into style */
    padding-right: 0px !important;
}

/* Rounded borders of Bootstrap are actually ugly */
.modal-content {
    -moz-box-shadow: none;
    -webkit-box-shadow: none;
    box-shadow: none;
    border-radius: 5px;
}

.modal-dialog {
    overflow: hidden;
    padding-top: 80px;
}

@media (max-width: 768px) {
    .modal-dialog {
        padding-top: 100px;
    }
}

.modal-header {
    border-bottom: none;
    padding: 20px;
    padding-bottom: 0px;
}

hr {
    width: 30%;
    max-width: 120px;
    height: 1px;
    border-color: #2E3542;
    margin-top: 20px;
    margin-bottom: 25px;
}

.modal-backdrop {
    background: linear-gradient(#AAEBF1, #FC3558);
}

.modal-body {
    padding: 0px 40px;
}

.modal-footer {
    border-top: none;
    padding: 20px;
    padding-top: 0px;
    text-align: center;
}

.modal-paper-text {
    margin-left: 20px;
    color: #2E3542;
}

.modal-title, .modal-paper-download {
    font-size: 18px;
    line-height: 25px;
    font-family: "avenirheavy";
    text-transform: uppercase;
    padding: 0 60px;
    color: #2E3542;
    text-align: center;
}

/******************** PAPER *************************/

.paperDescription{
    font-size:14px; display:none;
    text-align: justify;
    margin-bottom: 40px;
    padding:0 20px;
}


.paper-title{
    font-size: 18px;
    line-height: 25px;
    font-family: "avenirheavy";
    text-transform: uppercase;
    padding: 0 20px;
    color: #2E3542;
}

.paper-authors, .paper-source {
}

.paper-authors{
    margin-top: 10px;
    padding:0 20px;
}

.paper-source{
    padding:0 20px;
    margin-bottom: 10px;
}

.paperSmall{
    font-size:15px;
}

.paperSmall a{
    font-size:15px;
}

.paper-links {
    margin-top: 30px;
}

/******************** MEDIA *************************/
@media only screen and (max-width : 992px) {

    .paper-container {
        margin-top: 30px;
    }

}

@media only screen and (min-width: 769px) {
    .store-btn-large-container{
        margin-top: -67px;
    }
}

@media only screen and (min-width: 992px) {
    .store-btn-large-container{
        margin-top: -72px;
    }
}

/* Medium Devices, Desktops */
@media only screen and (max-width: 768px) {

    body {
        padding-top:15px;
    }

    #retryButton {
        margin-top: 15px;
        width: 270px;
    }

    .title{
        font-size: 34px;
    }

    .research-title{
        padding-top: 40px;
        padding-bottom: 30px;
    }

    .blinq-title {
        padding-top: 20px;
        padding-bottom: 20px;
    }

    .subtitle{
        margin-bottom: 20px;
    }

    .gray-container{
        padding-bottom: 20px;
    }

    .logo-container {
        float: none;
    }

    .upload-button{
        margin-top: 0px;
    }

    .main-title{
        padding-top: 0px;
        margin-top: 15px;
        margin-bottom: 15px;
        font-size: 30px;
        line-height: 1.2em;
    }

    .modal-title {
        padding: 0 20px;
    }

    /* STORE BUTTON */

    .store-btn-large-container{
        width: 168px;
        height: 168px;
        margin-left: auto;
        margin-right: auto;
        display: block;
    }


    .store-button-large-distance{
        margin-left: 0px;
    }


    /* BLINQ */


    .blinq-subtitle{
        font-size: 20px;
        text-align: center;
    }

    .blinq-text{
        text-align: center;
    }

    .blinq-text a{
        font-size: 18px;
    }

    .what-is img{
        display: block;
        margin-right: auto;
        margin-left: auto;
        float:none;
        margin-bottom: 10px;
    }

    .blinq-phone{
        margin-top: 10px;
    }


    /* LOGO */

    .logo-container-small {
        font-size: 18px;
        text-align: center;
        width: 280px;
        height: 30px;
        margin-left: auto;
        margin-right: auto;
    }

    .eth-logo-small, .cvl_logo{
        width: 150px;
        float: left;
        margin-right: 5px;
        margin-top: 0px;
    }


    .blinq-logo-small{
        width: 85px;
        float: left;
        margin-left: 25px;
    }

    .socialmedia_container{
        margin: 17px 0px 0px 0px;
    }
}




/* Extra Small Devices, Phones */
@media only screen and (max-width : 450px) {

    .socialmediabutton, iframe, .fb-share-button{
        margin-right: 5px;
    }

}


/******************** ORDER *************************/

#imageUploadInput{
    visibility:hidden;
    height: 7px;
}

/******************** AGE DISCLAIMER *************************/

/* Disclaimer styles are injected by script and can only be overwritten with important */

.cc_banner-wrapper {
    height: 65px !important;
    animation-duration: 0.1s;
    -webkit-animation-duration: 0.1;
    -moz-animation-duration: 0.1;
    -o-animation-duration: 0.1;
}

.cc_container {
    background: #2E3542 !important;
}

.cc_container .cc_message {
    margin-top: 0px !important;
    font-size: 16px !important;
    line-height: 22px !important;
    text-align: center !important;
}

.cc_container .cc_btn {
    background-color: #FC3558 !important;
    font-family: 'avenirheavy' !important;
    font-size: 16px !important;
    line-height: 22px !important;
    color: #fff !important;
    border-radius: 4px !important;
    text-transform: uppercase !important;
}

.cc_container .cc_btn, .cc_container .cc_btn:visited {
    width: 22px !important;
    height: 22px !important;
    border-radius: 50px !important;
    background-color: #2E3542 !important;
    opacity: 1 !important;
    color: #fff !important;
    margin-top: -7px !important;
}

.cc_more_info {
    color: #79939F !important;
}

/******************** SLIDER *************************/

.flickity-prev-next-button {
  background: #2E3542;
  width: 50px;
  height: 50px;
}

.flickity-prev-next-button svg {
}

.flickity-prev-next-button .arrow {
  fill: white;
}

.flickity-prev-next-button:hover {
  background: #2E3542;
  opacity: .8;
}

.flickity-prev-next-button.previous {
    left: 30px;
}

.flickity-prev-next-button.next {
    right: 30px;
}

.gallery {
  height: 320px;
}

.gallery img {
  display: block;
  height: 100%;
  width: 100%;
  transition: opacity .15s;
  opacity: .8;
  position: relative;
  z-index: -1000;
}

.gallery-cell {
  height: 320px;
  width: 300px;
  border-top: 10px solid transparent;
  border-bottom: 10px solid transparent;
  background: url('/img/gradient.png') center center no-repeat;
  background-clip: padding-box;
}

.gallery-cell.is-selected {
  width: 320px;
  height: 320px;
  margin-left: -10px;
  margin-right: -10px;
  border-top: none;
  border-bottom: none;
}

.gallery-cell.is-selected img {
    opacity: 1;
    position: relative;
    z-index: 1000;
}

.gallery-container {
    width: 100%;
    margin-top: 10px;
    margin-bottom: 10px;
}


@media only screen and (max-width : 1200px) {
    .main-button {
        width: 250px;
        padding-top: 14px;
        padding-bottom: 10px;
    }
}


@media screen and (max-width: 1200px) {
  .gallery {
    height: 250px;
  }

  .gallery-cell {
    height: 250px;
    width: 230px;
  }

  .gallery-cell.is-selected {
    width: 250px;
    height: 250px;
  }
}
