
@import url("https://cdn.jsdelivr.net/npm/bootstrap-icons@1.8.3/font/bootstrap-icons.css");

:root {
    --darkblue: #003955;
    --bggrey: #f2f7f8;
    --turqoise: rgb(79, 144, 157);
    --topcolor2: #80b4be;

}

* {
    outline: none;
}

body {
    background-color: var(--bggrey);
}

a {
    text-decoration: none;
    color: var(--darkblue);
}

a:hover {
    text-decoration: underline;
    color: red;
}

h1, h2, h3, h4, h5, h6 {
    color: var(--darkblue);
    font-family: "Rubik", sans-serif;
    font-weight: 400;
}

h1 {
    font-size: 1.9rem;
    margin-bottom: 1.9rem;
}

h2 {
    font-size: 1.7rem;
}

h3 {
    font-size: 1.4rem;
}

h4 {
    font-size: 1.2rem;
}

h5 {
    font-size: 1.1rem;
}

.bg-blue {
    background-color: var(--darkblue);
}

.nav-item {

}



li a.nav-link {
    color: var(--darkblue) !important;
    text-transform: uppercase;
    font-size: 1.1rem;
    padding: 1rem;
}

li a.nav-link.active {
    font-weight: bold;
}

li a.nav-link:hover {
    color: red;
    text-decoration: none;
}

a.dropdown-item:hover, a.dropdown-item:active, a.dropdown-item:focus {
    text-decoration: none;
    color:#FFF;
    background-color: var(--darkblue);
}


.branchennav a.nav-link {
    color: var(--darkblue) !important;
}

.font-light {
    font-weight: 300;
}

.small, small {
    font-size: 0.8rem;
}

.icon {
    color: #4f909d;
    font-size: 3rem;
}

.pageicon {
    margin-right: 0.8rem;
    font-size: 1rem;
}
.pageicon.iconlg {
    font-size: 1.1rem;
}

.mdi {
    color: var(--turqoise);
}


.round.round-info {
    /* background: #465673; */
    background: #4f909d;
}
.round {
    line-height: 55px;
    color: #ffffff;
    width: 55px;
    height: 55px;
    display: inline-block;
    font-weight: 400;
    text-align: center;
    font-size: 16px;
    border-radius: 100%;
    background: #009efb;
}

.round.round-info {
    background: #4f909d;
}

.media {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-align: start;
    align-items: flex-start;
}

.media-body {
    -ms-flex: 1;
    flex: 1;
}

.text-ver {
    color: #5b85af !important;
    font-size: 0.9rem;
}

.gridelement > div > div.card, div.flex-column > div {
    margin-bottom: 1rem;
}

.gridelement > div > div.card:last-child, div.flex-column > div:last-child {
    margin-bottom: 0rem;
}

tfoot td {
    font-weight: bold;
}

.table {
    font-size: 0.9rem;
    margin-bottom: 60px;
}

.table-responsive > .table {
    margin-bottom: 15px;
}

.table>:not(:first-child) {
    border-top: 0px solid currentColor;
}

.table-container header {
    padding: 1rem;
}

.frame-type-tablesektor .table-container header {
    padding-left: 0rem;
}

.table>:not(caption)>*>* {
    padding: 0.4rem 1rem;
}

.table caption {
    margin-top: 1rem;
    border-top: 1px solid rgba(0,0,0,.125);
    font-size: 0.8rem;
    padding-left: 1rem;
    bottom: 0;
    position: absolute;
    width: 100%;
    left: 0;
}

.table.table-no-border td, .table *.no-border {
    border:0 !important;
}



td.zwheader {
    font-weight: bold;
    color: var(--turqoise);
}

th {
    text-align: center;
}

tr > th:first-child { text-align: left;}

td.border-right , th.border-right {
    border-right-width: 1px;
}

td.border-left {
    border-left-width: 1px;
}
td.border-bottom {
    border-bottom: 1px solid #000;
}

td.border-top {
    border-top: 1px solid #000;
}

td.zwsumme {
    font-weight: bold;
    border-bottom: 1px solid #4f909d;
    color:#4f909d !important;
}

td.summe {
    font-weight: bold;
}

td > p, th > p {
    margin:0;
}

table.table.table-with-border tr > *:first-child, table.table-default tr > *:first-child {
    border-right-width: 1px;
}

.table td.withbg, .table th.withbg {
    --bs-table-accent-bg: var(--bs-table-striped-bg);
    color: var(--bs-table-striped-color);
}

thead.border-bottom-2 {
    border-bottom: 2px solid #4f909d;
}

.table *.border-bottom-1 {
    border-bottom: 1px solid #4f909d;
}

.frame {
    margin-bottom: 2rem;
}

.frame-type-tablesektor, .frame-layout-1, .frame-layout-0 {
    background-color: white;
    border: 1px solid rgba(0,0,0,.125);
    border-radius: 0.25rem;
    margin-bottom: 1rem;
}

.frame-layout-1, .frame-layout-0 {
    padding:1.5rem;
}

.frame-layout-3 {
    background-color: transparent;
    padding: 1.5rem 1.5rem 0 1.5rem;
    border: 0;
}

.frame-default > .card {
    border:0;
}

.card-noborder .card {
    border-radius:0;
}

.table-responsive {
    height: 100%!important;
    position: relative;
    padding-bottom: 60px;
}

.frame .table-responsive, .accordion-body .table-responsive {
    height: unset !important;
}

td.bg-white {
    --bs-table-accent-bg: white !important;
}

.untlist > div {
    color: #4f909d;
    font-weight: bold;
    margin-bottom: 0.5rem;
    font-size: 1.2rem;
}

.accordion-button {
    font-size: inherit;
}

.accordion-button:not(.collapsed) {
    color: #FFF;
    background-color: rgb(79, 144, 157);
    box-shadow: none;
}

.accordion-button:not(.collapsed)::after {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23ffffff'%3e%3cpath fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/%3e%3c/svg%3e");
}
.accordion-button:not(.collapsed) > h2, .accordion-button:not(.collapsed) i::before {
    color: #FFF;
}


.accordion-body  header {
    padding-left:0 !important;
}

.card-title h5 i.bi {
    margin-right:0.3rem;
}

.list-group-item > button { display: none;}

h5.collapsed > i.bi-chevron-up::before {
    content: "\f282";
}

.list-group-item.d-flex.filtered {
    display: none !important;
}

.branchennav {
    border: 1px solid rgba(0,0,0,.125);
    border-radius: 0.25rem;
}

.branchennav .active {
    font-weight: bold;
}

.frame-type-menu_sitemap_pages {
    border: 1px solid rgba(0,0,0,.125);
    border-radius: 0.25rem;
    padding:1rem;
    background-color: white;
}

.frame-type-menu_sitemap_pages > ul > li {
    list-style-image: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" fill="currentColor" class="bi bi-arrow-right-short" viewBox="0 0 16 8">   <path fill-rule="evenodd" d="M4 8a.5.5 0 0 1 .5-.5h5.793L8.146 5.354a.5.5 0 1 1 .708-.708l3 3a.5.5 0 0 1 0 .708l-3 3a.5.5 0 0 1-.708-.708L10.293 8.5H4.5A.5.5 0 0 1 4 8z"/> </svg>');
}
.frame-type-menu_sitemap_pages > ul > li::marker {
    margin-top: 5px;
}

.rechtstext {
    border-bottom: 1px solid;
    padding: 1rem 0;
}

footer, footer a {
    color: #FFF;
}

.footerlogo {
    max-width:200px;
    height: auto;
}

.toplogo {
    max-width: 250px;
    height: auto;
    width: 100%;
}

.page-wrapper {
    min-height:65vh;
}

.printarea {
    background-color: #fff;
    padding: 2rem;
    width: 21.7cm
}

.printbottom {
    display: none;
}

page[size="A4"] {

}

iframe {
    border:1px solid rgba(0,0,0,.125);
}

.row.gridelement div div.frame:last-child {
    margin-bottom: 0;
}

.ce-border img {
    border-radius: 100%;
    border-color: var(--turqoise);
}

.turquoise {
    color: var(--turqoise);
}

.bg-yellow {
    background-color: yellow;
}

.chart-subheadline {
    color: var(--darkblue);
    font-family: "Rubik", sans-serif;
    font-size: 1.5rem;
    margin-top: 0;
    margin-bottom: 0.5rem;
    line-height: 1.2;
}

.chart-subheadline-h3 {
    font-size: 1.3rem;
    color: var(--darkblue);
    font-family: "Rubik", sans-serif;
    margin-top: 0;
    margin-bottom: 0.5rem;
    line-height: 1.2;
}

.chart-subheadline-h5 {
    font-size: 1.1rem;
    color: var(--darkblue);
    font-family: "Rubik", sans-serif;
    margin-top: 0;
    margin-bottom: 0.5rem;
    line-height: 1.2;
}

form button {
    border: 0;
    background-color: inherit;
    padding: 0;
}

@page {
    size: A4;
    margin: 2cm 1.5cm 2cm 1.5cm;
    background-color: white;
}

.print-first-page {
    display: none;
}

.btn:focus,.btn:active {
    outline: none !important;
}

.btn-primary {
    background-color: rgb(79, 144, 157);
    border-color: rgb(128, 180, 190);
}

.btn-primary:hover, .btn-primary:focus, .btn-primary:active {
    background-color: rgb(128, 180, 190);
    border-color: rgb(79, 144, 157);
    text-decoration: none;
}

.accordion-body .table-container h4 {
    padding-left:1rem;
}

ul {
    list-style-type: none;
}

ul:not(.navbar-nav, .dropdown-menu) {
    padding-left: 2rem;
}

ul:not(.navbar-nav, .dropdown-menu, .list-group) li:not(.nav-item):before {
    content: "\25BA" " ";
    color: var(--turqoise);
    font-family: Arial, Helvetica;
    margin-left: -1.3rem;
}

ul ul > li:before {
    margin-left: 0 !important;
}

.rechtstext ul {
    list-style-type: disc;
    padding-left: 2rem;
}

.rechtstext ul li:before {
    content: "" !important;
    margin-left: 0 !important;
}

ul:not(.navbar-nav, .dropdown-menu) ul ul {
    list-style-type: circle;
    padding-left: 2rem;
}

ul:not(.navbar-nav, .dropdown-menu) ul {
    list-style-type: disc;
    padding-left: 2rem;
}

ul:not(.navbar-nav, .dropdown-menu) ul li:not(.nav-item):before {
    content: "";
}

.pagesmenu .card-title {


}

.pagesmenu .card-title a {
    color: white;
    background-color: var(--turqoise);
    font-size: 1.2rem;
}

.pagesmenu .card-title a:hover {
    color: white;
    text-decoration: none;
    background-color: var(--darkblue);
}

.pagesmenu .list-group-item a {

}

.pagesmenu .list-group-item a:hover {
    text-decoration: none;
    color: white;
    background-color: var(--darkblue);
}

.text-red {
    color: red;
}

.text-green {
    color: green;
}

.iconlg:not(.pageicon) {
    font-size: 2.5rem;
    color: var(--darkblue);
    padding-bottom: 1rem;
}

.iconpng {
    width: 50px;
    height: 50px;
    display: block;
    background-position: center !important;
    background-size: contain !important;
    background-repeat: no-repeat !important;
}

.iconkarotte {
    background: url("/fileadmin/templates/img/icons/1Element 5@3x.png");
}
.iconbagger {
    background: url("/fileadmin/templates/img/icons/1Element 3@3x.png");
}
.iconschere {
    background: url("/fileadmin/templates/img/icons/1Element 9@3x.png");
}
.iconflasche {
    background: url("/fileadmin/templates/img/icons/1Element 10@3x.png");
}
.iconbrustkorb {
    background: url("/fileadmin/templates/img/icons/1Element 14@3x.png");
}
.iconspritze {
    background: url("/fileadmin/templates/img/icons/1Element 15@3x.png");
}
.icongelenk{
    background: url("/fileadmin/templates/img/icons/1Element 17@3x.png");
}
.iconbrot {
    background: url("/fileadmin/templates/img/icons/1Element 30@3x.png");
}
.icontraktor {
    background: url("/fileadmin/templates/img/icons/1Element 35@3x.png");
}
.icontier {
    background: url("/fileadmin/templates/img/icons/1Element 36@3x.png");
}
.icongetreide {
    background: url("/fileadmin/templates/img/icons/1Element 38@3x.png");
}

.jvectormap-zoomin, .jvectormap-zoomout, .jvectormap-goback {
    background: var(--turqoise);
}

.jvectormap-legend-icons {
    background: white;
    border: var(--darkblue) 1px solid;
}

.jvectormap-legend-tick-text, .jvectormap-legend-title {
    color: var(--darkblue);
}

.home {
    background: url("/fileadmin/templates/img/Branchenmonitor_Neu4.jpg");
    background-size: cover;
    max-height: 600px;
    height: 60vh;
    background-position-y: bottom;
}

.home .container {
    position: relative;
}

.home .container .homeslogan {
    background-color: rgba(0,57,85,0.6);
    color: #FFF;
    position: absolute;
    bottom: 1rem;
    border: 1px solid #FFF;
}

.home .container h1 {
    color: #FFF;
}

.homeslogan header h1 {
    margin-bottom: 1rem;
}

.homeslogan {
    font-size: 1.2rem;
}

.multiple .h-100 {
    height: auto !important;
    margin-bottom: 1rem;
}

.multiple .h-100:last-child {
    margin-bottom: 0;
}

.frame-h-100 {
    height:100% !important;
}

.caption {
    padding-top: 0.5rem;
    padding-bottom: 0.5rem;
    color: #6c757d;
    text-align: left;
    margin-top: 1rem;
    font-size: 0.8rem;
    padding-left: 1rem;
}

.image-embed-item {
    width: 100%;
    height: auto;
}

p.top1 {
    color: var(--turqoise);
    font-size: 1.1rem;
}
p.top2 {
    color: var(--turqoise);
    font-size: 1.1rem;
}
p.top3 {
    color: var(--topcolor2);
    font-size: 1.1rem;
}
@media only screen and (max-width: 575px) {
    .home .container .homeslogan {
        position: initial;
    }

    .home > .container {
        padding: 2rem 0;
    }

    .home {
        max-height: unset;
        height: unset;

    }

    .table caption {
        position: relative;
    }
}

@media print {
    body, html {
        background-color: white;
    }

    table, .table-container, .card, .frame-type-tablesektor {
        page-break-inside: avoid;
    }

    .card.container-recht {
        page-break-inside: auto;
    }

    h1:not(.nobreakbefore), .pagebreakbefore,.frame-space-before-pagebreakbefore {
        page-break-before: always;
    }

    .print-first-page h1 {
        page-break-before: auto !important;
    }

    h2:not(.nobreakbefore), h3:not(.nobreakbefore) {
        /*page-break-before: always;*/
    }


    .header-nopagebreak h2, .header-nopagebreak h3 {
        page-break-before: auto !important;
    }

    .float-lg-end {
        float: none !important;
    }
    .printarea {
        padding: 0;
        padding-bottom: 2cm;

    }

    .frame-layout-1, .frame-layout-0 {
        padding-top:0;
        padding-bottom: 0;
    }

    .print-first-page {
        display: block;
        page-break-after: always;

    }

    .print-first-page .headerblock {
        background-color: var(--bggrey);
        height: 18cm;
        padding: 6cm 3cm 0 3cm;
        border-bottom:1px solid var(--turqoise);
    }

    .print-first-page .headerblock h1, .print-first-page .headerblock h2, .print-first-page .headerblock h3 {
        font-size: 36pt;
        margin-bottom: 0.3cm
    }

    .print-first-page .headerblock h1, .print-first-page .headerblock h3 {
        text-transform: uppercase;
        font-weight: lighter;

    }
    .print-first-page .headerblock h2 {

    }

    .printlogo {
        width: 6cm;
        height: auto;
        margin-bottom: 1cm;
    }

    .logoblock {
        text-align: right;
        margin-top: 4.5cm;
    }

    .logoblock img {
        width: 6cm;
        height: auto;
        margin-right: -1.2cm;

    }


    .printbottom {
        display: block;
        position: absolute;
        bottom: 0;
        border-top: 3px solid var(--turqoise);
        padding-top: 10px;
        width: calc(100%);
        text-align: right;
    }

    .col-print-6 {
        width: 50% !important;
    }

    .h-100 {
        height: auto !important;
    }


    .float-lg-end {
        float: none!important;
    }

    .container-fluid {
        display: none;
    }

}






