body,
html {
    background: #fff;
    color: #2f302f;
    font-size: 16px;
    font-family: Arial, sansserif;
    font-weight: 300;
    line-height: 1.5;
}
body {
    visibility: hidden;
    opacity: 0;
    transition: all 1s;
}
.h1,
.h2,
.h3,
.h4,
.h5,
.h6,
.typography h1,
.typography h2,
.typography h3,
.typography h4,
.typography h5,
.typography h6,
h1,
h2,
h3,
h4,
h5,
h6 {
    font-family: Arial, sanserif;
    font-weight: 800;
    color: #2f302f;
}
.h1,
.h2,
.typography h1,
.typography h2,
h1,
h2 {
    line-height: 1.1;
}
.h3,
.h4,
.typography h3,
.typography h4,
h3,
h4 {
    line-height: 1.3;
}
.h1,
.typography h1,
h1 {
    font-size: 300%;
    letter-spacing: -2px;
}
.h2,
.typography h2,
h2 {
    font-size: 250%;
    letter-spacing: -1px;
}
.h3,
.typography h3,
h3 {
    font-size: 220%;
}
.h4,
.typography h4,
h4 {
    font-size: 180%;
}
.h5,
.typography h5,
h5 {
    font-size: 120%;
}
.link,
.typography a,
a {
    color: #2f302f;
    text-decoration: none;
}
.link:visited,
.typography a:visited,
a:visited {
    color: shade(#2f302f, 40%);
}
.link:hover,
.link:visited:hover,
.typography a:hover,
.typography a:visited:hover,
a:hover,
a:visited:hover {
    color: tint(#2f302f, 90%);
}
.fixed,
.typography code,
.typography pre {
    font-family: PT Mono;
    font-size: 14px;
    line-height: 1.2;
}
.quiet {
    font-color: #2f302f;
}
.bold,
.loud,
.typography b,
.typography strong {
    font-color: #e6007e;
}
.italic,
.typography em,
.typography i {
    font-style: italic;
}
.bold,
.typography b,
.typography strong {
    font-weight: 700;
}
.block-margins,
.typography ol,
.typography p,
.typography pre,
.typography ul {
    margin: 16px 0;
    margin: 1rem 0;
}
.typography ul,
.unordered-list {
    list-style-type: disc;
    margin-left: 20px;
    margin-left: 1.25rem;
}
.ordered-list,
.typography ol {
    list-style: decimal;
    margin-left: 20px;
    margin-left: 1.25rem;
}
.typography h1,
.typography h2,
.typography h3,
.typography h4,
.typography h5,
.typography h6 {
    margin: 16px 0 8px;
    margin: 1rem 0 0.5rem;
}
.typography code,
.typography pre {
    white-space: normal;
    background: #2f302f;
    padding: 16px;
    padding: 1rem;
}
.bottone,
button,
input,
select,
textarea {
    display: block;
    position: relative;
    overflow: hidden;
    width: 100%;
    padding: 1% 2%;
    margin: 2% 0;
    border: none;
    background-color: #e6007e;
    color: #fff;
    transition: all 1s;
}
.bottone:hover,
button:hover,
input:hover,
select:hover,
textarea:hover {
    background-color: #2f302f;
    text-decoration: none;
}
.bottone:focus,
button:focus,
input:focus,
select:focus,
textarea:focus {
    background-color: #2f302f;
    color: #fff;
    outline: none;
}
.bottone::-webkit-input-placeholder,
button::-webkit-input-placeholder,
input::-webkit-input-placeholder,
select::-webkit-input-placeholder,
textarea::-webkit-input-placeholder {
    color: #fff;
}
.bottone::-moz-placeholder,
button::-moz-placeholder,
input::-moz-placeholder,
select::-moz-placeholder,
textarea::-moz-placeholder {
    color: #fff;
}
.bottone:-ms-input-placeholder,
button:-ms-input-placeholder,
input:-ms-input-placeholder,
select:-ms-input-placeholder,
textarea:-ms-input-placeholder {
    color: #fff;
}
.bottone::placeholder,
button::placeholder,
input::placeholder,
select::placeholder,
textarea::placeholder {
    color: #fff;
}
.bottone,
button {
    color: #fff;
    background-color: #e6007e;
}
.bottone,
.bottone:hover,
button,
button:hover {
    border-bottom: none;
}
.bottone:focus,
button:focus {
    border-bottom: none;
    background-color: #e6007e;
    color: #fff;
}
header {
    display: block;
    position: fixed;
    left: 0;
    top: 0;
    padding: 1% 0;
    width: 100%;
    z-index: 3;
    transition: all 0.5s;
}
header.scroll {
    background-color: hsla(0, 0%, 100%, 0.6);
}
header.aperto nav #login_short {
    color: #fff;
}
header.aperto nav #login_short #icona_login {
    fill: #fff;
}
header.aperto nav #login_short:hover {
    color: #7b7d7b;
}
header.aperto nav #login_short:hover #icona_login {
    fill: #7b7d7b;
}
header #logo {
    display: block;
    position: relative;
    overflow: hidden;
    max-width: 350px;
    height: auto;
    margin-top: 0;
    transition: all 0.5s;
}
@media (min-width: 48em) {
    header #logo {
        height: auto;
        margin-top: 0;
    }
}
header #logo img {
    display: block;
    position: relative;
    top: 0;
    left: 0;
    width: auto;
}
header #logo.aperto img {
    top: -30px;
}
@media (min-width: 48em) {
    header #logo.aperto img {
        top: -40px;
    }
}
header nav {
    display: block;
    float: right;
    width: 80px;
    font-size: 0.7em;
    text-align: center;
}
header nav,
header nav #login_short {
    position: relative;
    height: 40px;
    cursor: pointer;
}
header nav #login_short {
    display: none;
    overflow: hidden;
    width: 40px;
    margin-right: 5px;
    float: left;
}
@media (min-width: 48em) {
    header nav #login_short {
        display: block;
    }
}
header nav #login_short #icona_login {
    width: 20px;
    height: 20px;
    fill: #2f302f;
}
header nav #login_short:hover {
    color: #e6007e;
}
header nav #login_short:hover #icona_login {
    fill: #e6007e;
}
header nav .hamburger {
    display: block;
    position: relative;
    overflow: hidden;
    width: 35px;
    float: right;
}
header nav .hamburger .linea {
    display: block;
    position: relative;
    overflow: hidden;
    background-color: #2f302f;
    height: 3px;
    width: 30px;
    margin: 3px auto;
    opacity: 1;
    transition: all 0.5s;
}
header nav .hamburger .linea.centrale {
    margin-top: -6px;
}
header nav .hamburger:hover .linea {
    width: 35px;
}
header nav .hamburger:hover .linea.centrale,
header nav .hamburger:hover .linea.centrale_sopra {
    width: 20px;
}
header nav .hamburger .visibile {
    display: none;
}
header nav .hamburger .invisibile {
    display: inline-block;
}
header nav.aperto {
    color: #fff;
}
header nav.aperto .hamburger .linea {
    opacity: 0;
    background-color: #fff;
}
header nav.aperto .hamburger .linea.centrale {
    opacity: 1;
    transform: rotate(-45deg);
    width: 25px;
}
header nav.aperto .hamburger .linea.centrale_sopra {
    opacity: 1;
    transform: rotate(45deg);
    width: 25px;
}
header nav.aperto .hamburger .visibile {
    display: inline-block;
}
header nav.aperto .hamburger .invisibile {
    display: none;
}
#menu {
    position: fixed;
    padding: 0 1em;
    left: 0;
    width: 100%;
    background-color: #e6007e;
    z-index: 2;
    transition: all 0.5s;
}
#menu,
#menu ul {
    display: block;
    overflow: hidden;
}
#menu ul {
    position: relative;
    padding: 0;
    list-style: none;
}
#menu ul li {
    margin: 0;
    padding: 0;
}
#menu ul li a {
    display: inline-block;
    position: relative;
    color: #fff;
    font-size: 150%;
    line-height: 2;
    text-transform: uppercase;
}
@media (min-width: 48em) {
    #menu ul li a {
        font-size: 380%;
        line-height: 1.1;
    }
}
@media (min-width: 62em) {
    #menu ul li a {
        font-size: 500%;
    }
}
#menu ul li a:before {
    content: "";
    display: block;
    position: absolute;
    width: 0;
    height: 5px;
    background-color: #fff;
    top: 50%;
    left: 0;
    transition: all 1s;
    z-index: 0;
}
#menu ul li a:hover {
    color: #fff;
    text-decoration: none;
}
#menu ul li a:hover:before {
    width: 100%;
}
main {
    z-index: 1;
    transition: all 0.5s;
}
main,
main section {
    display: block;
    position: relative;
    overflow: hidden;
}
main section .centra {
    display: block;
    position: absolute;
    overflow: hidden;
    z-index: 1;
}
main section .centra img {
    width: 100%;
    height: auto;
}
main section .bg {
    display: block;
    position: relative;
    overflow: hidden;
    width: 100%;
    background-position: 50%;
    background-repeat: no-repeat;
    background-size: cover;
    z-index: 0;
}
main section#home .bg {
    background-image: url(../images/home.jpeg);
}
main section#home h1,
main section#home h3 {
    color: #2f302f;
}
@media (min-width: 48em) {
    main section#home h1,
    main section#home h3 {
        font-size: 400%;
    }
}
@media (min-width: 62em) {
    main section#home h1,
    main section#home h3 {
        font-size: 500%;
    }
}
main section#login h1,
main section#login h2,
main section#home h3 {
    color: #2f302f;
}
main section#login h1,
main section#home h3 {
    font-size: 200%;
}
@media (min-width: 48em) {
    main section#login h1,
    main section#home h3 {
        font-size: 250%;
    }
}
@media (min-width: 62em) {
    main section#login h1,
    main section#home h3 {
        font-size: 350%;
    }
}
main section#login h2 {
    font-size: 120%;
}
@media (min-width: 48em) {
    main section#login h2 {
        font-size: 180%;
    }
}
@media (min-width: 62em) {
    main section#login h2 {
        font-size: 250%;
    }
}
main section#login .bg {
    background: transparent;
}
main section#login .recupero {
    display: block;
    position: relative;
    margin-top: 8%;
}
main section#login .recupero a {
    display: block;
    position: relative;
    overflow: hidden;
}
main section.breack#rotto1 .bg {
    background-image: url(../fe_images/breack_1.jpeg);
}
main section.breack#rotto2 .bg {
    background-image: url(../fe_images/breack_2.jpeg);
}
footer {
    text-align: center;
    font-size: 0.8em;
}
footer,
footer a {
    color: #7b7d7b;
}


.content-login{
    width: 360px;
    height: 360px;
    position: absolute;
    top: 50%;
    left: 50%;
    margin: -180px 0 0 -180px;
}

.content-login input{
    width: 100%;
}

.content-login .logo{
    margin-bottom: 30px;
}

.content-login label{
    font-size: 16px;
    font-weight: 400;
    color: #0F0F0F;
}


.content-login input{
    background-color: #F7F9FA;
    color: #000000;
    margin: 0 0 30px 0;
    padding: 10px;
    border-radius: 2px;
}

.content-login button{
    background-color: #1D87A8;
    color: white;
    text-align: center;
    text-transform: uppercase;
    font-size: 16px;
    font-weight: 700;
    padding: 10px;
    border-radius: 2px;
}



