:root {
    --orange: #E8932C;
    --orange-hover: #a76313;
    --white: #FFF;
    --text: #111;
    --btn: #1a1a1a;
    --btn2: #141414;
}

h1, h2, h3, h4, h5, h6, .h1, .h2, .h3, .h4, .h5, .h6 {
    font-family: "Pompiere", cursive;
    font-weight: 500;
    line-height: 1.1;
    color: #D37F17;
}

.ce-intext.ce-right .ce-gallery, 
.ce-intext.ce-left .ce-gallery, 
.ce-above .ce-gallery {
    margin-bottom: 0;
}
.ce-left .ce-gallery, .ce-column {
    float: none;
}
.ce-center .ce-outer, 
.ce-center .ce-inner { 
    float: none; right: initial;
}

.ce-gallery figure {
    display: flex;
    justify-content: center;
    align-items: center;
}

.fe-space-top {
    margin-top: 4em;
}
.fe-space-bottom {
    margin-bottom: 4em;
}

.list-inline {
    padding-left: 0;
    list-style: none;
    display: flex;
    gap: 10px;
}

/* FORM */
.form-label {
    color: var(--text);
}
.form-check-wrapping-label {
    display: flex;
    gap: 18px;
    color: var(--text);
}
form .form-control { border-radius: 0;}
form .form-navigation { display: flex; justify-content: end;}
form .btn.btn-primary {
    padding: 0.6em 1.5em;
    background: var(--btn);
    color: var(--white);
    border: 1px solid var(--btn2);
    outline: none;
    border-radius: 0;
    transition: all .2s ease-in-out;
}
form .btn:first-child:active, 
form .btn:first-child:hover { 
    background: var(--orange); 
    transition: all .3s ease-in-out;
    border: 1px solid var(--btn2);
}


/* NAVIGATION */
#hotline {
    background: var(--orange);
    color: var(--text);
    border-radius: 0;
    border: none;
    top: -1.4em;
}
#hotline:hover {
    background: var(--orange-hover);
    color: var(--white);
}

#mainnav .container { display: block;}
#mainnav {
    min-height: 100px;
    margin-bottom: 20px;
    margin-top: 40px;
    border: 1px solid transparent;
    padding: 0;
    position: fixed !important;
}

#mainnav #nav-main {
    margin: 0;
    padding: 0;
}

.navbar-default .navbar-nav > li > a:hover, 
.navbar-default .navbar-nav > li > a:focus {
    color: #333;
    background-color: #e9e9e9;
    outline: none;
    text-decoration: none;
}

#navbarNav .navbar-nav,
.nav-item.dropdown .nav-link.dropdown-toggle {
    gap: 30px;
    text-transform: uppercase;
    font-weight: 500;
}

.navbar, 
.navbar > .container,
.navbar > .container-fluid {
    position: relative !important;
}

.navbar .nav-item.dropdown {
    position: static !important;
}

.navbar .dropdown-menu.megamenu-fullwidth {
    width: 100%;
    left: 0 !important;
    right: 0 !important;
    top: 100% !important;
    margin-top: 0;
    border-radius: 0; 
    transform: none !important; 
}

.dropdown a.nav-link {
    background-color: transparent;
    color: #333333;
    text-transform: capitalize;
    font-weight: 400;
}

@media (min-width: 992px) {
    .navbar-expand-lg .navbar-collapse {
        display: flex !important;
        flex-basis: content;
        justify-content: flex-end;
    }
}


/* Homepage Gallery */
.masonry {
  columns: 3;
  gap: 1.5em;
}

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

.masonry .teaser_image {
    position: relative;
    margin-bottom: 1.5em;
}

.masonry .teaser_image img {
    transition: all .2s ease-in-out;
}

.masonry .teaser_image:hover img {
    transform: scale(1.04);
    transition: all .3s ease-in-out;
}

.masonry .teaser_image .teaser_caption {
    background: rgba(0, 0, 0, 0.5);
    padding: 10px;
    display: block;
    position: absolute;
    bottom: 0;
    left: 30px;
    right: 30px;
    text-align: center;
    text-transform: uppercase;
    font-family: "Archivo Narrow", sans-serif;
    line-height: 1.8em;
    z-index: 100;
    color: white !important;
}

@supports (display: grid-lanes) {
  .masonry {
    display: grid-lanes;
    grid-template-columns: repeat(3, 1fr);
    columns: unset;
  }
}

@media(min-width: 593px) and (max-width: 1023px) {
  .masonry {
    columns: 2;
    gap: 1em;
  }
}

@media(max-width: 592px) {
  .masonry {
    columns: 1;
  }
}

/* Subpages Filter */
.nav-projects-categories div {
    display: flex;
    align-content: center;
    flex-direction: row;
    justify-content: center;
    align-items: center;
    margin-bottom: 1em;
}
.nav-projects-categories div a {
    display: flex;
    align-items: center;
}

/* FOOTER */
footer a { text-decoration: none;}
footer .copyright {
    text-align: center;
    margin-top: 2em;
}
footer .copyright span { color: var(--white);}

/* SUBPAGES */
#subpage a {
    color: var(--orange);
}

#subpage .image img {
    width: 100%;
    height: auto;
}


#subpage .ce-headline-center { color: var(--orange);}

#subpage .nav-projects-categories {
    margin: 1em 0;
}

#subpage .nav-projects-categories .btn-primary {
    background: var(--orange);
    color: var(--btn);
    border: transparent;
    border-radius: 0;
    transition: all .3s ease-in-out;
}

#subpage .nav-projects-categories .btn-primary:hover {
    background: var(--orange-hover);
    transition: all .3s ease-in-out;
}

#subpage .nav-projects-categories .btn-default {
    background: var(--btn);
    color: var(--white);
    border: transparent;
    border-radius: 0;
    transition: all .3s ease-in-out;
}

#subpage .nav-projects-categories .btn-default:hover {
    background: var(--orange-hover);
    color: var(--btn);
    transition: all .3s ease-in-out;
}


@media (min-width: 1024px) {
    .ce-gallery {
        display: grid;
        grid-template-columns: repeat(1, minmax(0, 1fr));
        gap: 1rem;
        width: 100%;
    }
    .ce-gallery[data-ce-columns="3"],
    .ce-gallery[data-ce-images="3"] {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
    .ce-gallery[data-ce-columns="4"],
    .ce-gallery[data-ce-images="4"] {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }
    .ce-gallery[data-ce-columns="6"],
    .ce-gallery[data-ce-images="6"] {
        grid-template-columns: repeat(3, minmax(0, 2fr));
    }
}

@media(max-width: 768px) {
    #navbarNav .navbar-nav, 
    .nav-item.dropdown .nav-link.dropdown-toggle {
        gap: 10px;
    }
    .navbar-collapse {
        margin-bottom: 2em;
    }
}

@media(max-width: 591px) {
    #mainnav { position: relative !important; margin-top: 0;}
    #mainnav .container { padding-top: 2em !important; }
    #hotline {
        top: 0;
        left: 0;
        right: 0;
    }
}