/*
/*
Theme Name: theme23
Theme URI: http://www.23bit.it/
Author: 23bit, 23bit.it
Author URI: http://www.23bit.it/
*/

/* General */

body{
    margin: 0;
    padding: 0;
    width: 100%;
    height: auto; 
    overflow-x: hidden;  
    color:#4340e8; 
    font-size: 14px; 
    font-family: 'Roboto Mono', monospace;
    background: #fff;

} 

.clear{
    clear: both
} 
a{
    text-decoration: none; 
    color:#cecece;  
    -webkit-transition: all .25s ease-out;
    -moz-transition: all .25s ease-out;
    -o-transition: all .25s ease-out;
    transition: all .25s ease-out;
}
a:hover{
    color: #fff
}
ul{
    margin: 0; 
    padding: 0;
    list-style: none; 
}
li{
    list-style-type: none;
}
img{
    border: 0;
}

.box{
    -moz-box-sizing: border-box; 
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}
li{
    float: left; 
    -moz-box-sizing: border-box; 
    -webkit-box-sizing: border-box; 
    box-sizing: border-box;
}

h1 {
    text-align: center;
    font-size: 32px;

}

input, textarea, select {
    font-family: 'lato',sans-serif;
    background: #cecece;  
    font-size: 14px; 
    border:none; 
    outline:none; 
    resize: none; 
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;  
    -webkit-transition: all .25s ease-out;
    -moz-transition: all .25s ease-out;
    -o-transition: all .25s ease-out;
    transition: all .25s ease-out;
}
.form input:focus, .form textarea:focus {}
input:-webkit-autofill {
    -webkit-box-shadow: 0 0 0px 1000px #666 inset;
}

.btn {} 
.btn:hover {}



::-webkit-input-placeholder { 
    color: #666; 
}
:-moz-placeholder { 
    color: #666; 
}
::-moz-placeholder { 
    color: #666; 
}
:-ms-input-placeholder { 
    color: #666; 
}


.cookies { 
    position: fixed; 
    display: none;  
    bottom: 0; 
    width: 100%;  
    background: #fff; 
    color: #000; 
    z-index: 999; 
    font-size: 14px; 
    text-align: center;
    border-top: 1px solid #000;
}
.cookies a {
    color: #000
}
.accetto { 
    background: #000; 
    padding: 5px; 
    color: #fff; 
    cursor: pointer 
}

.transition { 
    -webkit-transition: all .25s ease-out; 
    -moz-transition: all .25s ease-out; 
    -o-transition: all .25s ease-out; 
    transition: all .25s ease-out; 
}
.visible {
    opacity: 1 !important;
}



.ciccetto::after {
    content: ""; 
    width: 75px; 
    height: 2px; 
    background: #cecece; 
    display: block; 
    margin: auto; 
    margin-top: 5px
}



/* Structure */ 

#content{
    padding: 20px 20px 20px 170px;
    -moz-box-sizing: border-box; 
    -webkit-box-sizing: border-box;
    box-sizing: border-box;  

}

.content { 

    position: relative;
    margin: auto;
    -moz-box-sizing: border-box; 
    -webkit-box-sizing: border-box;
    box-sizing: border-box;    
}

.inner_content {
    padding: 0 100px; 
    position: relative; 
}

.wrapper {margin-top: 100px}



.load { 
    text-align: center;
    padding: 40px 0;
}

.load-more { 
    display: inline-block;
    padding: 10px;
    font-weight: 700;
    cursor: pointer;
    font-style: italic;
    font-size: 18px;
}

.load-more:hover .plus{
    -ms-transform: rotate(90deg);  
    -webkit-transform: rotate(90deg);  
    transform: rotate(90deg);
    -webkit-transition: all .25s ease-out;
    -moz-transition: all .25s ease-out;
    -o-transition: all .25s ease-out; 
    transition: all .25s ease-out; 
}

.noMore {
    position: absolute;
    width: 100%;
    bottom: 25px;
    display: none;
}


.rotate { 
    -webkit-animation: rotating .25s linear infinite; 
    -moz-animation: rotating .25s linear infinite;
    -ms-animation: rotating .25s linear infinite;
    -o-animation: rotating .25s linear infinite; 
    animation: rotating .25s linear infinite; 
}
@-webkit-keyframes rotating {
    from {
        -ms-transform: rotate(0deg); -moz-transform: rotate(0deg); -webkit-transform: rotate(0deg); -o-transform: rotate(0deg);  transform: rotate(0deg);
    }
    to {
        -ms-transform: rotate(90deg); -moz-transform: rotate(90deg); -webkit-transform: rotate(90deg); -o-transform: rotate(90deg); transform: rotate(90deg);
    }
}
@keyframes rotating {
    from {
        -ms-transform: rotate(0deg); -moz-transform: rotate(0deg); -webkit-transform: rotate(0deg); -o-transform: rotate(0deg); transform: rotate(0deg);
    }
    to {
        -ms-transform: rotate(90deg); -moz-transform: rotate(90deg); -webkit-transform: rotate(90deg); -o-transform: rotate(90deg);  transform: rotate(90deg);
    }
}




.errorpage{
    min-height: 500px;
    text-align: center;
    font-size: 32px;
    font-weight: 700;
}

.errorpage span {
    font-size: 48px;
    padding-bottom: 25px;
    display: inherit;
}




/* HEADER & MENU */

#head{
    width: 120px; 
    padding: 25px;
    position: fixed; 
    z-index: 999;
    top: 0;
}

.desktop {  
}
.desktop li {
    width: 100%;
}
.desktop li:last-child {
    background: none;
}
.desktop a{
    color: #4340e8;
    font-size: 14px;
}
.desktop a:hover {
   text-decoration: line-through;
} 
.menu{ 

    margin-top: 50px;	

} 

.menu li{
    text-align: center;
    text-transform: uppercase;	
}
.menu li:nth-child(2){
    margin: 10px 0;
}
#logo{  
    width: 100px;
    margin: auto;
}
#logo img{
    width: 100%; height: auto; 
}

.filter span{
    display: block;
    width: 100%;
    text-align: center;
    font-size: 12px;
    text-transform: lowercase;
    margin-top: 5px;
    cursor: pointer;
}

.filter span.selected{
    text-decoration: line-through;
}

.mobMenu{ 
    width: 30px; 
    height:20px; 
    padding: 20px 15px; 
    position: absolute; 
    z-index: 999; 
    right: 0px; 
    top: 10px; 
    cursor: pointer
}
#menu-line { 
    height: 2px; 
    background: #4340e8; 
    position: absolute;
    -webkit-transition: all .25s ease-out;
    -moz-transition: all .25s ease-out;
    -o-transition: all .25s ease-out;
    transition: all .25s ease-out;
}
.line-one {
    width: 30px; 
    top: 18px
}
.line-two {
    width: 30px; 
    top: 28px
}
.line-three {
    width: 30px; 
    top: 38px
}
/*
.mobMenu:hover .line-one{
width: 20px   
}
*/
.mobOpen .line-one{ 
    -ms-transform: rotate(45deg);
    -moz-transform: rotate(45deg);
    -webkit-transform: rotate(45deg);
    -o-transform: rotate(45deg);
    transform: rotate(45deg); 
    top: 30px;
    width: 30px !important;
}
.mobOpen .line-two{ 
    -ms-transform: rotate(-45deg); 
    -moz-transform: rotate(-45deg); 
    -webkit-transform: rotate(-45deg);
    -o-transform: rotate(-45deg);
    transform: rotate(-45deg);
    top: 30px;
}
.mobOpen .line-three{ 
    width: 0;
}
.mob { 
    position: absolute; 
    z-index: 998;
    margin-top: 80px;  
    width: 100%;  
    height: 100%;  
    background: #fff;  
    left: 0;  
    top: 0; 
    opacity: 0;
    visibility: hidden;
    height: 0;
    overflow: hidden;
    -webkit-transition: opacity .25s ease-out;
    -moz-transition: opacity .25s ease-out;
    -o-transition: opacity .25s ease-out;
    transition: opacity .25s ease-out;
}
.mob ul { 
    border-top: none; 
    width: 100%; 
    float: none; 
} 
.mob li {
    opacity: 0;
    padding: 20px;
    float: none !important; 
    color:#4340e8; 
    -webkit-transition: all .5s ease-out;
    -moz-transition: all .5s ease-out;
    -o-transition: all .25s ease-out;
    transition: all .5s ease-out; 
} 
.mob a {
    color:#4340e8 !important; 
}

.mob .arrow {display: none;}
.mob .sub { position: relative; top: 20px;  opacity: 1; visibility: visible; left: initial; width: 100%; background: none; border: none; padding: 0; display: none; }
.mob .sub a {  font-size: 18px !important; color: #ccc;}
.mob .sub ul { padding: 0 0 0 30px; margin: 0 0 30px !important; border-left: 3px solid #cecece; }
.mob .sub li { padding: 10px 0; }


.mob-sec {   border-top: 1px solid #333; }
.mob-sec a {font-size: 16px; color: #00A86B !important}
.mob-sec li { padding: 5px 20px !important; }



.open{ opacity: 1; visibility: visible;  height: calc(100vh - 80px )}
.open li {opacity: 1}



.scrolled {
    position: fixed !important;
    top: -20px !important;
    z-index: 9;
    background: #1e1e1e;
}

.isscrolled {  }

/* HOME e pagine interne */



.facebook_icon{
    background: url('images/facebook_icon.svg') center no-repeat ;  
}
.twitter_icon{
    background: url('images/twitter_icon.svg') center no-repeat ;  
}
.instagram_icon{
    background: url('images/instagram_icon.svg') center no-repeat ;  
}
.linkedin_icon{
    background: url('images/linkedin_icon.svg') center no-repeat ;  
}


.title{
    font-size: 32px;
    font-weight: 600;
    text-align: center;
    margin: 50px 0 20px;
}
.title.first{
    margin: 0 0 50px;
}


.grid h2 {
    font-size: 14px;
    margin: 10px 0;
    color: #4340e8;
    font-weight: 300;

}


.grid ul {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    grid-gap: 20px;
}

.grid li{
    width: 100%;
    display: none;
    margin-bottom: 30px;
    -moz-box-sizing: border-box; 
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}

.grid li img{
    width:100%;
    height: auto;
    display: block;
}


.grid li.visible{
    display: block;
}


/*HOME*/

.filter{
    width: 100%;
    padding: 0 0 10px;
}

/* SINGLE */


.project_infos {
    position: fixed;
    width: 520px;
    right: 50px;
    font-size: 13px;
}
.project_infos h1{
    text-align: left;
    font-size: 14px;
    margin: 0 0 20px;
}

.project_images{
    padding-right: 600px;
    -moz-box-sizing: border-box; 
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    position: relative;
}
.project_images img{
    width: 100%;
    height: auto;
    margin-bottom: 20px;
}
.project_images p:last-of-type img{
    margin-bottom: 0;
}
.project_images p{
    margin: 0;
}

.sep{

    margin: 50px 0;

}
.related {
    font-weight: 700 !important;
}



.about a{
    display: inherit;
    margin-top: 5px;
    color: #4340e8;
}
.about a:hover{
    text-decoration: line-through;
}
.about .project_infos {
    width: 50%;
    position: absolute !important;
    right: 0;
    padding-left: 50px;
    -moz-box-sizing: border-box; 
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}
.about .project_images{
    width: 50%;
}

.background { 
    position: absolute;
    width: 100%;
    height: calc(100vh - 40px );
    -webkit-background-size: cover !important;
    -moz-background-size: cover !important;
    -o-background-size: cover !important;
    background-size: cover !important;
}


/*FOOTER*/

#footer {
    position: fixed;
    width: 180px;
    bottom: 0;
    margin: 10px;
    font-size: 11px;
}







/*media screen*/


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


    .mobMenu  {
        display: none
    }  



} 


@media screen and (min-width: 1367px) and (max-width: 1600px) {


    .mobMenu  {
        display: none
    }  
    .project_infos {
        width: 370px;
    }
    .project_images{
        padding-right: 450px;
    }


}    

@media screen and (min-width: 1024px) and (max-width: 1366px) {

    .mobMenu  {
        display: none
    }
 
    .project_infos {
        position: relative !important;
        width: 100%;
        margin-bottom: 50px;
        right: 0 !important;
        top: 0 !important;
    }    
    .project_images {
        padding-right: 0;
    }

}  

@media screen and (min-width: 320px) and (max-width: 1023px) {
    .desktop {
        display: none
    }
    #head{ 
        width: 100%;
        height: 80px; 
        padding: 0;
        background: #fff;
    }
    #content {
        padding: 120px 20px 20px 20px;
    }
    #logo { 
        width: 50px;
        margin: 10px;
    }
    .content{
        max-width: 100%;

    }
 
    .project_infos {
        position: relative !important;
        width: 100%;
        margin-bottom: 50px;
        right: 0 !important;
        top: 0 !important;
    }      
    .project_images {
        padding-right: 0;
    }

    .about .project_images {
        width: 100%;
    }
    .about .project_infos {
        width: 100%;
        position: relative!important;
        right: 0;
        padding-left: 0;
        margin: 30px 0 0 0;
    }
    .background {
        position: relative; 
        width: 100%;
        height: 50vh;
    }

    #footer {
        position: relative;
        width: auto;
        margin: 20px;
    }
    .copy {
        font-size: 13px;
    }
} 

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

    .grid ul {
        grid-template-columns: repeat(2, 1fr);
    }


}

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

    .grid ul {
        grid-template-columns: repeat(2, 1fr);
    }


}

@media screen and (min-width: 320px) and (max-width: 479px) {


    .grid ul {
        grid-template-columns: repeat(1, 1fr);
    }


    .grid li .info {
        height: auto;
    }


    .freccia{
        bottom:75px;
    }

    .copylinks{


    }

}


