body {
    Opacity: 0;
    visibility: visible !important;
    background-color: #fff;
    color: #000000;
    font-family: 'Roboto', sans-serif;
    font-size: 13px;
    -webkit-font-smoothing: antialiased;
    font-weight: 300;
    line-height: 24px;
    overflow-x: hidden !important
}

a, a:hover {
    text-decoration: none
}

h1, h2, h3 {
    font-size: 25px;
    font-weight: 300;
    letter-spacing: .08em;
    line-height: 1.21em
}

a, p a {
    color: #000;
    text-decoration: none;
    -webkit-transition: color .2s ease-out;
    -o-transition: color .2s ease-out;
    transition: color .2s ease-out
}

.btnCustom {
    font-family: inherit;
    position: relative;
    display: inline-block;
    vertical-align: middle;
    width: auto;
    outline: 0;
    line-height: 22px;
    letter-spacing: .1em;
    font-weight: 600;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    margin: 0;
    -webkit-transition: color .15s ease-out, background-color .15s ease-out, border-color .15s ease-out;
    -o-transition: color .15s ease-out, background-color .15s ease-out, border-color .15s ease-out;
    transition: color .15s ease-out, background-color .15s ease-out, border-color .15s ease-out;
    padding: 17px 51px;
    font-size: 13px;
    cursor: pointer;
    background-color: #000;
    color: #fff !important
}

.btnCustomSimple {
    font-family: inherit;
    position: relative;
    display: inline-block;
    vertical-align: middle;
    width: auto;
    outline: 0;
    line-height: 18px;
    letter-spacing: .1em;
    font-weight: 300;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    margin: 0;
    -webkit-transition: color .15s ease-out, background-color .15s ease-out, border-color .15s ease-out;
    -o-transition: color .15s ease-out, background-color .15s ease-out, border-color .15s ease-out;
    transition: color .15s ease-out, background-color .15s ease-out, border-color .15s ease-out;
    padding: 17px 51px;
    font-size: 13px;
    cursor: pointer;
    border: 1px solid #000;
    color: #000
}

main {
}

.noContainerPadding {
    padding: 0px !important;
    margin: 0px !important
}

form input, form textarea {
    width: 100%;
    margin: 0 0 46px;
    padding: 9px 0;
    font-family: inherit;
    font-size: 15px;
    line-height: 24px;
    font-weight: 300;
    color: #878787;
    background-color: transparent;
    border: none;
    border-bottom: 1px solid #e1e1e1;
    border-radius: 0;
    outline: 0;
    -webkit-appearance: none;
    -webkit-box-sizing: border-box;
    box-sizing: border-box
}

form textarea {
    padding: 10px;
    border: 1px solid #e1e1e1
}

form input[type='checkbox'] {
    background-color: gray;
    border: none;
    border-bottom: 1px solid #e1e1e1;
    border-radius: 0;
    outline: 0;
    -webkit-appearance: checkbox;
    -webkit-box-sizing: border-box;
    box-sizing: border-box
}

footer {
    bottom: 0;
    left: 0;
    width: 100%;
    height: 60px;
    line-height: 60px;
    background-color: #fff;
    border-top: 1px dashed #ccc;
    opacity: 1;
    position: fixed;
    padding: 0px 25px 0px 25px
}

main {
    margin-bottom: 100px
}

h1 {
    color: #000 !important
}

h2, h3 {
    font-size: 1.3em;
    font-weight: 300;
    letter-spacing: .08em;
    line-height: 1.5em;
    font-weight: bold;
}

h4{font-size: 1rem!important;}

.key {
    color: #ff0000 !important
}

::selection {
    background: #000;
    color: #fff
}

::-moz-selection {
    background: #000;
    color: #fff
}

.btnCustomSimple:hover {
    -webkit-transition: color .15s ease-out, background-color .15s ease-out, border-color .15s ease-out;
    -o-transition: color .15s ease-out, background-color .15s ease-out, border-color .15s ease-out;
    transition: color .15s ease-out, background-color .15s ease-out, border-color .15s ease-out;
    background-color: #000;
    color: #fff
}

.btnCustomSimpleLessPadding {
    padding: 5px 10px !important
}

.btnCustomSimpleInverse {
    background-color: #000;
    color: #fff
}

.btnCustomSimpleInverse:hover {
    background-color: #fff;
    color: #000 !important;
    border: 1px solid #000
}

.smallInputText input {
    font-size: 10px
}

.bold {
    font-weight: bold !important
}

.zoom50 {
    zoom: 75% !important
}

.zoom40 {
    zoom: 65% !important
}

.zoom75 {
    zoom: 80% !important
}

.navG {
    padding: 0 !important
}

.top2p {
    top: 2px !important
}

.navbar ul li a {
    font-size: 13px;
    line-height: 23px;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    letter-spacing: .08em;
    text-transform: uppercase;
    font-weight: 600
}

.item_inner {
    position: relative;
    top: -10px;
    color: #9c9c9c
}

.item_outer {
    position: relative
}

.item_outer::after {
    content: '';
    transform-origin: 0 0;
    transform: scaleX(0);
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: .4em;
    background: #000;
    z-index: -1;
    opacity: 0.8
}

.item_outer:hover::after {
    transform: scaleX(1)
}

.item_outer_active:after {
    content: '';
    transform-origin: 0 0;
    transform: scaleX(0);
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: .4em;
    background: #000;
    z-index: -1;
    opacity: 0.8
}

.item_outer_active::after {
    transform: scaleX(1)
}

.item_outer_active .item_inner {
    color: #000
}

.stickOnScroll {
    position: fixed;
    width: 100%;
    background-color: #fff
}

#map {
    height: 400px;
    width: 100%
}

.navbar-toggler-icon {
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg viewBox='0 0 32 32' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath stroke='rgba(0,0,0, 1)' stroke-width='2' stroke-linecap='round' stroke-miterlimit='10' d='M4 8h24M4 16h24M4 24h24'/%3E%3C/svg%3E")
}

.col-sm, .col-sm-3, .col-sm-9 {
    padding-left: 0 !important
}

.row {
    margin-left: 0 !important;
    margin-right: 0 !important
}

.projectInfo {
}

.text-black {
    color: #000 !important
}

.text-bold {
    font-weight: bold !important
}

.text-noBold {
    font-weight: 300 !important
}

.text-bigger {
    font-size: 1.2em
}

.text-normal {
    font-size: 1em !important
}

.text-small {
    font-size: 0.85em
}

.text-ultra-bigger {
    font-size: 1.7em !important
}

.text-super-bigger {
    font-size: 1.5em !important
}

#loaderOverlay {
    width: 100%;
    height: 100%;
    position: fixed;
    left: 0;
    top: 0;
    background-color: #fff !important;
    opacity: 1;
    z-index: 1000000 !important
}

#loaderOverlay .loaderOverlayContent {
    text-align: center;
    position: relative;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%) !important;
    -ms-transform: translate(-50%, -50%) !important;
    transform: translate(-50%, -50%) !important
}

.ddCat {
    font-size: 1.5em !important;
    color: #000;
    font-weight: bold
}

@media (min-width: 1200px) {
    .container {
        max-width: 1020px
    }
}

.fullWidthProject {
    width: 100vw;
    position: relative;
    margin-left: -50vw;
    left: 50%;
    padding: 0px 200px
}

.marginTop {
    margin-top: 45px
}

.projectsHome {
    margin: 0 0 87px 0
}

.projectsHome:last-of-type {
    margin: 0 0 40px 0
}

.max {
    max-width: 980px !important
}

.linkHome {
    font-weight: 500;
    font-size: 1.5em;
    text-align: center;
    margin-top: 35px
}

.descriptionHome {
    max-width: 700px;
    color: #000;
    font-size: 0.9em;
    margin: 8px 0 8px;
    line-height: 20px;
    text-align: justify
}
#cookie-bar-prompt-content{margin-top:200px!important}
.separatorHomeLeft {
    left: 0;
    width: 180px;
    border-top: 1px solid #000;
    margin-bottom: 50px
}
#cookie-bar-prompt-logo{display:none!important}
#cookie-bar-button{background-color:transparent!important}
#cookie-bar{padding:16px!important;    bottom:60px!important;}
.separatorHomeRight {
    float: right;
    width: 180px;
    border-top: 1px solid #000;
    margin-top: 40px;

}

.overlayContact, .overlayConfid, .overlayLegals {
    position: fixed;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: rgba(255, 255, 255, 0.95);
    cursor: default !important
}

.maxZindex {
    z-index: 10000000 !important
}

.midZindex {
    z-index: 1000000 !important
}

.switchName {
    position: relative;
    top: -3px
}

.switchNameCh {
    position: relative;
    top: -1px;
    margin-right: 5px
}

.text-center {
    text-align: center !important
}

.authorDesc {
    font-size: 0.9em
}

.authorDesc p {
    margin: 8px 0 8px;
    line-height: 21px
}

.btnAllProjects {
}

.uppercase {
    text-transform: uppercase !important
}

.black {
    color: #111 !important
}

.gray {
    color: #878787
}

.darkGray {
    color: #2f2f2f
}

.lightGray {
    color: #dedede
}

.darkLessGray {
    color: #4f4f4f
}

.linkCodeQuantum a {
    color: #878787 !important;
    font-weight: normal;
}

.linkCodeQuantum {
    color: #9f9f9f !important;
    font-weight: normal;
    font-size: 0.8em;
    top: 2px
}

.red {
    color: #ff0000 !important
}

.darkRed {
    color: #b30101 !important
}

.white {
    color: #fff !important
}

.green {
    color: #003300 !important
}

.bgTeal {
    background-color: #027a78 !important
}

.bgGold {
    background-color: #FFD700 !important
}

.bgDarkGold {
    background-color: #e6c200 !important
}

.gold {
    color: #FFD700 !important
}

.bgGreen {
    background-color: #003300 !important
}

.bgLightGreen {
    background-color: #018001 !important
}

.bgBlack {
    background-color: #000 !important
}

.bgRed {
    background-color: #660000 !important
}

.fw400 {
    font-weight: 400 !important
}

.borderBlack {
    border: 1px solid #000 !important
}

.opacity5 {
    opacity: 0.5 !important
}

.cursorNotAllowed {
    cursor: not-allowed !important
}

.cursorPointer {
    cursor: pointer !important
}

.backtotop {
    position: fixed;
    width: 20px;
    right: 20px;
    bottom: 17px;
    margin: 0;
    z-index: 10000;
    opacity: 0
}
.backtotop img{width:15px}
#containerP {
    color: #000 !important;
    font-size: 2em
}

.verySmall {
    font-size: 0.7em !important
}

.allWidth {
    position: absolute;
    left: -30%
}

main section {
    margin: 20px 0
}

main section h2 {
    margin: 30px 0
}

.noWrap {
    white-space: nowrap !important
}

.mb-6 {
    margin-bottom: 5.5rem !important
}

#isotope {
    column-count: 2
}

.textBlackShadow {
    text-shadow: 1px 0 0 #000, -1px 0 0 #000, 0 1px 0 #000, 0 -1px 0 #000, 1px 1px #000, -1px -1px 0 #000, 1px -1px 0 #000, -1px 1px 0 #000
}

.textLightGreyShadow {
    text-shadow: 1px 0 0 #ccc, -1px 0 0 #ccc, 0 1px 0 #ccc, 0 -1px 0 #ccc, 1px 1px #ccc, -1px -1px 0 #ccc, 1px -1px 0 #ccc, -1px 1px 0 #ccc
}

.insideProject h2 {
    font-size: 12px;
    font-weight: 500;
    letter-spacing: .08em;
    line-height: 1.33em;
    text-transform: uppercase;
    color: #000;
    width: 100%
}

.monospacedFont {
    font-family: monospace;
}

.cursorHelp {
    cursor: help !important
}

.cursorDefault {
    cursor: default !important
}

.menuCustom {
    float: right;
    top: 50px;
    position: relative
}

.borderBlack {
    border-color: #000 !important
}

.authorName {
    font-size: 1.5em
}

.homeH1 {
    font-size: 22px !important;
    font-weight: 600 !important;
    letter-spacing: .08em !important;
    line-height: 1.18em !important;
    text-transform: uppercase !important
}

.mw-150p {
    max-width: 150px !important
}

.mh-150p {
    max-height: 150px !important
}

.mw-200p {
    max-width: 200px !important
}

.mh-200p {
    max-height: 200px !important
}

input, input:focus, .sbc-btn:focus {

    box-shadow: none !important;
}

.filters label {
}

.nav-link {
    font-size: 1.2em;
    margin: 0 7px
}

a {
    font-weight: bold;
    text-decoration: underline
}

a:hover {
    color: #111
}

.brackets a::before,
.brackets a::after {
    display: inline-block;
    opacity: 0;
    -moz-transition: -moz-transform 0.3s, opacity 0.2s;
    -webkit-transition: -webkit-transform 0.3s, opacity 0.2s;
    transition: transform 0.3s, opacity 0.2s;
}

.fill {
    display: flex;
    justify-content: center;
    align-items: center;
    overflow: hidden
}

.fill img {
    flex-shrink: 0;
    min-width: 100%;
    min-height: 100%
}

.container-cover {
    width: 100%
}

.brackets a::before {
    content: '[';
    margin-right: 5px;
    -moz-transform: translateX(5px);
    -webkit-transform: translateX(5px);
    transform: translateX(5px);
}

.brackets a::after {
    content: ']';
    margin-left: 5px;
    -moz-transform: translateX(-5px);
    -webkit-transform: translateX(-5px);
    transform: translateX(-5px);
}

.brackets a:hover::before,
.brackets a:active,
.brackets a:hover::after,
.brackets a:focus::before,
.brackets a:focus::after {
    color: #7e0000;

    opacity: 1;
    -moz-transform: translateX(0px);
    -webkit-transform: translateX(0px);
    transform: translateX(0px);
}

.column::after {
	content: '';
	clear: both;
	display: block;
}
.column div {
	position: relative;
	float: left;
	margin: 0 0 0 25px;
	padding: 0;
}
.column div:first-child {
	margin-left: 0;
}
.column div span {
	position: absolute;
	bottom: -20px;
	left: 0;
	z-index: -1;
	display: block;

	margin: 0;
	padding: 0;
	color: #444;
	font-size: 18px;
	text-decoration: none;
	text-align: center;
	-webkit-transition: .3s ease-in-out;
	transition: .3s ease-in-out;
	opacity: 0;
}
figure {

	margin: 0;
	padding: 0;
	background: #fff;
	overflow: hidden;
}
figure:hover {
	bottom: -36px;
	opacity: 1;
}


/* Zoom In #1 */
.hover01 figure img {
	-webkit-transform: scale(1);
	transform: scale(1);
	-webkit-transition: .3s ease-in-out;
	transition: .3s ease-in-out;
}
.hover01 figure:hover img {
	-webkit-transform: scale(1.3);
	transform: scale(1.3);
}

/* Zoom In #2 */
.hover02 figure img {
	width: 300px;
	height: auto;
	-webkit-transition: .3s ease-in-out;
	transition: .3s ease-in-out;
}
.hover02 figure:hover img {
	width: 350px;
}

/* Zoom Out #1 */
.hover03 figure img {
	-webkit-transform: scale(1.5);
	transform: scale(1.5);
	-webkit-transition: .3s ease-in-out;
	transition: .3s ease-in-out;
}
.hover03 figure:hover img {
	-webkit-transform: scale(1);
	transform: scale(1);
}

/* Zoom Out #2 */
.hover04 figure img {
	width: 400px;
	height: auto;
	-webkit-transition: .3s ease-in-out;
	transition: .3s ease-in-out;
}
.hover04 figure:hover img {
	width: 300px;
}

/* Slide */
.hover05 figure img {
	margin-left: 30px;
	-webkit-transform: scale(1.5);
	transform: scale(1.5);
	-webkit-transition: .3s ease-in-out;
	transition: .3s ease-in-out;
}
.hover05 figure:hover img {
	margin-left: 0;
}

/* Rotate */
.hover06 figure img {
	-webkit-transform: rotate(15deg) scale(1.4);
	transform: rotate(15deg) scale(1.4);
	-webkit-transition: .3s ease-in-out;
	transition: .3s ease-in-out;
}
.hover06 figure:hover img {
	-webkit-transform: rotate(0) scale(1);
	transform: rotate(0) scale(1);
}

/* Blur */
.hover07 figure img {
	-webkit-filter: blur(3px);
	filter: blur(3px);
	-webkit-transition: .3s ease-in-out;
	transition: .3s ease-in-out;
}
.hover07 figure:hover img {
	-webkit-filter: blur(0);
	filter: blur(0);
}

/* Gray Scale */
.hover08 figure img {
	-webkit-filter: grayscale(100%);
	filter: grayscale(100%);
	-webkit-transition: .3s ease-in-out;
	transition: .3s ease-in-out;
}
.hover08 figure:hover img {
	-webkit-filter: grayscale(0);
	filter: grayscale(0);
}

/* Sepia */
.hover09 figure img {
	-webkit-filter: sepia(100%);
	filter: sepia(100%);
	-webkit-transition: .3s ease-in-out;
	transition: .3s ease-in-out;
}
.hover09 figure:hover img {
	-webkit-filter: sepia(0);
	filter: sepia(0);
}

/* Blur + Gray Scale */
.hover10 figure img {
	-webkit-filter: grayscale(0) blur(0);
	filter: grayscale(0) blur(0);
	-webkit-transition: .3s ease-in-out;
	transition: .3s ease-in-out;
}
.hover10 figure:hover img {
	-webkit-filter: grayscale(100%) blur(3px);
	filter: grayscale(100%) blur(3px);
}

/* Opacity #1 */
.hover11 figure img {
	opacity: 1;
	-webkit-transition: .3s ease-in-out;
	transition: .3s ease-in-out;
}
.hover11 figure:hover img {
	opacity: .5;
}

/* Opacity #2 */
.hover12 figure {
	background: #1abc9c;
}
.hover12 figure img {
	opacity: 1;
	-webkit-transition: .3s ease-in-out;
	transition: .3s ease-in-out;
}
.hover12 figure:hover img {
	opacity: .5;
}

/* Flashing */
.hover13 figure:hover img {
	opacity: 1;
	-webkit-animation: flash 1.5s;
	animation: flash 1.5s;
}
@-webkit-keyframes flash {
	0% {
		opacity: .4;
	}
	100% {
		opacity: 1;
	}
}
img{cursor:pointer}
@keyframes flash {
	0% {
		opacity: .4;
	}
	100% {
		opacity: 1;
	}
}

/* Shine */
.hover14 figure {
	position: relative;
}
.hover14 figure::before {
	position: absolute;
	top: 0;
	left: -75%;
	z-index: 2;
	display: block;
	content: '';
	width: 50%;
	height: 100%;
	background: -webkit-linear-gradient(left, rgba(255,255,255,0) 0%, rgba(255,255,255,.3) 100%);
	background: linear-gradient(to right, rgba(255,255,255,0) 0%, rgba(255,255,255,.3) 100%);
	-webkit-transform: skewX(-25deg);
	transform: skewX(-25deg);
}
.hover14 figure:hover::before {
	-webkit-animation: shine .75s;
	animation: shine .75s;
}
@-webkit-keyframes shine {
	100% {
		left: 125%;
	}
}
@keyframes shine {
	100% {
		left: 125%;
	}
}

/* Circle */
.hover15 figure {
	position: relative;
}
.hover15 figure::before {
	position: absolute;
	top: 50%;
	left: 50%;
	z-index: 2;
	display: block;
	content: '';
	width: 0;
	height: 0;
	background: rgba(255,255,255,.2);
	border-radius: 100%;
	-webkit-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
	opacity: 0;
}
.hover15 figure:hover::before {
	-webkit-animation: circle .75s;
	animation: circle .75s;
}
@-webkit-keyframes circle {
	0% {
		opacity: 1;
	}
	40% {
		opacity: 1;
	}
	100% {
		width: 200%;
		height: 200%;
		opacity: 0;
	}
}
@keyframes circle {
	0% {
		opacity: 1;
	}
	40% {
		opacity: 1;
	}
	100% {
		width: 200%;
		height: 200%;
		opacity: 0;}}