* {
    box-sizing: border-box;
    padding: 0;
    margin: 0;
}

html {
    font-size: 100%;
    -webkit-text-size-adjust: 100%;
    -ms-text-size-adjust: 100%;
}

body {
    font-family: "Verdana";
    font-size: 16px;
    line-height: 22px;
    color: #333;
    background: #172b1b;
}

h1 {
    font-size: 2em;
    line-height: 1em;
    margin-bottom: 50px;
}

h2 {
    font-size: 1.5em;
    margin-bottom: 20px;
}

h3 {
    font-size: 1.2em;
    margin-bottom: 10px;
}
h4 {
    font-size: 1em;
    margin-bottom: 10px;
}
p {
    margin-bottom: 15px;
}

ol,
ul {
    list-style: none;
}

a {
    text-decoration: none;
    color: #172b1b;
}

img {
    max-width: 100%;
}
fieldset {
    border: 0;
}
footer a,
main a {
    position: relative
}

footer a::after,
main a::after {
    content: " ";
    width: 100%;
    height: 1px;
    background: #172b1b;
    position: absolute;
    left: 0;
    bottom: 50%;
    opacity: 0;
    transition: 0.3s;
}
footer a:hover::after,
main a:hover::after {
    bottom: -5px;
    opacity: 1;
}

.wrapper {
    width: 100%;
    max-width: 1080px;
    margin: 0 auto;
}

#contentInfo .newsflash,
.flexBox {
    display: flex;
    flex-direction: row;
}

header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 30px 0;
}

header #logo {
    max-width: 120px;
}
header nav ul li {
    display: inline-block;
    position: relative
}

header nav ul li a {
    color: #fff;
    font-weight: bold;
    padding: 10px;
}

@media(min-width: 1025px) {
    header nav ul li a::after {
        content: " ";
        width: 100%;
        height: 2px;
        background: #fff;
        position: absolute;
        left: 0;
        bottom: 50%;
        opacity: 0;
        transition: 0.3s;
    }

    header nav ul li.active a::after,
    header nav ul li:hover a::after {
        bottom: -10px;
        opacity: 1;
    }
    header nav ul li:hover ul,
    header nav ul li:focus ul,
    header nav ul li:active ul {
       display: block
    }
    header nav ul ul {
    display: none;
        position: absolute;
        background: #fff;
        border: 1px solid #172b1b;
        padding: 5px 0;
        z-index: 9;
    }
    header nav ul ul li {
        width: 100%;
        display: block;
        padding: 0 10px;
    }
    header nav ul ul li a {
        color: #333;
        white-space: nowrap;
        border-bottom:  1px solid #172b1b;
        display: block;
        padding: 5px;
    }
    header nav ul ul li:last-child a {
        border-bottom: 0;
    }
    header nav ul ul li:hover a {
        color: #fff;
        background: #172b1b;
    }
}

#banner {
    margin-bottom: 5px;
    width: 100%;
    overflow: hidden
}

#banner img {
    width: 100%;
}

#contentLeft,
#footerLeft {
    background: #fff;
    padding: 50px;
    width: 59%;
    width: calc(60% - 5px);
    margin-right: 5px;
}

#contentLeft.full {
    width: 100%;
    margin-right: 0;
}
#contentRight,
#footerRight {
    background: #fff;
    padding: 50px;
    width: 40%;
}
.termine .news_item,
#contentRight .news_item {
    border-bottom: 1px solid #172d1d;
    padding-bottom: 40px;
    margin-bottom: 40px;
    position: relative
}
.termine .news_item:last-of-type,
#contentRight .news_item:last-of-type {
    border-bottom: 0;
    padding-bottom: 0px;
    margin-bottom: 0px;
}
.termine .news_item .newsflash-title,
#contentRight .news_item .newsflash-title {
    margin-bottom: 10px;
}
.termine .news_item .dateBox,
#contentRight .news_item .dateBox {
    color: #fff;
    background: #172d1d;
    padding: 8px;
    position: absolute;
    bottom: 40px;
    right: -50px;
    text-align: center;
    text-transform: uppercase;
    height: 60px;
    width: 60px;
}

.termine .news_item:last-of-type .dateBox,
#contentRight .news_item:last-of-type .dateBox {
    bottom: 0;
}

.termine .news_item .dateBox b,
#contentRight .news_item .dateBox b {
    display: block;
    font-size: 1.2em;
}

#contentInfo {
    margin: 5px 0;
    background: #fff;
    clear: both;
    padding: 50px;
}

#contentInfo h2 {
    text-align: center;
}

#contentInfo .newsflash {
    margin: 0 -15px;
}

#contentInfo .news_item {
    padding: 15px;
}
#contentInfo .news_item h1 {
    font-size: 22px;
}
#contentInfo .news_item h3 {
    margin: 10px 0 15px;
}
#contentGallery .custom {
    display: flex;
    margin: 5px 0;
}
#contentGallery .galleryLeft {
    background: #fff;
    padding: 50px;
    width: 40%;
}
#contentGallery .galleryRight {
    background: #fff;
    padding: 50px 30px;
    width: calc(60% - 5px);
    margin-left: 5px;
}
#contentGallery .galleryRight::after {
   display: table;
    clear: both;
    content: " ";
}
#contentGallery .galleryRight img {
    float: left;
    width: 50%;
    padding: 20px;
}
footer {
    margin: 5px 0 50px;
}
footer img {
    max-width: 120px;
    display: block;
    margin-bottom: 15px;
}
footer h4 {
    margin-bottom: 15px;
}

footer .pl-1 {
    padding-left: 30px;
}
div[class^="huge_it_slideshow_description_text_gallery"] {
    display: none !important;
}
div[class^="huge_it_slideshow_image_wrap_gallery"] {
    margin-left: 0;
}
main ul {
    padding-left: 20px;
    margin-bottom: 20px;
}
main ul li {
    padding: 3px 0;
    list-style: disc;
}

#acco h2 {
    position: relative;
    display: block;
    padding: 10px 50px 10px 10px;
    border: 1px solid #ddd;
    cursor: pointer;
    font-size: 20px;
    line-height: 25px;
}
#acco h2::after {
    content: "+";
    position: absolute;
    right: 10px;
    top: 50%;
    transform: translate(0,-50%);
}
#acco h2.open {
    border-color: #172b1b;
    background: #172b1b;
    color: #fff;
}
#acco h2.open::after {
    content: "-";
}
#acco .tab {
    display: none;
    border: 1px solid #ddd;
    padding: 15px;
    margin-top: -22px;
    margin-bottom: 20px;
    transition: 0.2s ease-out;
}
#acco .tab.open {
    display: block
}
#acco .tab hr {
    border-top: 1px solid #333;
    border-bottom: 0;
    margin: 40px 0 30px;
}
table {
    border-collapse: collapse;
    width: 100%;
    margin-bottom: 20px;
    text-align: center;
}
table tr:nth-child(odd) {
    background: #eee;
}
table tr th {
     border: 1px solid #172b1b;
    background: #172b1b;
    color: #fff;
    padding: 8px;
}
table tr td {
    border: 1px solid #172b1b;
    padding: 8px
    
}
.contact h3 {
    margin-top: 50px;
}
#modal-jform_consentbox,
.popover,
.contact legend {
    display: none !important;
}
.contact label {
    margin-top: 15px;
    display: block;
}
.contact input[type="text"],
.contact input[type="email"] {
    padding: 5px 10px;
    width: 100%;
}
.contact textarea {
    width: 100%;
}
.contact .btn-primary {
     background: #172b1b;
    color: #fff;
    padding: 8px;
    border: 0;
    margin-top: 20px;
}
@media(max-width: 1130px) {
    .wrapper {
        padding: 0 15px;
    }
}
@media(max-width: 1024px) {
    .navbar-toggle a {
        float: right;
        width: 40px;
        height: 40px;
        background: #fff;
        padding: 6px 0;
        cursor: pointer;
    }
    .navbar-toggle a span {
        width: 30px;
        height: 2px;
        background: #172b1b;
        margin: 5px auto;
        display: block;
    }
    header nav .navbar {
        display: none;
    }
    header nav.open .navbar {
        display: block;
        position: fixed;
        left: 0;
        top: 0;
        height: 100%;
        z-index: 99;
        width: 300px;
        padding: 50px 20px;
        background: #fff;
    }
    header nav ul > li > a  {
        border-bottom: 1px solid #172b1b;
    }
    header nav ul li,
    header nav ul li a {
        display: block;
        color:  #172b1b;
    }
    header nav ul li.active > a {
        background: #172b1b;
        color: #fff;
    }
    header nav ul li.parent .toggle {
        cursor: pointer
    }
    header nav ul li.parent .toggle::after {
        display: block;
        content: "+";
        width: 40px;
        text-align: center;
        height: 40px;
        font-size: 25px;
        padding: 7px;
        box-sizing: border-box;
        float: right;
    } 
    header nav ul li.parent .toggle.open::after {
        content: "-";
    }
    header nav ul li.active .toggle {
        color: #fff;
    }
    
    header nav ul ul {
        display: none;
        padding-left: 20px;
    }
    header nav ul ul.open {
        display: block;
    }
}
@media(max-width: 991px) {
    h1 {
        font-size: 1.5em;
        line-height: 1em;
        margin-bottom: 30px;
    }
}
@media(max-width: 768px) {
    p img {
        float: none !important;
    }
    #contentInfo h2 {
        text-align: left;
    }
    #contentInfo .newsflash, 
    .flexBox,
    #contentGallery .custom {
        display: block;
    }
    #footerLeft .flexBox {
        display: flex
    }
    #contentRight,
    #contentLeft,
    #footerRight,
    #footerLeft,
    #contentGallery .galleryLeft,
    #contentGallery .galleryRight{
        width: 100%;
        margin: 0 0 5px;
    }
    #footerRight {
        text-align: center
    }
    #footerRight img {
        margin: 0 auto 10px;        
    }
    #footerRight br {
        display: none;
    }
}
@media(max-width: 515px) {
   #footerLeft  {
        text-align: center;
    } 
    #footerLeft .flexBox {
        display: block
    } 
    footer .pl-1 {
        padding-left: 0;
        padding-top: 50px;
    }
}
@media(max-width: 425px) {
    #contentGallery .galleryRight img {
        float: none;
        width: 100%;
        margin-bottom: 10px;
    }
    table {
            display: block;
    overflow-x: auto;
    white-space: nowrap;
    }
}