/*! HTML5 Boilerplate v5.2.0 | MIT License | https://html5boilerplate.com/ */

/*
 * What follows is the result of much research on cross-browser styling.
 * Credit left inline and big thanks to Nicolas Gallagher, Jonathan Neal,
 * Kroc Camen, and the H5BP dev community and team.
 */

/* ==========================================================================
   Base styles: opinionated defaults
   ========================================================================== */

html {
    overflow-x: hidden;
}

body {
    font-family: 'Inter', sans-serif;
    color: #2D1F40;
    overflow-x: hidden;
}

.blurred{
    filter: blur(8px);
  -webkit-filter: blur(8px);
}

/*
 * Remove text-shadow in selection highlight:
 * https://twitter.com/miketaylr/status/12228805301
 *
 * These selection rule sets have to be separate.
 * Customize the background color to match your design.
 */

::-moz-selection {
    background: #b3d4fc;
    text-shadow: none;
}

::selection {
    background: #b3d4fc;
    text-shadow: none;
}

/*
 * Remove the gap between audio, canvas, iframes,
 * images, videos and the bottom of their containers:
 * https://github.com/h5bp/html5-boilerplate/issues/440
 */

audio,
canvas,
iframe,
img,
svg,
video {
    vertical-align: middle;
}

/*
 * Remove default fieldset styles.
 */

fieldset {
    border: 0;
    margin: 0;
    padding: 0;
}

/*
 * Allow only vertical resizing of textareas.
 */

textarea {
    resize: vertical;
}

/* ==========================================================================
   Browser Upgrade Prompt
   ========================================================================== */

.browserupgrade {
    margin: 0.2em 0;
    background: #ccc;
    color: #000;
    padding: 0.2em 0;
}

/* ==========================================================================
   Custom styles
   ========================================================================== */

/* ======================================
   Utilities
   ====================================== */

.mb-10, .my-10 {
    margin-bottom: 6rem !important;
}

.w-60 {
    width: 60% !important;
}

@media screen and (min-width: 768px){

    .w-md-60 {
        width: 60% !important;
    }

}

@media screen and (min-width: 992px){

    .w-lg-60 {
        width: 60% !important;
    }

    .w-lg-100 {
        width: 100% !important;
    }

}


/* ======================================
   Bootstrap 5 columns grid
   ====================================== */

.col-5r,
.col-sm-5r,
.col-md-5r,
.col-lg-5r,
.col-xl-5r {
    position: relative;
    width: 100%;
    padding-right: 15px;
    padding-left: 15px;
}

.col-5r {
    -ms-flex: 0 0 20%;
    flex: 0 0 20%;
    max-width: 20%;
}

@media (min-width: 576px) {
    .col-sm-5r {
        -ms-flex: 0 0 20%;
        flex: 0 0 20%;
        max-width: 20%;
    }
}

@media (min-width: 768px) {
    .col-md-5r {
        -ms-flex: 0 0 20%;
        flex: 0 0 20%;
        max-width: 20%;
    }
}

@media (min-width: 992px) {
    .col-lg-5r {
        -ms-flex: 0 0 20%;
        flex: 0 0 20%;
        max-width: 20%;
    }
}

@media (min-width: 1200px) {
    .col-xl-5r {
        -ms-flex: 0 0 20%;
        flex: 0 0 20%;
        max-width: 20%;
    }
}

/* ======================================
   Bootstrap 8 columns grid
   ====================================== */

.col-8r,
.col-sm-8r,
.col-md-8r,
.col-lg-8r,
.col-xl-8r {
    position: relative;
    width: 100%;
    padding-right: 15px;
    padding-left: 15px;
}

.col-8r {
    -ms-flex: 0 0 12.5%;
    flex: 0 0 12.5%;
    max-width: 12.5%;
}

@media (min-width: 576px) {
    .col-sm-8r {
        -ms-flex: 0 0 12.5%;
        flex: 0 0 12.5%;
        max-width: 12.5%;
    }
}

@media (min-width: 768px) {
    .col-md-8r {
        -ms-flex: 0 0 12.5%;
        flex: 0 0 12.5%;
        max-width: 12.5%;
    }
}

@media (min-width: 992px) {
    .col-lg-8r {
        -ms-flex: 0 0 12.5%;
        flex: 0 0 12.5%;
        max-width: 12.5%;
    }
}

@media (min-width: 1200px) {
    .col-xl-8r {
        -ms-flex: 0 0 12.5%;
        flex: 0 0 12.5%;
        max-width: 12.5%;
    }
}

/* ======================================
   Bootstrap 10 columns grid
   ====================================== */

.col-10r,
.col-sm-10r,
.col-md-10r,
.col-lg-10r,
.col-xl-10r {
    position: relative;
    width: 100%;
    padding-right: 15px;
    padding-left: 15px;
}

.col-10r {
    -ms-flex: 0 0 10%;
    flex: 0 0 10%;
    max-width: 10%;
}

@media (min-width: 576px) {
    .col-sm-10r {
        -ms-flex: 0 0 10%;
        flex: 0 0 10%;
        max-width: 10%;
    }
}

@media (min-width: 768px) {
    .col-md-10r {
        -ms-flex: 0 0 10%;
        flex: 0 0 10%;
        max-width: 10%;
    }
}

@media (min-width: 992px) {
    .col-lg-10r {
        -ms-flex: 0 0 10%;
        flex: 0 0 10%;
        max-width: 10%;
    }
}

@media (min-width: 1200px) {
    .col-xl-10r {
        -ms-flex: 0 0 10%;
        flex: 0 0 10%;
        max-width: 10%;
    }
}

/* ======================================
   Container
   ====================================== */

.container,
.container-fluid,
.container-lg,
.container-md,
.container-sm,
.container-xl {
    padding-right: 31px;
    padding-left: 31px;
}

@media (min-width: 992px) {

    .container,
    .container-fluid,
    .container-lg,
    .container-md,
    .container-sm,
    .container-xl {
        padding-right: 15px;
        padding-left: 15px;
    }

}

/* ======================================
   Intro
   ====================================== */

#main {
    position: relative;
    z-index: 99;
}

/* ======================================
   Headings
   ====================================== */

.h2,
h2 {
    font-size: 30px;
    line-height: 32px;
    font-weight: 800;
    text-transform: uppercase;
}

.h3,
h3 {
    font-size: 28px;
    line-height: 30px;
    font-weight: 200;
    text-align: center;
    margin-bottom: 30px;
}

.h4,
h4 {
    font-size: 15px;
    line-height: 20px;
    font-weight: 700;
    margin-bottom: 0;
}

.bold-left{
    text-align: left;
    font-weight: bold;
}

@media screen and (min-width: 768px){

    .h2,
    h2 {
        font-size: 40px;
        line-height: 40px;
    }

    .h3,
    h3 {
        font-size: 40px;
        line-height: 40px;
        margin-bottom: 40px;
    }


}

/* ======================================
   Typography
   ====================================== */

p {
    color: #2D1F40;
    font-size: 15px;
    line-height: 20px;
    font-weight: 300;
}

p.text-small {
    font-size: 14px !important;
    line-height: 18px !important;
}

.spaced {
    margin-bottom: 46px;
}

.spaced p {
    line-height: 30px;
    font-size: 18px;
}

a:link,
a:active,
a:visited {
    color: #7A5CBE;
    text-decoration: underline;
}

.hero-caption a:link,
.hero-caption a:active,
.hero-caption a:visited {
    color: #A2EFEA;
}

.white{
    color:#ffffff;
}

.bold{
    font-weight: bold;
}

.ft-25{
    font-size: 25px;
}

.ft-35{
    font-size: 35px;
}

.notrans{
    text-transform: none;
}

.workshop-breadcrumb a:link,
.workshop-breadcrumb a:active,
.workshop-breadcrumb a:visited {
    color: #2D1F40;
    text-decoration: none;
}

/* ======================================
   Buttons
   ====================================== */

a.btn,
.btn {
    font-weight: 700;
    padding: 16px 34px;
    font-size: 15px;
    line-height: 15px;
    border-radius: 30px;
    text-transform: uppercase;
    text-decoration: none;
}

.btn-subtitle {
    text-transform: initial;
}

.btn.btn-with-padding {
    padding-left: 87px;
    padding-right: 87px;
}

a.btn-primary:link,
a.btn-primary:active,
a.btn-primary:visited,
.btn-primary,
.btn-primary.disabled,
.btn-primary:disabled {
    color: #2D1F40;
    background-color: #A2EFEA;
    border-color: #A2EFEA;
}

a.btn-light-blue:link,
a.btn-light-blue:active,
a.btn-light-blue:visited,
.btn-light-blue,
.btn-light-blue.disabled,
.btn-light-blue:disabled {
    color: #2D1F40;
    background-color: #A2EFEA;
    border-color: #A2EFEA;
    padding: 0;
    padding-top: 17px;
    width: 50px;
    height: 50px;
    border-radius: 25px;
}

.btn-primary.disabled,
.btn-primary:disabled {
    opacity: 0.5;
}

.btn-primary:not(:disabled):not(.disabled):hover,
.btn-primary:not(:disabled):not(.disabled).hover,
.btn-primary:not(:disabled):not(.disabled).focus,
.btn-primary:not(:disabled):not(.disabled):focus,
.btn-primary:not(:disabled):not(.disabled).active,
.btn-primary:not(:disabled):not(.disabled):active,
.show > .btn-primary.dropdown-toggle {
    color: #A2EFEA;
    background-color: #2D1F40;
    border-color: #2D1F40;
    box-shadow: none !important;
}

a.btn-light:link,
a.btn-light:active,
a.btn-light:visited,
.btn-light,
.btn-light.disabled,
.btn-light:disabled {
    color: #2D1F40;
    background-color: #FFFFFF;
    border-color: #FFFFFF;
}

.btn-light.disabled,
.btn-light:disabled {
    opacity: 0.5;
}

.btn-light:not(:disabled):not(.disabled):hover,
.btn-light:not(:disabled):not(.disabled).hover,
.btn-light:not(:disabled):not(.disabled).focus,
.btn-light:not(:disabled):not(.disabled):focus,
.btn-light:not(:disabled):not(.disabled).active,
.btn-light:not(:disabled):not(.disabled):active,
.show > .btn-light.dropdown-toggle {
    color: #FFFFFF;
    background-color: #2D1F40;
    border-color: #2D1F40;
    box-shadow: none !important;
}

a.btn-light-border:link,
a.btn-light-border:active,
a.btn-light-border:visited,
.btn-light-border,
.btn-light-border.disabled,
.btn-light-border:disabled {
    color: #FFFFFF;
    background-color: transparent;
    border-color: #FFFFFF;
}

.btn-light-border.disabled,
.btn-light-border:disabled {
    opacity: 0.5;
}

.btn-light-border:not(:disabled):not(.disabled):hover,
.btn-light-border:not(:disabled):not(.disabled).hover,
.btn-light-border:not(:disabled):not(.disabled).focus,
.btn-light-border:not(:disabled):not(.disabled):focus,
.btn-light-border:not(:disabled):not(.disabled).active,
.btn-light-border:not(:disabled):not(.disabled):active,
.show > .btn-light-border.dropdown-toggle {
    color: #2D1F40;
    background-color: #A2EFEA;
    border-color: #FFFFFF;
    box-shadow: none !important;
}

a.btn-dark:link,
a.btn-dark:active,
a.btn-dark:visited,
.btn-dark,
.btn-dark.disabled,
.btn-dark:disabled {
    color: #A2EFEA;
    background-color: #2D1F40;
    border-color: #2D1F40;
}

.btn-dark.disabled,
.btn-dark:disabled {
    opacity: 0.5;
}

.btn-dark:not(:disabled):not(.disabled):hover,
.btn-dark:not(:disabled):not(.disabled).hover,
.btn-dark:not(:disabled):not(.disabled).focus,
.btn-dark:not(:disabled):not(.disabled):focus,
.btn-dark:not(:disabled):not(.disabled).active,
.btn-dark:not(:disabled):not(.disabled):active,
.show > .btn-dark.dropdown-toggle {
    color: #2D1F40;
    background-color: #A2EFEA;
    border-color: #A2EFEA;
    box-shadow: none !important;
}

a.btn-dark:link,
a.btn-dark:active,
a.btn-dark:visited,
.btn-dark,
.btn-dark.disabled,
.btn-dark:disabled {
    color: #A2EFEA;
    background-color: #2D1F40;
    border-color: #2D1F40;
}

.btn-dark.disabled,
.btn-dark:disabled {
    opacity: 0.5;
}

.btn-dark:not(:disabled):not(.disabled):hover,
.btn-dark:not(:disabled):not(.disabled).hover,
.btn-dark:not(:disabled):not(.disabled).focus,
.btn-dark:not(:disabled):not(.disabled):focus,
.btn-dark:not(:disabled):not(.disabled).active,
.btn-dark:not(:disabled):not(.disabled):active,
.show > .btn-dark.dropdown-toggle {
    color: #2D1F40;
    background-color: #A2EFEA;
    border-color: #A2EFEA;
    box-shadow: none !important;
}

a.btn-purple:link,
a.btn-purple:active,
a.btn-purple:visited,
.btn-purple,
.btn-purple.disabled,
.btn-purple:disabled {
    color: #2D1F40;
    background-color: #D7D1DE;
    border-color: #D7D1DE;
}

.btn-purple.disabled,
.btn-purple:disabled {
    opacity: 0.5;
}

.btn-purple:not(:disabled):not(.disabled):hover,
.btn-purple:not(:disabled):not(.disabled).hover,
.btn-purple:not(:disabled):not(.disabled).focus,
.btn-purple:not(:disabled):not(.disabled):focus,
.btn-purple:not(:disabled):not(.disabled).active,
.btn-purple:not(:disabled):not(.disabled):active,
.show > .btn-purple.dropdown-toggle {
    color: #2D1F40;
    background-color: #A2EFEA;
    border-color: #A2EFEA;
    box-shadow: none !important;
}

a.btn-large,
.btn-large {
    width: 100%;
}

a.btn-large-limited,
.btn-large-limited {
    width: 80%;
}

@media screen and (min-width: 576px){

    a.btn-large,
    .btn-large {
        width: auto;
        padding-left: 87px;
        padding-right: 87px;
    }

}

/* ======================================
   Shadow
   ====================================== */

.shadow {
    position: relative;
    box-shadow: 12px 12px 20px #0000001A !important;
}

/* ======================================
   Cards
   ====================================== */

.card {
    border: 0;
    border-radius: 0;
    box-shadow: -12px 0px 12px rgba(0, 0, 0, 0.1);
    margin-bottom: 30px;
}

.card-flat {
    box-shadow: none;
}

.card-shadow {
    z-index: 999;
    box-shadow: 0 0px 0px 0px transparent, 0 0px 0px 0px transparent, 12px 0 15px -4px rgba(0, 0, 0, 0.1), -12px 0 15px -4px rgba(0, 0, 0, 0.1);
}

.card .card-header {
    position: relative;
    background-color: #A2EFEA;
    text-align: center;
    height: 110px;
}

.card-header:first-child {
    border-radius: 0;
}

.card .card-header h4 {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    color: #1A1A1A;
}

.card .dark-header {
    background-color: #2D1F40;
}

.card .dark-header h4 {
    color: #A2EFEA;
}

.card .card-header h4 .thin{
    font-weight: 300;
}

.card .card-body {
    padding: 0;
}

.card .card-body .list-group-item {
    position: relative;
    text-align: center;
    border-top: 0;
    border-bottom: 1px dotted #2D1F40;
}

.card .card-body .list-group-item:last-child {
    border-bottom: 0;
}

.card .card-body .card-headings .list-group-item {
    color: #2D1F40;
    /*font-weight: 200;*/
    font-size: 13px;
    padding: 20px 0;
}

.card .card-body .card-check .mobile-heading {
    clear: both;
    color: #2D1F40;
    /*font-weight: 200;*/
    font-size: 13px;
}

.card .card-body .card-check .item-description {
    clear: both;
    color: #2D1F40;
    /*font-weight: 200;*/
    font-size: 13px;
    text-transform: uppercase;
}

.card .card-body .list-group-item .fas {
    font-size: 23px;
    color: #A2EFEA;
}

.card .card-body .card-cta {
    position: relative;
    text-align: center;
    height: 90px;
}

.card .card-body .card-cta .btn {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    white-space: nowrap;
    padding: 16px 60px;
}

@media screen and (min-width: 768px){

    .card .list-group-item .card-heading {
    }

    .card .list-group-item {
        height: 60px;
    }

    .card-zoomable:hover .card-body .list-group-item {
        height: 70px;
    }

    #sponsor-advantages .card .list-group-item {
        height: 140px;
    }

    .card .card-heading,
    .card .card-body .card-check {
        width: 90%;
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
    }

}

@media screen and (min-width: 992px){

    #sponsor-advantages .card .list-group-item {
        height: 100px;
    }

}


/* ======================================
   Backgrounds
   ====================================== */

.bg-dark {
    background-color: #1A1A1A;
}

.bg-green {
    background-color: #E6FAF9;
}

.bg-purple {
    background-color: #2D1F40;
}

.bg-purple h3 {
    color: #A2EFEA;
}

.bg-purple h4 {
    color: #A2EFEA;
}

.bg-purple p {
    color: #D7D1DE;
}

.bg-purple2{
    background-color: #D7D1DE;
}

.bg-purple p a:link,
.bg-purple p a:active,
.bg-purple p a:visited {
    color: #A2EFEA;
    text-decoration: underline;
}

.bg-overlay-purple:before {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    background-color: #2D1F40;
    mix-blend-mode: color;
}

/* ======================================
   Navbar
   ====================================== */

.navbar-dark {
    background-color: transparent;
}

.homepage #main-menu.top {
    background-color: transparent;
}

#main-menu {
    background-color: #2D1F40;
    -webkit-transition: background-color .3s;
    -moz-transition: background-color .3s;
    -o-transition: background-color .3s;
    transition: background-color .3s;
}

#overlay-menu .navbar,
#main-menu.navbar {
    padding: 16px 31px;
}

#main-menu .navbar-collapse {
    margin-top: 20px;
}

.navbar-brand {
    padding: 0;
}

.navbar-brand img {
    max-width: 70px;
}

.navbar-collapse {
    display: flex;
    flex-basis: auto;
}

#main-menu .nav-item {
    margin-left: 10px;
    margin-bottom: 10px;
}

.hamburger {
    cursor: pointer;
    width: 33px;
}

.hamburger .menu-bar-1,
.hamburger .menu-bar-2,
.hamburger .menu-bar-3 {
    background-color: #A2EFEA;
    height: 2px;
    margin-bottom: 7px;
    float: right;
}

.hamburger .menu-bar-1 {
    width: 33px;
}

.hamburger .menu-bar-2 {
    width: 25px;
}

.hamburger .menu-bar-3 {
    width: 13px;
}

@media screen and (min-width: 768px){

    #main-menu .nav-item {
        margin-bottom: 0;
    }

}

@media screen and (min-width: 992px){

    .hamburger .menu-bar-1,
    .hamburger .menu-bar-2,
    .hamburger .menu-bar-3 {
        height: 4px;
        margin-bottom: 5px;
    }

    #main-menu .navbar-collapse {
        margin-top: 0;
    }

    .navbar-dark {
        background-color: #2D1F40 !important;
    }

    #overlay-menu .navbar,
    #main-menu.navbar {
        padding: 22px 47px;
    }

    .homepage #overlay-menu .navbar,
    .homepage #main-menu.navbar {
        padding: 23px 47px;
    }

    .navbar-brand img {
        max-width: none;
    }

    .navbar-brand .iab-logo,
    .navbar-brand .metaverse-logo {
        display: inline-block;
        float: left;
    }

    .navbar-brand .iab-logo {
        width: 60px;
    }

    .navbar-brand .metaverse-logo {
        width: 54px;
    }

    .homepage .navbar-brand .iab-logo {
        width: 75px;
        -webkit-transition: width .3s;
        -moz-transition: width .3s;
        -o-transition: width .3s;
        transition: width .3s;
    }

    .homepage #main-menu.top .navbar-brand .iab-logo {
        width: 135px;
    }


}

@media screen and (min-width: 1200px){

    #overlay-menu .navbar,
    #main-menu.navbar {
        padding: 20px 47px;
    }

    #main-menu .nav-item {
        margin-left: 35px;
    }

    .navbar-brand .iab-logo {
        width: 70px;
    }

    .navbar-brand .metaverse-logo {
        width: 64px;
    }


}


/* =====================
   Internal pages
   ===================== */

.question{
    font-weight: bold;
}

.navbar-internal {
    padding: 23px 3.5vw;
}

.navbar-internal .navbar-brand img {
    max-width: 65px;
}

.img-container{
    background-color: white;
    position: relative;
    width: 90%;
    margin: auto;
    margin-bottom: 15%;
    -webkit-box-shadow: 10px 10px 19px -13px rgba(168,163,168,1);
    -moz-box-shadow: 10px 10px 19px -13px rgba(168,163,168,1);
    box-shadow: 10px 10px 19px -13px rgba(168,163,168,1);
}

.img-container:after {
  content: "";
  display: block;
  padding-bottom: 100%;
}

.img-container.rect:after {
  padding-bottom: 50%;
}

.img-container img{
    position: absolute;
    top:50%;
    left: 50%;
    max-width: 75%;
    transform: translate(-50%,-50%);
}

.img-container-full img{
    max-width: 100%;
}

/* ======================================
   Menu
   ====================================== */

#overlay-menu {
    position: fixed;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    background-color: rgba(45, 31, 64, 0.9);
    z-index: 1200;
}

#overlay-menu .menu-items {
    position: relative;
    width: 100%;
    /*top: 50%;*/
    /*left: 50%;*/
    /*transform: translate(-50%, -40%);*/
    text-align: center;
    padding-left: 0;
}

#overlay-menu .menu-form {
    display: none;
}

#overlay-menu .menu-items li {
    list-style-type: none;
    margin-bottom: 15px;
}

#overlay-menu .menu-items li a:link,
#overlay-menu .menu-items li a:active,
#overlay-menu .menu-items li a:visited {
    font-weight: 300;
    font-size: 18px;
    line-height: 42px;
    color: #FFFFFF;
    text-decoration: none;
}

#overlay-menu .menu-items li a:hover {
    font-weight: bold;
    font-size: 35px;
    line-height: 42px;
    color: #A2EFEA;
    text-decoration: none;
    -webkit-transition: color .3s, font-size .3s;
   -moz-transition: color .3s, font-size .3s;
     -o-transition: color .3s, font-size .3s;
        transition: color .3s, font-size .3s;
}

#main-menu-close {
    width: 26px;
    height: 26px;
    position: relative;
    cursor: pointer;
    margin-top: 10px;
    z-index: 99;
}

#main-menu-close:before,
#main-menu-close:after {
    position: absolute;
    display: block;
    right: 11px;
    top: -2px;
    content: ' ';
    height: 33px;
    width: 2px;
    background-color: #A2EFEA;
}

#main-menu-close:before {
    transform: rotate(45deg);
}

#main-menu-close:after {
    transform: rotate(-45deg);
}

@media screen and (min-width: 768px){

    #main-menu-close {
        /*top: 30px;*/
        /*right: 30px;*/
    }

    #overlay-menu .menu-items {
        /*transform: translate(-50%, -50%);*/
    }

    #overlay-menu .menu-items li {
        list-style-type: none;
        margin-bottom: 54px;
    }

}

@media screen and (min-width: 992px){

    #overlay-menu:before {
        content: "";
        position: absolute;
        top: 50%;
        right: 0;
        transform: translate(0, -50%);
        width: 308px;
        height: 460px;
        background-image: url("../img/triangolo_punti.png");
        background-size: cover;
    }

    #overlay-menu .menu-items {
        position: absolute;
        width: 100%;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -40%);
        text-align: center;
        padding-left: 0;
    }

    #main-menu-close:before,
    #main-menu-close:after {
        width: 4px;
    }

}

/* ======================================
   Mobile menu buttons
   ====================================== */

.mobile-menu-buttons {
    background-color: #2D1F40;
    padding-top: 16px;
    padding-bottom: 9px;

}

.mobile-menu-buttons .nav-item {
    width: 244px;
    margin-bottom: 26px;
}

/* ======================================
   Hero
   ====================================== */

.hero {
    /*background-position: center center;*/
    background-position: 50% center;
    background-color: #2D1F40;
    background-repeat: no-repeat;
    /*background-size: cover;*/
    background-size: auto 100%;
    width: 100%;
    position: relative;
    color: #FFFFFF;
    margin-top: 90px;
}

.homepage .hero {
    margin-top: 0;
}

.hero-page {
    height: 120vw;
    background-size: cover;
}

.home-hero {
    background-image: url("../img/home-hero-bg.jpg");
    background-position: calc(50% + 30px) -100px;
    /*height: 100vh;*/
    /*padding-bottom: 105px;*/
}

.homepage .hero:before {
    content: "";
    position: absolute;
    top: -49px;
    right: -45px;
    background-image: url("../img/Logo_Bolla.png");
    background-size: cover;
    width: 154px;
    height: 154px;
}

.sponsor-form-hero {
    background-image: url("../img/sponsor-form-hero-bg.jpg");
    background-position: calc(50% - 50px) 0;
}

.evento_speciale .hero {
    background-image: url("../img/evento-speciale-hero-mobile-bg.jpg");
}

.special-offer .hero {
    background-image: url("../img/special-offer-mobile-hero-bg.jpg");
}

.conferenza .hero {
    background-image: url("../img/conferenza-mobile-hero-bg.jpg");
}

.workshop-agenda .hero,
.workshop .hero {
    background-image: url("../img/workshop-mobile-hero-bg.jpg");
}

.iab_game_changer .hero {
    background-image: url("../img/iab-game-changer-mobile-hero-bg.jpg");
}

.networking .hero {
    background-image: url("../img/networking-mobile-hero-bg.jpg");
}

.speaker-detail .hero {
    background-image: url("../img/speaker-detail-mobile-hero-bg.jpg");
}

.faq .hero {
    background-image: url("../img/faq-mobile-hero-bg.jpg");
}

.hero-x-desktop-gradient {
    height: 100%;
}

.hero-x-gradient {
    height: 100%;
    background: transparent linear-gradient(90deg, #2D1F40 0%, #1F1F1F00 100%) 0% 0% no-repeat padding-box;
}

.hero-y-mobile-gradient,
.hero-y-gradient {
    height: 100%;
    background: transparent linear-gradient(0, #2D1F40 0%, #1F1F1F00 100%) 0% 0% no-repeat padding-box;
}

.homepage .hero-x-gradient {
    height: calc(100% + 4px);
}

.homepage .hero-y-gradient {
    height: calc(100% + 4px);
}

.sponsor-form-hero:after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translate(-50%, 0);
    width: 300px;
    height: 200px;
    background-image: url("../img/triangolo_punti_h.png");
    background-size: contain;
    background-position: center;
    background-repeat: no-repeat;
}

.sponsor_form .hero:before {
    content: "";
    position: absolute;
    top: 40px;
    left: 20px;
    width: 177px;
    height: 143px;
    background-image: url("../img/Logo_Bussola.png");
    background-repeat: no-repeat;
    background-size: contain;
    z-index: 10;
}

.hero-caption {
    position: absolute;
    bottom: 5%;
    width: 100%;
    /*transform: translate(0, -50%);*/
}

.home-hero .hero-caption {
    padding-top: 100px;
    position: relative;
    top: auto;
    transform: none;
}

.sponsor-form-hero .hero-caption {
    position: relative;
    padding-top: 230px;
    padding-bottom: 230px;
    transform: none;
}

.hero-caption h1 {
    color: #A2EFEA;
    font-size: 30px;
    line-height: 32px;
    font-weight: 800;
    margin-bottom: 26px;
}

.hero-caption h2 {
    color: #A2EFEA;
    text-transform: none;
    margin-bottom: 19px;
}

.hero-caption h3 {
    color: #A2EFEA;
    text-align: left;
    font-size: 25px;
    line-height: 50px;
}

.hero-caption p {
    color: #FFFFFF;
}

.hero-caption ul {
    font-size: 15px;
    line-height: 20px;
    font-weight: 300;
    text-transform: uppercase;
    padding-left: 15px;
}

.hero-date {
    margin-bottom: 19px;
}

.hero-date .days,
.hero-date .month,
.hero-date .year {
    color: #A2EFEA;
    font-weight: 900;
    text-align: left;
}

.hero-date .days {
    font-size: 25px;
    line-height: 30px;
}

.hero-date .month {
    font-size: 20px;
    line-height: 24px;
    color: #FFFFFF;
    text-transform: uppercase;
    font-weight: 300;
}

.hero-date .year {
    font-size: 37px;
    line-height: 45px;
    letter-spacing: 2.92px;
}

.hero-date .online {
    font-size: 20px;
    line-height: 24px;
    color: #FFFFFF;
    text-transform: uppercase;
    font-weight: 300;
    letter-spacing: 6.5px;
}

.anchor-btn {
    display: none;
}

.iab_game_changer-logos {
    position: relative;
    background-color: #2D1F40;
}

.iab_game_changer-logos:before {
    position: absolute;
    content: "";
    top: 0;
    left: 50%;
    background-image: url("../img/triangolo_punti_h.png");
    background-size: cover;
    transform: translate(-50%, 0) scale(-1);
    width: 60vw;
    height: 40vw;
}

.iab-logo-rounded {
    width: 148px;
    height: 148px;
    background-color: #FFFFFF;
    border-radius: 50%;
    margin: 0 auto;
}

.powered-by > * {
    display: block;
}

.powered-by {
    font-size: 18px;
    font-weight: bold;
    color: #FFFFFF;
}

@media screen and (min-width: 576px){

    .iab_game_changer-logos:before {
        width: 50vw;
        height: 33vw;
    }

}

@media screen and (min-width: 768px){

    .iab_game_changer-logos:before {
        width: 40vw;
        height: 26vw;
    }

    .conferenza .hero:before {
        display: none;
    }

    .hero-caption {
        top: 50%;
        bottom: auto;
        transform: translate(0, -50%);
    }


}

@media screen and (min-width: 992px){

    .hero-x-desktop-gradient {
        height: 100%;
        background: transparent linear-gradient(90deg, #2D1F40 0%, #1F1F1F00 100%) 0% 0% no-repeat padding-box;
    }

    .hero-y-mobile-gradient {
        background: none;
    }

    .homepage .hero-x-gradient {
        height: calc(100% + 4px);
    }

    .homepage .hero-y-gradient {
        height: calc(100% + 4px);
    }

    .hero-x-gradient {
        height: 100%;
    }

    .homepage .hero-x-gradient {
        height: calc(100% + 4px);
    }

    .hero-y-gradient {
        height: 100%;
    }

    .evento_speciale .hero {
        background-image: url("../img/evento-speciale-hero-bg.jpg");
    }

    .special-offer .hero {
        background-image: url("../img/special-offer-hero-bg.jpg");
    }

    .conferenza .hero {
        background-image: url("../img/conferenza-hero-bg.jpg");
    }

    .workshop-agenda .hero,
    .workshop .hero {
        background-image: url("../img/workshop-hero-bg.jpg");
    }

    .iab_game_changer .hero {
        background-image: url("../img/iab-game-changer-hero-bg.jpg");
    }

    .networking .hero {
        background-image: url("../img/networking-hero-bg.jpg");
    }

    .speaker-detail .hero {
        background-image: url("../img/speaker-detail-hero-bg.jpg");
    }

    .faq .hero {
        background-image: url("../img/faq-hero-bg.jpg");
    }

    .hero {
        width: 100vw;
        height: 32vw;
        background-size: cover;
        margin-top: 93px;
    }

    .workshop-detail .hero {
        height: 0;
    }

    .sponsor_form .hero {
        height: 44vw;
    }

    .faq .hero {
        height: 40vw;
    }

    .homepage .hero {
        height: 100vh;
        background-position: center;
        margin-top: 0;
        padding-bottom: 105px;
    }

    .networking .hero {
        box-shadow: 0 3px 6px #00000029;
        position: relative;
        z-index: 9;
    }

    .sponsor-form-hero {
        background-position: center center;
    }

    .hero:before {
        content: "";
        position: absolute;
        top: -49px;
        right: -45px;
        background-image: url("../img/Logo_Bolla.png");
        background-size: cover;
        width: 154px;
        height: 154px;
    }

    .speaker-detail .hero:before {
        display: none;
    }

    .hero:after {
        content: "";
        position: absolute;
        top: 50%;
        left: auto;
        right: 0;
        transform: translate(0, -50%);
        width: 30%;
        height: 80%;
        background-image: url("../img/triangolo_punti.png");
        background-repeat: no-repeat;
        background-size: contain;
        background-position: right center;
    }

    .sponsor_form .hero:before {
        content: "";
        position: absolute;
        top: 50%;
        left: auto;
        right: 10%;
        transform: translate(0, -50%);
        width: 20%;
        height: 37%;
        background-image: url("../img/Logo_Bussola.png");
        background-repeat: no-repeat;
        background-size: contain;
        z-index: 10;
    }

    .homepage .hero:after {
        display: none;
    }

    .iab_game_changer .hero:before {
        top: 40%;
        right: auto;
        left: -72px;
        width: 245px;
        height: 245px;
        transform: translate(0, -50%);
    }

    .evento_speciale .hero:before,
    .workshop .hero:before {
        top: -77px;
        right: auto;
        left: -44px;
        width: 245px;
        height: 245px;
    }

    .special-offer .hero:before,
    .networking .hero:before {
        top: -10px;
        right: 30px;
        left: auto;
        width: 218px;
        height: 218px;
        z-index: 99;
    }

    .hero-ciambella {
        content: "";
        position: absolute;
        top: 50%;
        right: 4%;
        left: auto;
        width: 179px;
        height: 148px;
        background-image: url("../img/Logo_Ciambella.png");
        background-size: cover;
        background-position: center;
        transform: translate(0, -50%) scaleX(-1);
        z-index: 99;
    }

    .workshop-agenda .hero:before {
        top: -77px;
        right: auto;
        left: -44px;
        width: 245px;
        height: 245px;
    }


    .hero-caption {
        position: relative;
        top: 50%;
    }

    .home-hero .hero-caption {
        top: calc(50% + 105px);
        transform: translate(0, -50%);
        padding-top: 0;
    }

    .home-hero .hero-caption:before {
        content: "";
        position: absolute;
        top: 50%;
        right: 0;
        transform: translate(0, -50%);
        width: 150px;
        height: 223px;
        background-image: url("../img/triangolo_punti.png");
        background-size: cover;
        background-position: center;
    }

    .sponsor-form-hero .hero-caption {
        padding-top: 0;
        padding-bottom: 0;
        top: 50%;
        transform: translate(0, -50%);
    }

    .hero-caption {
        padding-left: 32px;
        padding-right: 32px;
    }

    .hero-caption h1 {
        font-size: 50px;
        line-height: 50px;
        text-transform: uppercase;
    }

    .sponsor-form-hero .hero-caption h1 {
        text-transform: uppercase;
    }

    .hero-date .days {
        font-size: 38px;
        line-height: 48px;
    }

    .hero-date .month {
        font-size: 30px;
        line-height: 38px;
    }

    .hero-date .year {
        font-size: 55px;
        line-height: 70px;
        letter-spacing: 5px;
    }

    .hero-date .online {
        font-size: 30px;
        line-height: 38px;
        letter-spacing: 10.5px;
    }

    .anchor-btn {
        display: block;
        position: absolute;
        left: 50%;
        transform: translate(-50%, 0);
        background-color: #A2EFEA;
        color: #1A1A1A;
        text-align: center;
        bottom: 80px;
        width: 68px;
        height: 68px;
        font-size: 35px;
        line-height: 68px;
    }

    .anchor-btn:link,
    .anchor-btn:active,
    .anchor-btn:visited {
        color: #1A1A1A;
    }

    .anchor-btn:hover {
        color: #A2EFEA;
        background-color: #1A1A1A;
    }


    .iab_game_changer-logos {
        display: block;
        position: absolute;
        right: 10%;
        top: 50%;
        transform: translate(0, -50%);
        z-index: 99;
        background-color: transparent;
    }

    .iab_game_changer-logos:before {
        display: none;
    }


    .logo-iab-game-changers {
        background-color: #FFFFFF;
        border-radius: 50%;
        width: 148px;
        height: 148px;
        margin-bottom: 60px;
        margin-right: 0;
        margin-left: auto;
        background-image: url("../img/IAB-GameChangers-logo.png");
        background-repeat: no-repeat;
        background-size: cover;
    }

    .logo-candy {
        background-color: #FFFFFF;
        border-radius: 50%;
        width: 148px;
        height: 148px;
        background-image: url("../img/sponsors/blackrock.png");
        background-repeat: no-repeat;
        background-position: center;
        background-size: 90% 90%;
    }

    .logo-iabgenerations {
        background-color: #FFFFFF;
        border-radius: 50%;
        width: 148px;
        height: 148px;
        background-image: url("../img/Logo_Generations-02.png");
        background-repeat: no-repeat;
        background-position: center;
        background-size: 90% 90%;
    }

    .powered-by span {
        margin-right: 21px;
    }

    .powered-by * {
        display: inline-block;
        /*float: left;*/
        vertical-align: middle;
    }



}

@media screen and (min-width: 992px) and (max-height: 750px){
    .home-hero .hero-caption {
        top: 50%;
        transform: translate(0, -50%);
        padding-top: 0;
    }
}

@media screen and (min-width: 1200px){

    .home-hero .hero-caption:before {
        width: 200px;
        height: 300px;
    }

    .hero-date .days {
        font-size: 45px;
        line-height: 55px;
    }

    .hero-date .month {
        font-size: 35px;
        line-height: 45px;
    }

    .hero-date .year {
        font-size: 65px;
        line-height: 80px;
        letter-spacing: 7px;
    }

    .hero-date .online {
        font-size: 35px;
        line-height: 45px;
        letter-spacing: 13px;
    }

}

@media screen and (min-width: 1400px){

    .home-hero .hero-caption:before {
        width: 240px;
        height: 358px;
    }

    .hero-date .days {
        font-size: 60px;
        line-height: 72px;
    }

    .hero-date .month {
        font-size: 48px;
        line-height: 59px;
    }

    .hero-date .year {
        font-size: 89px;
        line-height: 107px;
        letter-spacing: 7px;
    }

    .hero-date .online {
        font-size: 48px;
        line-height: 59px;
        letter-spacing: 16px;
    }


}

/* ======================================
   agenda-sub-hero
   ====================================== */

#agenda-sub-hero {
    background-color: #D7D1DE;
}

#agenda-sub-hero ul {
    list-style-type: none;
    margin: 0;
    padding: 0;
    overflow: hidden;
}

#agenda-sub-hero li {
    font-size: 14px;
    float: left;
    margin-left: 1%;
}

/* ======================================
   Counter
   ====================================== */

.counter {
    position: relative;
    /*background-color: #2d1f40;*/
    padding-top: 11px;
    padding-bottom: 17px;
    text-align: center;
}

.counter-blocks {
    display: inline-block;
    margin: 0 auto;
}

.counter-block {
    position: relative;
    display: inline-block;
    float: left;
    width: 50px;
}

.counter-block.with-separator {
    margin-right: 36px;
}

.counter-block .title {
    text-transform: uppercase;
    color: #FFFFFF;
    text-align: center;
    font-size: 10px;
    line-height: 20px;
    font-weight: bold;
}

.counter-block .content {
    position: relative;
    background-color: #A2EFEA;
    width: 50px;
    height: 50px;
}

.counter-block .content div {
    line-height: 50px;
    text-align: center;
    font-weight: bold;
    color: #2D1F40;
}

.counter-block.with-separator .content:before {
    content: ":";
    position: absolute;
    top: 0;
    right: -18px;
    line-height: 50px;
    color: #FFFFFF;
    font-weight: bold;
}

@media screen and (min-width: 992px){

    .counter {
        position: absolute;
        background-color: #2d1f40;
        bottom: 0;
        left: 0;
        right: 0;
        padding-top: 11px;
        padding-bottom: 17px;
        text-align: center;
    }

}

/* ======================================
   Intro
   ====================================== */

.intro {
    position: relative;
    background-image: url("../img/intersection_2.jpg");
    background-color: #2D1F40;
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
    padding-top: 30px;
    padding-bottom: 30px;
}

.intro h2 {
    margin-bottom: 24px;
    color: #A2EFEA;
}

/*TODO motivo verde*/
/*.intro::before {*/
/*    content: "";*/
/*    position: absolute;*/
/*    top: 50%;*/
/*    right: 0;*/
/*    transform: translate(0, -50%);*/
/*}*/

.intro p {
    font-size: 15px;
    line-height: 20px;
    font-weight: 300;
    color: #FFFFFF;
    margin-bottom: 34px;
}

@media screen and (min-width: 768px){

    .intro {
        /*padding: 56px 20px 80px;*/
    }

}

@media screen and (min-width: 992px){

    .intro {
        padding: 56px 42px 80px;
    }
}

@media screen and (min-width: 1200px){

    .intro {
        padding: 56px 84px 80px;
    }
}


/* ======================================
   Numbers
   ====================================== */

.numbers {
    position: relative;
    background-color: #FFFFFF;
    background-image: url("../img/Logo_Ciambella.png");
    background-position: -20px 60%;
    background-repeat: no-repeat;
    background-size: 45%;
}

.numbers h3 {
    margin-bottom: 26px;
}

.numbers p {
    margin-bottom: 34px;
}

.number-block {
    position: relative;
    width: 224px;
    height: 224px;
    display: inline-block;
    border: 3px solid #A2EFEA;
    opacity: 1;
    border-radius: 50%;
    margin-bottom: 30px;
    background: #FFFFFF;
}

.number-block .content {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}


.number-block .number {
    font-size: 55px;
    line-height: 66px;
    font-weight: 100;
    color: #7A5CBE;
}

.number-block .title {
    font-size: 17px;
    line-height: 20px;
    font-weight: 900;
    letter-spacing: 0.6px;
    color: #2D1F40;
    text-transform: uppercase;
}

@media screen and (min-width: 578px){

    .numbers {
        background-size: 40%;
    }

}

@media screen and (min-width: 768px){

    .numbers {
        background-size: 30%;
        background-position: -40px 60%;
    }

    .numbers-slider {
        display: flex;
        justify-content: center;
    }

    .number-block {
        display: flex;
        flex-wrap: wrap;
        width: 224px;
        height: 224px;
        margin: 0 10px;
    }

    .number-block .number {
        font-size: 45px;
        line-height: 50px;
    }

}

@media screen and (min-width: 992px){

    .numbers {
        position: relative;
        padding-top: 57px;
        padding-bottom: 80px;
        background: #FFFFFF url("../img/Logo_Ciambella.png") -93px 11px no-repeat;
    }

    .numbers:before {
        content: "";
        position: absolute;
        bottom: 42px;
        right: -50px;
        width: 183px;
        height: 150px;
        background: #FFFFFF url("../img/Logo_Ciambella.png") 0 0 no-repeat;
        background-size: cover;
        transform: scaleX(-1);
    }

    .number-block {
        margin: 0 63px;
    }

}

/* ======================================
   Speakers
   ====================================== */

.speakers-top {
    position: relative;
}

.homepage .speakers-top:before {
    content: "";
    position: absolute;
    right: -23px;
    bottom: 18px;
    width: 183px;
    height: 150px;
    background-image: url("../img/Logo_Ciambella.png");
    background-size: cover;
    -webkit-transform: scaleX(-1);
    transform: scaleX(-1);
}

.speakers-top h3 {
    margin-bottom: 20px;
}

.speakers-top p {
    margin-bottom: 35px;
}

.speaker {
    margin-bottom: 30px;
}

.speaker-portrait {
    position: relative;
    margin-bottom: 7px;
}

.speaker-portrait:before {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    background-color: #061715;
    mix-blend-mode: color;
}

.bg-purple2 .speaker-portrait:before {
    background-color: #2d1f40;
}

.speaker-desc {
    position: relative;
    display: block;
    text-align: center;
    background-color: #A2EFEA;
    width: 100%;
    padding: 15% 10%;
}

.bg-purple2 .speaker-desc {
    background-color: #2d1f40;
}

.speaker-desc-head,
.speaker-desc-center,
.speaker-desc-button {
    position: absolute;
    width: 80%;
    left: 10%;
}

.speaker-desc-head {
    top: 15%;
}

.speaker-desc-center {
    top: 55%;
    transform: translate(0, -50%);
}

.speaker-desc-center .subtitle{
    display: none;
}

.speaker-desc-button {
    bottom: 10%;
}

.speaker-desc h4 {
    font-size: 25px;
    margin-bottom: 4px;
}

.speaker-desc h5 {
    font-size: 20px;
    margin-bottom: 4px;
    font-weight: bold;
}

.speaker-desc-center a:link,
.speaker-desc-center a:active,
.speaker-desc-center a:visited{
    color: #2D1F40;
    text-decoration: none;
}

.speaker-desc h5.conferenza {
    font-size: 22px;
    line-height: 22px;
    margin-bottom: 34px;
    text-transform: uppercase;
}

.bg-purple2 .speaker-desc h4,
.bg-purple2 .speaker-desc h5 {
    color: #A2EFEA;
}

.bg-purple2 .speaker-desc-center a{
    color: #ffffff ;
}

.speaker-desc p {
    margin-bottom: 0;
}

.speaker-desc p .day,
.speaker-desc p .month {
    font-weight: bold;
}

.speaker-desc p .day {
    font-size: 40px;
    line-height: 20px;
}

.speaker-desc p .month {
    font-size: 20px;
    line-height: 20px;
    text-transform: capitalize;
}

.bg-purple2 .speaker-desc p {
    color: #D7D1DE;
}

.speaker-btn {
    background-color: #2D1F40;
    border: 0;
    box-shadow: none;
    padding: 16px !important;
}

.show-all-speakers-btn {
    width: 100%;
    margin-top: 44px;
}

@media screen and (min-width: 576px) {

    .show-all-speakers-btn {
        width: auto;
    }

    .speaker-portrait {
        margin-bottom: 0;
    }

    .speaker-desc {
        display: none;
        text-align: center;
    }

    .speaker:hover .speaker-portrait {
        display: none;
    }

    .speaker:hover .speaker-desc {
        display: block;
    }

}

@media screen and (min-width: 576px){

    .speaker-desc {
        padding: 20px;
    }

    .speaker-desc h4 {
        font-size: 25px;
        margin-bottom: 4px;
    }

    .speaker-desc h5 {
        font-size: 20px;
        margin-bottom: 4px;
    }

}

@media screen and (min-width: 768px){

    .speaker-desc {
        padding: 15% 10%;
    }

    .speaker-desc h4 {
        font-size: 20px;
    }

    .speaker-desc h5.conferenza {
        font-size: 18px;
        line-height: 18px;
    }

}

@media screen and (min-width: 992px){

    .speakers-top:before {
        display: none;
    }

    .speakers-top h3 {
        text-transform: uppercase;
    }

    .speaker-desc h4 {
        font-size: 25px;
    }

    .speaker-desc h5.conferenza {
        font-size: 25px;
        line-height: 25px;
        margin-bottom: 20px;
    }

}

@media screen and (min-width: 1200px) {

    .speaker-desc h4 {
        font-size: 20px;
    }

    .speaker-desc h5.conferenza {
        font-size: 18px;
        line-height: 18px;
        margin-bottom: 25px;
    }

}

@media screen and (min-width: 1400px) {

    .speaker-desc h4 {
        font-size: 18px;
    }

    .speaker-desc p {
        line-height: 15px;
    }

    .speaker-desc h5.conferenza {
        font-size: 16px;
        line-height: 16px;
    }

}

/* ======================================
   Special offer detail
   ====================================== */

.special-offer h2 {
    text-transform: none;
    color: #1A1A1A;
}

.special-offer-modal .modal-body {
    padding: 50px 25px;
}

.special-offer-modal .modal-content {
    background-color: #2D1F40;
    box-shadow: 12px 12px 20px #00000029;
}

#special-offer-modal-close-btn {
    width: 26px;
    height: 26px;
    position: absolute;
    cursor: pointer;
    top: 10px;
    right: 10px;
    z-index: 99;
}

#special-offer-modal-close-btn:before,
#special-offer-modal-close-btn:after {
    position: absolute;
    display: block;
    right: 11px;
    top: -2px;
    content: ' ';
    height: 33px;
    width: 2px;
    background-color: #A2EFEA;
}

#special-offer-modal-close-btn:before {
    transform: rotate(45deg);
}

#special-offer-modal-close-btn:after {
    transform: rotate(-45deg);
}

.special-offer .img-container {
    width: 100%;
}

.special-offer-modal h2 {
    color: #A2EFEA;
    font-size: 35px;
    line-height: 40px;
    margin-bottom: 37px;
}

.special-offer-modal p {
    color: #ffffff;
    font-size: 18px;
    line-height: 28px;
}

.special-offer-modal hr {
    margin-top: 50px;
    margin-bottom: 50px;
    border-top: 1px solid #999;
}

.label-small {
    font-size: 15px;
    line-height: 15px;
    color: #ffffff;
    margin-bottom: 0;
}

.form-days {
    position: relative;
    margin-top: 24px;
}

.day-label {
    width: 30px;
    color: #A2EFEA;
    font-size: 22px;
    line-height: 20px;
    font-weight: bold;
}

@media screen and (min-width: 576px){

    .special-offer-modal .modal-body {
        padding: 50px;
    }

}

@media screen and (min-width: 768px){

}

@media screen and (min-width: 992px){

    .special-offer .img-container {
        margin-bottom: 0;
    }

    #special-offer-modal-close-btn {
        top: 28px;
        right: 26px;
    }

    #special-offer-modal-close-btn:before,
    #special-offer-modal-close-btn:after {
        width: 4px;
    }

}

@media screen and (min-width: 1200px){

    .special-offer-modal .modal-body {
        padding: 60px 120px 40px;
    }

}

/* ======================================
   Special offer box
   ====================================== */

.special-offer-box {
    padding-top: 68px;
    padding-bottom: 68px;
}

.special-offer-box-row {

}

.special-offer-box-img {
    position: relative;
    z-index: 100;
}

.special-offer-box-img::before {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    background-color: #081f1d;
    mix-blend-mode: color;
}

.special-offer-box-description {
    padding: 43px 38px;
    background-color: #FFFFFF;
    box-shadow: 12px 12px 20px #00000024;
}

.special-offer-box-description h2 {
    margin-bottom: 22px;
}

.special-offer-box-description p {
    margin-bottom: 30px;
}

.special-offer-box-description ul {
    margin-bottom: 30px;
    padding-left: 15px;
}

.special-offer-box-description ul li {
    color: #2D1F40;
    font-size: 15px;
    line-height: 20px;
    font-weight: 300;
}

@media screen and (min-width: 576px){


}

@media screen and (min-width: 768px){

}

@media screen and (min-width: 992px){

    .special-offer-box-description {
        position: relative;
        margin-left: -75px;
        z-index: 200;
    }

}

@media screen and (min-width: 1200px){

    .special-offer-box-description {
        padding: 60px 48px 83px;
    }

}


/* ======================================
   Resources
   ====================================== */

.resources {
    position: relative;
}

.resources:before,
.resources:after {
    content: "";
    position: absolute;
    background-size: cover;
    background-repeat: no-repeat;
}

.resources:before {
    width: 201px;
    height: 166px;
    left: -44px;
    bottom: 60px;
    background-image: url("../img/Logo_Ciambella.png");
    transform: scaleX(-1);
}

.resources:after {
    display: none;
    width: 273px;
    height: 273px;
    right: -136px;
    bottom: 143px;
    background-image: url("../img/Logo_Bolla.png");
}

.resources-bolla {
    display: none;
    content: "";
    position: absolute;
    width: 411px;
    height: 411px;
    left: -150px;
    top: 18%;
    background-image: url("../img/Logo_Bolla.png");
    background-size: cover;
    background-repeat: no-repeat;
}

.resources-content {
    margin-bottom: 0;
}

.resource-row + .resource-row{
    margin-top: 60px;
}

.resource-img {
    position: relative;
    z-index: 100;
}

.resource-img::before {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    background-color: #081f1d;
    mix-blend-mode: color;
}

.resource-description-col {
    z-index: 200;
}

.resource-description {
    padding: 43px 38px;
    background-color: transparent;
    text-align: center;
}

.resource-description h2 {
    margin-bottom: 22px;
    text-align: center;
}

.resource-description p {
    margin-bottom: 30px;
    text-align: left;
}

.resource-description ul {
    margin-bottom: 30px;
    padding-left: 15px;
}

.resource-description ul li {
    color: #2D1F40;
    font-size: 15px;
    line-height: 20px;
    font-weight: 300;
}

.resource-btns .resource-btn-group {
    display: block;
    position: relative;
    margin-bottom: 60px;
    text-align: center;
}

.resource-btn-group:last-child {
    margin-right: 0;
}

.resource-btns .resource-btn-group > a {
    display: block;
    text-align: center;
}

.resource-btns .resource-btn-group > a span {
    display: block;
    margin-bottom: 15px;
    text-align: center;
}

.resource-btn-group:before {
    content: "";
    position: absolute;
    top: 60%;
    left: 50%;
    transform: translate(-50%,-50%);
    width: 130px;
    height: 130px;
    background-color: #D7D1DE;
    border-radius: 50%;
    z-index: 1;
}

.resource-description .resource-btn-group a:link,
.resource-description .resource-btn-group a:active,
.resource-description .resource-btn-group a:visited {
    color: #2D1F40;
    text-transform: uppercase;
    text-decoration: underline;
}

.resource-btn-txt {
    position: relative;
    z-index: 50;
}

.icon-calendar,
.icon-speaker {
    display: inline-block;
    position: relative;
    vertical-align: middle;
    z-index: 50;
    margin: 0 auto;
    background-size: cover;
}

.icon-calendar {
    width: 82px;
    height: 72px;
    background-image: url("../img/icon-calendar.svg");
}

.icon-speaker {
    width: 94px;
    height: 96px;
    background-image: url("../img/icon-speaker.svg");
}

.sky-video {
    position: relative;
    width: 100%;
    height: 100vh;
}

.sky-video iframe {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    width: 100%;
    height: 100vh;
}

.sky-video img {
    box-shadow: 12px 12px 20px #0000001A;
}

.sky-description {
    background-color: #FFFFFF;
    padding: 15% 20%;
    box-shadow: 12px 12px 20px #0000001A;
}

.sky-description p {
    margin-bottom: 40px;
}

.sky-logo {
    padding: 20px 28px;
    margin-bottom: 45px;
}

.resources-content {
    background-color: #FFFFFF;
}

@media screen and (min-width: 576px){

    .resources-bolla {
        top: 16%;
    }

}

@media screen and (min-width: 768px){

}

@media screen and (min-width: 992px){

    .resources {
        background-color: #D7D1DE;
    }

    .resources:after {
        display: block;
    }


    .resources-bolla {
        display: none;
    }

    .resource-row {
        margin-bottom: 110px;
    }

    .resource-row + .resource-row{
        margin-top: 0;
    }

    .resource-img {
        box-shadow: 12px 12px 20px #00000029;
        max-width: 500px;
    }

    .resource-btns .resource-btn-group {
        display: inline-block;
        position: relative;
        margin-right: 43px;
        margin-bottom: 32px;
    }

    .resource-btn-group:before {
        content: "";
        position: absolute;
        top: 50%;
        left: 20px;
        transform: translate(0,-50%);
        width: 80px;
        height: 80px;
        background-color: #D7D1DE;
        border-radius: 50%;
        z-index: 1;
    }

    .resource-description {
        padding: 10% 35% 10% 15%;
        background-color: #FFFFFF;
        box-shadow: 12px 12px 20px #00000024;
        text-align: left;
    }


    .resource-description h2 {
        text-align: left;
    }

    .resource-img-col {
        position: absolute;
        right: 0;
        top: 50%;
        transform: translate(0, -50%);
        z-index: 999;
    }

    .sky-video {
        margin-bottom: 0;
    }

    .icon-calendar,
    .icon-speaker {
        margin-right: 9px;
    }

    .icon-calendar {
        width: 49px;
        height: 43px;
    }

    .icon-speaker {
        width: 52px;
        height: 53px;
    }

    .resource-btns .resource-btn-group > a {
        display: inline-block;
        text-align: left;
    }

    .resource-btns .resource-btn-group > a span {
        display: inline-block;
        margin-bottom: 0;
        text-align: left;
    }

    .sky-video iframe {
        height: 100%;
    }

}

@media screen and (min-width: 1200px){

    .resources:before {
        bottom: 445px;
        right: -90px;
    }

    .resource-btn-icon {
        font-size: 60px;
    }

    .resource-description {
    }

}

/* ======================================
   Advantages
   ====================================== */

.advantages {
    background-color: #2D1F40;
    padding-top: 36px;
    padding-bottom: 56px;
}

.advantages p {
    margin-bottom: 26px;
}


/* ======================================
   Become sponsor
   ====================================== */

.become-s {
    position: relative;
    background-image: url("../img/become-s-bg.jpg");
    background-color: #2D1F40;
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
    padding-bottom: 206px;
}

.become-s:before {
    content: "";
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translate(-50%, 0);
    background-image: url("../img/triangolo_punti_h.png");
    /*width: 80vw;*/
    /*height: 53vw;*/
    width: 258px;
    height: 173px;
    background-repeat: no-repeat;
    background-size: contain;
}

.become-s h3 {
    text-align: center;
    margin-bottom: 24px;
    color: #FFFFFF;
}

.become-s p {
    color: #FFFFFF;
    margin-bottom: 24px;
}

.become-s .btn {
    width: 100%;
    padding: 16px 60px;
}

@media screen and (min-width: 576px){

    .become-s-cta {
        text-align: center;
    }

    .become-s .btn {
        width: auto;
    }

}

@media screen and (min-width: 768px){

    .become-s {
        /*padding: 56px 20px 80px;*/
    }

}

@media screen and (min-width: 992px){

    .become-s {
        padding: 56px 42px 80px;
    }

    .become-s:before {
        /*content: "";*/
        /*position: absolute;*/
        top: 50%;
        bottom: auto;
        left: auto;
        right: -113px;
        transform: translate(0, -50%);
        background-image: url("../img/triangolo_punti.png");
        /*width: 80vw;*/
        /*height: 53vw;*/
        width: 218px;
        height: 325px;
        background-repeat: no-repeat;
        background-size: cover;
    }

    .become-s h3 {
        text-align: left;
    }

    .become-s-cta {
        text-align: left;
    }

}

@media screen and (min-width: 1200px){

    .become-s {
        padding: 67px 84px 96px;
    }
}

/* ======================================
   faq
   ====================================== */

.faq-row {
    background-color: #E6FAF9;
    padding-top: 5px;
    padding-bottom: 144px;
    position: relative;
}

.faq-row-inverse {
    background-color: #D7D1DE;
}

.faq h2 {
    text-align: left;
    text-transform: none;
    color: #2D1F40;
    font-size: 25px;
    margin-top: 43px;
    margin-bottom: 37px;
}

.faq-row .answer {
}

.faq-row p {
    color: #1A1A1A;
    font-size: 18px;
    line-height: 36px;
}

a.faq-btn:link,
a.faq-btn:active,
a.faq-btn:visited {
    position: absolute;
    bottom: 40px;
    left: 50%;
    transform: translate(-50%, 0);
    width: 68px;
    height: 68px;
    border-radius: 50%;
    font-size: 32px;
}

.faq-btn .fas {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

.faq-btn .fas:before {
    content: "\f068";
}

.faq-btn.collapsed .fas:before {
    content: "\f067";
}

@media screen and (min-width: 768px){


}

@media screen and (min-width: 992px){

    .faq-row {
        padding-bottom: 0;
    }

    .faq-row .container {
        position: relative;
    }

    .faq h2,
    .faq .answer {
        width: 80%;
    }

    a.faq-btn:link,
    a.faq-btn:active,
    a.faq-btn:visited {
        position: absolute;
        bottom: auto;
        left: auto;
        width: 50px;
        height: 50px;
        border-radius: 50%;
        font-size: 17px;
        top: 50%;
        right: 15px;
        transform: translate(0, -50%);
        padding: 0;
    }

}

@media screen and (min-width: 1200px){


}


/* ======================================
   Contributors
   ====================================== */

.rect {
    border: 1px solid #D7D1DE;
    background-color: #FFFFFF;
}

.contributors {
    position: relative;
}

.contributors-container {
    position: relative;
    z-index: 9;
}

.contributors-ciambella-1,
.contributors-ciambella-2,
.contributors-ciambella-3 {
    display: none;
    content: "";
    position: absolute;
    width: 279px;
    height: 230px;
    background-image: url("../img/Logo_Ciambella.png");
    background-size: cover;
    background-repeat: no-repeat;
    z-index: 0;
}

.contributors-ciambella-1 {
    top: 15%;
    left: -32px;
    transform: scaleX(-1);
}

.contributors-ciambella-2 {
    top: 50%;
    right: -129px;
}

.contributors-ciambella-3 {
    bottom: 10%;
    left: -128px;
    transform: scaleX(-1);
}

.contributors h3 {
    color: #2D1F40;
    margin-bottom: 42px;
}

.contributors h4 {
    color: #2D1F40;
    font-size: 20px;
    line-height: 20px;
    margin-bottom: 19px;
    text-align: center;
}

.contributors .img-thumbnail {
    margin-bottom: 20px;
}

@media screen and (min-width: 768px){

    .contributors-ciambella-1,
    .contributors-ciambella-2 {
        display: block;
    }

}

@media screen and (min-width: 992px){

    .rect-big {
        padding: 0 200px;
    }

    .contributors {
        padding-top: 82px;
        padding-bottom: 147px;
    }

    .contributors h3 {
        margin-bottom: 83px;
    }

    .contributors h4 {
        margin-bottom: 34px;
    }

    .contributors-ciambella-1 {
        display: none;
    }


}

@media screen and (min-width: 1200px){

    .contributors-ciambella-3 {
        display: block;
    }


}

/* ======================================
   Sliders
   ====================================== */

.slick-dots li button::before {
    font-size: 10px;
    line-height: 20px;
    width: 20px;
    height: 20px;
    opacity: 1;
    color: #2D1F40;
}

.slick-dots li.slick-active button::before {
    opacity: 1;
    color: #A2EFEA;
    font-size: 16px;
}

.bg-purple2 .slick-dots li.slick-active button::before {
    color: #7A5CBE;
}

.sidebar-sliders .slick-dots li {
    width: 8px;
    height: 8px;
    padding: 0 5px;
}

.sidebar-sliders .slick-dots li button {
    width: 8px;
    height: 8px;
    padding: 5px;
}

.sidebar-sliders .slick-dots li button::before {
    font-size: 8px;
    line-height: 11px;
    width: 11px;
    height: 11px;
    opacity: 1;
    color: #2D1F40;
}

.sidebar-sliders .slick-dots li.slick-active button::before {
    font-size: 11px;
}

.small-slider .slick-dots {
    bottom: 0;
}

.small-slider .slick-list {
    padding-bottom: 25px;
}

.small-slider img {
    margin: 0 auto;
}

/* ======================================
   Footer
   ====================================== */

.footer {
    position: relative;
    background-color: #1A1A1A;
    padding-top: 35px;
    padding-bottom: 300px;
}

.footer:before,
.footer:after {
    content: "";
    position: absolute;
    background-repeat: no-repeat;
    background-size: cover;
}

.footer:before {
    background-image: url("../img/Logo_Bolla.png");
    top: 272px;
    right: -105px;
    width: 271px;
    height: 271px;
}

.footer:after {
    background-image: url("../img/Logo_Ciambella.png");
    bottom: 48px;
    left: 50%;
    transform: translate(-50%, 0);
    width: 227px;
    height: 188px;
}

.footer-logo {
    max-width: 100px;
}

.social-btn {
    position: relative;
    width: 85px;
    height: 85px;
    background-color: #FFFFFF;
    margin-bottom: 60px;
    font-size: 45px;
}

.social-btn:hover {
    background-color: #A2EFEA;
}

.social-btn a {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

.social-btn a:link,
.social-btn a:active,
.social-btn a:visited {
    color: #1A1A1A;
}

.footer .nav-item {
    width: 100%;
    text-align: center;
    margin-bottom: 60px;
    z-index: 99;
}

.footer .nav a:link,
.footer .nav a:active,
.footer .nav a:visited {
    color: #FFFFFF;
    font-size: 18px;
    line-height: 21px;
    font-weight: 300;
    text-decoration: none;
}

.footer .nav-green a:link,
.footer .nav-green a:active,
.footer .nav-green a:visited {
    color: #A2EFEA;
}

.footer .nav a:hover {
    text-decoration: underline;
}

.footer p {
    color: #FFFFFF;
    font-size: 14px;
    line-height: 17px;
}

@media screen and (min-width: 768px){

    .footer .nav-item {
        /*width: auto;*/
    }

}

@media screen and (min-width: 992px){

    .footer {
        padding-bottom: 45px;
    }

    .footer .nav-item {
        margin-bottom: 0;
        width: auto;
    }

    .footer:before {
        top: 75px;
        right: auto;
        left: -125px;
    }

    .footer:after {
        bottom: auto;
        left: auto;
        top: 87px;
        right: -90px;
        /*transform: none;*/
        width: 279px;
        height: 230px;

        -webkit-transform: scaleX(-1);
        transform: scaleX(-1);

    }

    .social-btn {
        width: 32px;
        height: 32px;
        font-size: 1rem;
        margin-bottom: 0;
    }

}


/* ==========================================================================
   Login Form
   ========================================================================== */

.login-error {
    display: none;
    color: red;
}

.swal2-container.swal2-backdrop-show, .swal2-container.swal2-noanimation {
    background: rgba(45, 31, 64, 0.9);
}

.swal2-popup {
    display: none;
    position: unset;
    box-sizing: border-box;
    flex-direction: column;
    justify-content: center;
    /*width: 32em;*/
    width: 100%;
    height: 100%;
    max-width: 100%;
    padding: 1.25em;
    border: none;
    border-radius: 0;
    background-color: transparent;
    font-family: inherit;
    font-size: 1rem;
}

.swal2-content {
    z-index: 1;
    justify-content: center;
    margin: 0 auto;
    padding: 0 1.6em;
    padding: 0;
    color: #545454;
    font-size: 1.125em;
    font-weight: 400;
    line-height: normal;
    text-align: center;
    word-wrap: break-word;
    max-width: 32em;
}

.swal2-title {
    position: relative;
    max-width: 100%;
    padding: 0;
    color: #A2EFEA;
    text-align: center;
    text-transform: none;
    word-wrap: break-word;
    font-family: 'Inter', sans-serif;
    font-size: 40px;
    line-height: 40px;
    margin-bottom: 20px;
    font-weight: 200;
}

.swal2-styled.swal2-confirm {
    border: 1px solid #A2EFEA;
    color: #2D1F40;
    background-color: #A2EFEA;
    font-weight: 700;
    padding: 16px 34px;
    font-size: 15px;
    line-height: 15px;
    border-radius: 30px;
    text-transform: uppercase;
    white-space: nowrap;
    text-decoration: none;
}

.swal2-actions:not(.swal2-loading) .swal2-styled:hover {
    background-image: none;
    color: #A2EFEA;
    background-color: #2D1F40;
    border-color: #2D1F40 !important;
    box-shadow: none !important;
}

.swal2-styled.swal2-cancel {
    border: 1px solid #FFFFFF;
    color: #FFFFFF;
    background-color: transparent;
    font-weight: 700;
    padding: 16px 34px;
    font-size: 15px;
    line-height: 15px;
    border-radius: 30px;
    text-transform: uppercase;
    white-space: nowrap;
    text-decoration: none;
}

.btn-light-border:not(:disabled):not(.disabled):hover, .btn-light-border:not(:disabled):not(.disabled).hover, .btn-light-border:not(:disabled):not(.disabled).focus, .btn-light-border:not(:disabled):not(.disabled):focus, .btn-light-border:not(:disabled):not(.disabled).active, .btn-light-border:not(:disabled):not(.disabled):active, .show > .btn-light-border.dropdown-toggle {
    color: #2D1F40;
    background-color: #A2EFEA;
    border-color: #A2EFEA;
    box-shadow: none !important;
}

.swal2-close {
    display: block !important;
    content: " ";
    position: absolute;
    z-index: 2;
    top: 30px;
    right: 30px;
    align-items: center;
    justify-content: center;
    width: 26px;
    height: 26px;
    padding: 0;
    overflow: hidden;
    transition: color .1s ease-out;
    border: none;
    border-radius: 0;
    background: 0 0;
    color: #ccc;
    font-family: serif;
    font-size: 2.5em;
    line-height: 1.2;
    cursor: pointer;
    text-indent: -9999px;
}

.swal2-close:focus {
    outline: none;
}

.swal2-close::before,
.swal2-close::after {
    position: absolute;
    display: block;
    right: 11px;
    top: -2px;
    content: ' ';
    height: 33px;
    width: 2px;
    background-color: #A2EFEA;

}

.swal2-close::before {
    transform: rotate(45deg);
}

.swal2-close::after {
    transform: rotate(-45deg);
}

.login-link a:link,
.login-link a:active,
.login-link a:visited {
    color: #A2EFEA;
}

@media screen and (min-width: 576px){

    .swal2-content {
        padding: 0 1.6em;
    }

}

@media screen and (min-width: 992px){

    .swal2-close::before,
    .swal2-close::after {
        position: absolute;
        display: block;
        right: 11px;
        top: -2px;
        content: ' ';
        height: 33px;
        width: 2px;
        background-color: #A2EFEA;
    }

    .swal2-close::before,
    .swal2-close::after {
        width: 4px;
    }

}

/* ==========================================================================
   Form
   ========================================================================== */

.form {
    position: relative;
    background-image: url("../img/form-bg.jpg");
    background-color: #2D1F40;
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
}

.form-group {
    position: relative;
    margin-bottom: 50px;
}

.form-control {
    height: 50px;
    padding: 15px;
    background-color: transparent;
    border: 0;
    border-bottom: 1px solid #FFFFFF;
    border-radius: 0;
    -webkit-box-shadow: none;
    box-shadow: none;
    color: #FFFFFF !important;
    font-size: 22px;
    line-height: 26px;
}

select.form-control {
    padding: 0;
}

textarea.form-control {
    overflow: hidden;
}

.form-control:focus {
    border-color: #ffffff;
    background-color: transparent;
    outline: 0;
    -webkit-box-shadow: none;
    box-shadow: none;
}

.control-label {
    position: absolute;
    top: 12px;
    left: 15px;
    font-size: 22px;
    letter-spacing: -0.16px;
    line-height: 26px;
    transition: all ease 0.3s;
    font-weight: 300;
    color: #FFFFFF;
}

.textarea-label {
    font-size: 22px;
    line-height: 22px;
    font-weight: 800;
    color: #A2EFEA;
    text-align: center;
}

.form-control:focus + .control-label,
.form-control.filled + .control-label {
    top: -15px;
    font-size: 15px;
    line-height: 15px;
}

.radio-label {
    font-weight: 300;
    font-size: 12px;
    letter-spacing: -0.12px;
    line-height: 15px;
}

.radio-group {
    display: inline-block;
    position: relative;
    line-height: 18px;
}
input[type="radio"] {
    position: absolute;
    opacity: 0;
    visibility: hidden;
}

.radio-label {
    padding: 0 0 0 28px;
    line-height: 18px;
    cursor: pointer;
    margin-right: 10px;
}

.radio-label::before {
    position: absolute;
    top: 0;
    left: 0;
    display: inline-block;
    content: "";
    height: 18px;
    width: 18px;
    margin-right: 0.625rem;
    border: 1px solid #525252;
    border-radius: 50%;
}

.form-group.error .textarea-label,
.form-group.error .control-label{
    color:red;
}

.form-group.error select{
    color:red;
}

.alert {
    color: red;
    font-size: 14px;
    padding: 0;
    margin: 0;
}

.errors-container {
    color: red;
    font-size: 12px;
}

.ws-filter .form-control {
    height: 50px;
    padding: 15px;
    background-color: transparent;
    border: 1px solid lightgrey !important;
    border-radius: 25px;
    -webkit-box-shadow: none;
    box-shadow: none;
    color: #000000 !important;
    font-size: 22px;
    line-height: 26px;
}

.ws-filter{
    position: relative;
}
.ws-filter .fa-search{
    position: absolute;
    right: 14px;
    top:17px;
}
input[type="radio"].error + .radio-label {
    color:red;
}

.form-group.error .form-control {
    border-bottom: 1px solid red;
}

#thankyou h4 {
    color: #ffffff;
    text-align: center;
    font-size: 20px;
    line-height: normal;
}

/* =========================================
   radio + checkbox
   ====================================== */

p.privacy-label {
    color: #FFFFFF;
    font-size: 15px;
    line-height: 15px;
}

.privacy-label a:link,
.privacy-label a:active,
.privacy-label a:visited {
    color: #A2EFEA;
}

.error .privacy-label {
    color: red;
}

/* Basic styles */
input[type="checkbox"],
input[type="radio"] {
    position: absolute;
    opacity: 0;
    z-index: -1;
}

input[type="checkbox"] + label, input[type="radio"] +  label {
    position: relative;
    display: inline-block;
    padding: 0 0 0 30px;
    height: 30px;
    line-height: 1.5;
    cursor: pointer;
}

input[type="checkbox"] + label::before, input[type="radio"] +  label::before,
input[type="checkbox"] + label::after, input[type="radio"] +  label::after {
    position: absolute;
    top: 0;
    left: 0;
    display: block;
    width: 30px;
    height: 30px;
}
input[type="checkbox"] + label::before, input[type="radio"] +  label::before {
    content: " ";
    border: 2px solid #bdc3c7;
    border-radius: 0;
}
/* Checkbox */
input[type="checkbox"] + label::after {
    content: "\2714";
    color: #2c3e50;
    line-height: 30px;
    text-align: center;
    font-size: 20px;
}
/* Radio */
input[type="radio"] + label::before {
    border-radius: 50%;
}
input[type=radio] + label::after {
    content: " ";
    top: .25em;
    left: .25em;
    width: 1em;
    height: 1em;
    background: #fff;
    border: .2em solid #2c3e50;
    border-radius: 50%;
}
/* :checked */
input[type="checkbox"]:checked + label::before,
input[type="radio"]:checked + label::before {
    background: #fff;
    border-color: #fff;
}
input[type="checkbox"] + label::after,
input[type=radio] + label::after {
    -webkit-transform: scale(0);
    -ms-transform: scale(0);
    -o-transform: scale(0);
    transform: scale(0);
}
input[type="checkbox"]:checked + label::after,
input[type=radio]:checked + label::after {
    -webkit-transform: scale(1);
    -ms-transform: scale(1);
    -o-transform: scale(1);
    transform: scale(1);
}
/* Transition */
input[type="checkbox"] + label::before, input[type="radio"] +  label::before,
input[type="checkbox"] + label::after, input[type="radio"] +  label::after {
    -webkit-transition: .25s all ease;
    -o-transition: .25s all ease;
    transition: .25s all ease;
}

@media screen and (min-width: 992px) {

    .errors-container {
        display: none;
    }
}

@media screen and (min-width: 1200px) {

    .errors-container {
        display: block;
    }

}

@media screen and (min-width: 1400px) {

}

/* ==========================================================================
   Networking
   ========================================================================== */

.networking-icon {
    width: 200px;
    height: 200px;
    border-radius: 50%;
    box-shadow: 12px 12px 20px #00000029;
    line-height: 200px;
    text-align: center;
}

.bg-purple2 .networking-icon {
    background-color: #2D1F40;
    margin: 0 auto 30px;
}

.bg-green .networking-icon {
    background-color: #A2EFEA;
    margin: 0 auto 30px;
}

.networking h2 {
    text-transform: none;
}

@media screen and (min-width: 992px) {

    .networking .bg-purple2 {
        background-image: url("../img/TriangoloPunti_Viola.png");
        background-position: right center;
        background-repeat: no-repeat;
        background-size: auto 150% ;
    }

    .networking .bg-green {
        background-image: url("../img/triangolo_punti-left.png");
        background-position: left center;
        background-repeat: no-repeat;
        background-size: auto 150%;
    }

    .bg-purple2 .networking-icon {
        margin: 0 0 45px auto;
    }

    .bg-green .networking-icon {
        margin: 0 auto 45px 0;
    }

}

/* ==========================================================================
   Category detail
   ========================================================================== */

.category h3 {
    text-transform: none;
    margin-bottom: 46px;
}

.buy-premium-ticket {
    position: relative;
    padding-top: 260px !important;
}

.buy-premium-ticket h3 {
    line-height: 45px;
}

.buy-premium-ticket:before {
    content: "";
    position: absolute;
    top: 50px;
    left: 50%;
    transform: translate(-50%, 0);
    background-image: url("../img/Logo_Ciambella.png");
    background-size: cover;
    background-repeat: no-repeat;
    width: 185px;
    height: 152px;
}

.page-content {
    position: relative;
    padding-top: 240px !important;
}

.page-content:before {
    content: "";
    position: absolute;
    background-size: cover;
    background-repeat: no-repeat;
}

.workshop .page-content:before {
    left: 50%;
    top: 20px;
    transform: translate(-50%, 0);
    background-image: url("../img/Logo_Bussola.png");
    width: 259px;
    height: 209px;
}

.conferenza .page-content:before {
    left: 50%;
    top: 20px;
    transform: translate(-50%, 0);
    background-image: url("../img/Logo_Bussola.png");
    width: 259px;
    height: 209px;
}

.evento_speciale .page-content:before,
.iab_game_changer .page-content:before {
    right: -30px;
    top: 20px;
    background-image: url("../img/Logo_Bolla.png");
    width: 282px;
    height: 282px;
}

.collaborazione {
    margin-top: 20px;
    color: #ffffff;
    font-weight: bold;
}

.collaborazione,
.technogym-logo {
    display: block;
    margin: 20px auto;
}

.technogym-logo {
    max-width: 200px;
}

@media screen and (min-width: 992px) {

    .page-content {
        position: relative;
        padding-top: 3rem !important;
    }

    .workshop .page-content:before,
    .iab_game_changer .page-content:before,
    .conferenza .page-content:before {
        left: auto;
        right: -20px;
        top: 100px;
        transform: none;
        background-image: url("../img/Logo_Bussola.png");
        width: 379px;
        height: 306px;
    }

    .workshop .page-content:before {
        top: 112px;
    }

    .iab_game_changer .page-content:before {
        top: 50px;
    }

    .conferenza .page-content:before {
        top: 50px;
    }

    .workshop-sponsors {
        position: relative;
        background-image: url("../img/Logo_Bolla.png"), url("../img/TriangoloPunti_Viola.png");
        background-size: 540px 540px, 646px 964px;
        background-repeat: no-repeat, no-repeat;
        background-position: -141px 94px, center right;

    }

    .buy-premium-ticket {
        padding-top: 3rem !important;
        position: relative;
    }

    .buy-premium-ticket:before {
        content: "";
        position: absolute;
        top: 50%;
        transform: translate(0, -50%);
        background-image: url("../img/Logo_Ciambella.png");
        background-size: cover;
        background-repeat: no-repeat;
        width: 185px;
        height: 152px;
    }

    .iab_game_changer .buy-premium-ticket:before {
        left: 51px;
    }

    .conferenza .buy-premium-ticket:before {
        left: -38px;
    }

    .collaborazione,
    .technogym-logo {
        display: inline-block;
        margin: 20px auto;
    }

    .technogym-logo {
        max-width: 200px;
    }

}


/* ==========================================================================
   Chat btn
   ========================================================================== */

#chat {
    display: none;
    position: fixed;
    width: 90%;
    height: 50vh;
    bottom: 70px;
    left: 5%;
    z-index: 99;
}

.open #chat {
    display: block;
}

.chat-open-btn {
    display: block;
}

.fa-times {
    display: none;
}

.open .chat-open-btn {
    display: none;
}

.open .fa-times {
    display: block;
}

.chat-btn-box {
    width: 50px;
    height: 50px;
    position: fixed;
    right: 10px;
    bottom: 10px;
    background-color: #2D1F40;
    text-align: center;
    z-index: 99;
    box-shadow: 12px 12px 20px #0000001A;
    cursor: pointer;
    font-size: 25px;
    border-radius: 50%;
    text-transform: uppercase;
    text-decoration: none;
}

.chat-btn-box .far,
.chat-btn-box .fas {
    color: #A2EFEA;
    line-height: 50px;
}

.chat-open-btn > * {
    display: inline-block;
    float: left;
    vertical-align: middle;
}

@media screen and (min-width: 992px){

    #chat {
        width: 300px;
        height: 50vh;
        bottom: 90px;
        left: auto;
        right: 10px;
    }

    .chat-btn-box {
        width: 70px;
        height: 70px;
    }

    .chat-btn-box .far,
    .chat-btn-box .fas {
        line-height: 70px;
        font-size: 30px;
    }


}

/* ==========================================================================
   Workshop detail
   ========================================================================== */

body.workshop-detail {
    /*padding-top: 90px;*/
}

.detail-alert {
    background-color: #A2EFEA;
}

.detail-alert h3 {
    font-size: 22px;
    line-height: 22px;
}

.detail-alert h3 a:link,
.detail-alert h3 a:active,
.detail-alert h3 a:visited {
    color: #2D1F40;
}

.workshop-breadcrumb{
    position: relative;
}

.workshop-breadcrumb .subtitle{
    display: none;
}

.workshop-breadcrumb ul {
  list-style-type: none;
  margin: 0;
  padding: 0;
  overflow: hidden;
}

.workshop-breadcrumb li {
  float: left;
}

.workshop-breadcrumb li:after {
    content: " - ";
    white-space: pre;
}

.workshop-breadcrumb li:last-of-type:after {
    content: "";
}

#logo-ciambella{
    position: absolute;
    top:-10px;
    right: -70px;
}

#logo-ciambella img{
    width: 106px;
    -webkit-transform: scaleX(-1);
    transform: scaleX(-1);
}

#logo-bussola{
    text-align: center;
    margin-top: -50px;
    height: 190px;
    overflow-y: hidden;
}
#logo-bussola img{
    width: 240px;
}

.workshop-sidebar {
    background-color: #D7D1DE;
    text-align: center;
    height: 100%;
    background-image: url("../img/Logo_Bolla.png");
    background-repeat: no-repeat;
    background-size: 260px;
    background-position: right -100px top 450px;
}

.evento_speciale .workshop-sidebar {
    background-position: calc(200% - 10px) 70%;
}


.workshop-date{
    padding: 30px;
    color:#2D1F40;
    font-weight: bold;
}

.workshop-date.shadow{
    -webkit-box-shadow: 10px 10px 19px -13px rgba(168,163,168,1);
    -moz-box-shadow: 10px 10px 19px -13px rgba(168,163,168,1);
    box-shadow: 10px 10px 19px -13px rgba(168,163,168,1);
    width: 60%;
    margin: 40px auto;
}

.agenda-row {
    padding-top: 50px;
    padding-bottom: 50px;
    background-color: #2D1F40;
    border-bottom: 1px solid white;
}

.cell{
    /*border:1px solid white;*/
    background-color: #2D1F40;
    position: relative;
    padding: 0 60px;
    text-align: center;
}

.cell .btn-light-blue{
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%,-50%);
}

.relator{
    display: block;
    width: 100%;
    margin-bottom: 10px;
}

.bike-storming {
    color: #ffffff;
}

.bike-storming span {
    display: none;
}

.open .cell{
    background-color: #fff;
    border:1px solid #ccc;
}

.details{
    position: relative;
}

.relator .name {
    color: #ffffff;
}

.relator .job-title {
    color: #ffffff;
}

.details > div{
    /*position: absolute;*/
    /*top: 50%;*/
    /*left: 10%;*/
    /*transform: translate(0%,-50%);*/
}

.arena{
    color:white;
    font-weight: bold;
    font-size: 13px;
}

.agenda-row .title {
    /*margin-bottom: 35px;*/
}

.agenda-row .title,
.agenda-row .title a:link,
.agenda-row .title a:active,
.agenda-row .title a:visited {
    color:#A2EFEA;
    font-weight: bold;
    font-size: 25px;
    text-decoration: none;
}

.agenda-row .title a .subtitle {
    display: block;
    font-size: 16px;
    line-height: 20px;

}

.agenda-row .title a:hover:link,
.agenda-row .title a:hover:active,
.agenda-row .title a:hover:visited {
    text-decoration: underline;
}

.relators{
    color: white;
    font-size: 15px;
}

.workshop-date .day{
    font-size: 87px;
    line-height: 105px;
    font-weight: 900;
}

.workshop-date .month{
    color:#7A5CBE;
    font-size: 18px;
    line-height: 21px;
    text-transform: uppercase;
}

.workshop-date .year{
    font-size: 32px;
    line-height: 39px;
    letter-spacing: 2.5px;
    font-weight: 900;
}

.workshop-date .hour{
    color:#7A5CBE;
    font-size: 18px;
    line-height: 21px;
    text-transform: uppercase;
}

.workshop-hours{
    width: 75%;
    margin: 0 auto;
    padding-top:30px;
    padding-bottom: 30px;
}

.workshop-detail .workshop-hours{
    border-top:1px solid #2D1F40;
    border-bottom:1px solid #2D1F40;
}


.workshop-logo {
    position: relative;
    margin: 0 auto;
    width: 175px;
    height: 175px;
    background-color: #ffffff;
    box-shadow: 12px 12px 20px #0000001A;
}

.workshop-logo img{
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 150px;
}

.workshop-logo-full {
    position: relative;
    margin: 0 auto;
    width: 175px;
    background-color: #ffffff;
    box-shadow: 12px 12px 20px #0000001A;
}

.workshop-logo-full img{
    width: 100%;
}


.workshop-hour .label{
    text-transform: uppercase;
}
.workshop-hour .hour{
    color: #7A5CBE;
    font-weight: bold;
}

.ws-date-green {
    background-color: #E6FAF9;
}

.ws-date-grey {
    background-color: #D7D1DE;
}

.ws-list .workshop-hour{
    border:none;
    font-size: 24px;
}

.ws-list .workshop-hour .label,
.ws-list .workshop-hour .hour{
    color:white;
}


.workshop-video {
    display: block;
    background-color: #2D1F40;
    width: 100vw;
    height: 56vw;
}

.workshop-header {
    background-color: #E6FAF9;
}

.workshop-title {
    margin-top: 10px;
    margin-bottom: 35px;
}

.workshop-title .subtitle{
    display: block;
    font-size: 28px;
    line-height: 30px;
}

.workshop-title h2 {
    font-size: 16px;
    line-height: 20px;
    color: #7A5CBE;
    text-transform: none;
}

.workshop-title h1 {
    font-size: 40px;
    line-height: 40px;
    color: #1A1A1A;
    font-weight: 800;
}

.workshop-description {
    background-color: #FFFFFF;
}

.workshop-header,
.workshop-description {
    padding: 30px;
}

.workshop-description {
    padding-bottom: 215px;
}

.workshop-description p {
    font-size: 18px;
    line-height: 36px;
    color: #1A1A1A;
}

.bio-btn {
    background: none;
    border: 0;
    text-transform: uppercase;
    color: #2D1F40;
    font-size: 20px;
    font-weight: bold;
}

.modal-content {
    border: 0;
    border-radius: 0;
    outline: 0;
}

@media screen and (min-width: 992px) {

    body.workshop-detail {
        /*padding-top: 93px;*/
    }

    .workshop-video {
        width: 100%;
    }

    .workshop-hous {
        position: relative;
        top: 50%;
    }

    .ws-list .workshop-hour{
        font-size: 18px;
    }

    .agenda-row {
        padding-top: 0;
        padding-bottom: 0;
        /*background-color: transparent;*/
        border-bottom: 0;
        min-height: 100px;
    }

    .min-height-row {
        min-height: 305px;
    }


    .cell > div{
        position: absolute;
        top: 50%;
        left: 10%;
        transform: translate(0%,-50%);
    }

    .workshop-cell > div {
        position: relative;
        transform: none;
        top: auto;
        left: auto;
    }

    .cell{
        border: 1px solid white;
        /*border-right: 1px solid white;*/
        /*background-color: #2D1F40;*/
        /*position: relative;*/
        text-align: left;
        padding: 44px 20px;
    }

    .relator{
        display: block;
        float: left;
        width: auto;
        margin-bottom: 0;
        margin-right: 15px;
    }

    .conferenza .relator,
    .iab_game_changer .relator {
        clear: both;
    }

    .bike-storming {
        width: 80%;
    }

}

@media screen and (min-width: 1200px) {

    .workshop-header,
    .workshop-description {
        padding: 52px 121px 34px;
    }

    .workshop-description {
        padding-bottom: 215px;
    }

    .cell{
        padding: 44px 60px;
    }

}

/* ======================================
   Workshop detail speakers
   ====================================== */

.workshop-speaker {
    margin-bottom: 30px;
    box-shadow: 12px 12px 20px #0000001A;
}

.workshop-speaker-portrait {
    position: relative;
}

.workshop-speaker-portrait:before {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    background-color: #061715;
    mix-blend-mode: color;
}

.workshop-speaker-desc {
    position: relative;
    display: none;
    text-align: center;
    background-color: #A2EFEA;
    width: 100%;
    padding: 48px 48px 60px;
}

.workshop-speaker-desc-content {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

.workshop-speaker-desc h4 {
    font-size: 25px;
    margin-bottom: 4px;
}

.workshop-speaker:hover .workshop-speaker-portrait {
    display: none;
}

.workshop-speaker:hover .workshop-speaker-desc {
    display: block;
}

@media screen and (min-width: 576px) and (max-width: 767px){

    .workshop-speaker-desc {
        padding: 20px;
    }

    .workshop-speaker-desc h4 {
        font-size: 25px;
        margin-bottom: 4px;
    }

}


/* ==========================================================================
   BlockUI
   ========================================================================== */

.blockUI h1 {
    display: none;
}

/* ==========================================================================
   404
   ========================================================================== */


/* ==========================================================================
   Helper classes
   ========================================================================== */

.noscroll {
    overflow-y: hidden;
}

.scroll {
    overflow-y: scroll;
}

/*
 * Hide visually and from screen readers:
 */

.hidden {
    display: none !important;
}

/*
 * Hide only visually, but have it available for screen readers:
 * http://snook.ca/archives/html_and_css/hiding-content-for-accessibility
 */

.visuallyhidden {
    border: 0;
    clip: rect(0 0 0 0);
    height: 1px;
    margin: -1px;
    overflow: hidden;
    padding: 0;
    position: absolute;
    width: 1px;
}

/*
 * Extends the .visuallyhidden class to allow the element
 * to be focusable when navigated to via the keyboard:
 * https://www.drupal.org/node/897638
 */

.visuallyhidden.focusable:active,
.visuallyhidden.focusable:focus {
    clip: auto;
    height: auto;
    margin: 0;
    overflow: visible;
    position: static;
    width: auto;
}

/*
 * Hide visually and from screen readers, but maintain layout
 */

.invisible {
    visibility: hidden;
}

@media only screen and (min-width: 35em) {
    /* Style adjustments for viewports that meet the condition */
}

@media print,
       (-webkit-min-device-pixel-ratio: 1.25),
       (min-resolution: 1.25dppx),
       (min-resolution: 120dpi) {
    /* Style adjustments for high resolution devices */
}

/* ==========================================================================
   Print styles.
   Inlined to avoid the additional HTTP request:
   http://www.phpied.com/delay-loading-your-print-css/
   ========================================================================== */

@media print {
    *,
    *:before,
    *:after {
        background: transparent !important;
        color: #000 !important; /* Black prints faster:
                                   http://www.sanbeiji.com/archives/953 */
        box-shadow: none !important;
        text-shadow: none !important;
    }

    a,
    a:visited {
        text-decoration: underline;
    }

    a[href]:after {
        content: " (" attr(href) ")";
    }

    abbr[title]:after {
        content: " (" attr(title) ")";
    }

    /*
     * Don't show links that are fragment identifiers,
     * or use the `javascript:` pseudo protocol
     */

    a[href^="#"]:after,
    a[href^="javascript:"]:after {
        content: "";
    }

    pre,
    blockquote {
        border: 1px solid #999;
        page-break-inside: avoid;
    }

    /*
     * Printing Tables:
     * http://css-discuss.incutio.com/wiki/Printing_Tables
     */

    thead {
        display: table-header-group;
    }

    tr,
    img {
        page-break-inside: avoid;
    }

    img {
        max-width: 100% !important;
    }

    p,
    h2,
    h3 {
        orphans: 3;
        widows: 3;
    }

    h2,
    h3 {
        page-break-after: avoid;
    }
}

.lightbox .lb-image {
    border-radius: 0;
    border: 0;
}

.lightboxOverlay {
    background-color: rgba(45, 31, 64, 0.9);
}

img.gallery-img {
    opacity: 1;
    transition: opacity 0.3s;
}

img.gallery-img[data-src] {
    opacity: 0;
}

