/**
 * All of the CSS for your public-facing functionality should be
 * included in this file.
 */
/*
** ===================== GENERIX =====================
*/
.elem_c2imp_btn {
    text-align: center;
    padding: 15px 0;
    margin: 30px 0 0px 0;
    }   
.btn.c2imp_btn {
    background-color: #2962ff;
    border-radius: 999px;
    color: white;
    width: max-content;
    padding: 15px 25px;
    /*text-transform: capitalize;*/
    }
p.form-label{
    margin-bottom: .5rem!important;
    }
.btn.c2imp_btn:hover {
    background-color: #6989e3;
    color: white!important;
    }
button#mm_btn_submit {
    font-size: 22px;
    }
h2.mld_sec_head,
h2.c2imp_s_h_desc,
h2.c2imp_s_h_img,
h2.c2imp_s_h_map{
    font-weight: bold;
    }
h3.mld_sec_subhead{
    font-weight: 600;
    }
 #mapid,#mapid_copy {
 	height: 450px;
 	width: 100%;
 	}
 img.leaflet-marker-icon.leaflet-zoom-animated.leaflet-interactive {
	border: 0px;
	width: 20px!important;
	height: 29px!important;
	}
.cat_desc_ea{
	display: none;
	min-height: 100px;
	}
.cat_desc_ea {
    text-align: center;
    }
.cat_desc_ea.empty:empty{
    display: none;
    }
.cat_desc_ea.init{
	display: block;
	}
#mapSearchContainer{
	position:fixed;
	top:20px;
	right: 40px;
	height:30px;
	width:180px;
	z-index:110;
	font-size:10pt;
	color:#5d5d5d;
	border:solid 1px #bbb;
	background-color:#f8f8f8;
	}
.pointer{
	position:absolute;
	top:86px;
	left:60px;
	z-index:99999;
	}
#topbutton {
    z-index: 999!important;
    }
input.c2imp_form_control,
textarea.c2imp_form_control {
    border: 1px solid rgba(41, 98, 255, .25)!important;
    border-radius: 3px!important;
    }
#elem_privpol {
    display: -moz-flex;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    align-items: center;
    -webkit-flex-direction: row-reverse;
    flex-direction: row-reverse;
    -webkit-justify-content: flex-end;
    justify-content: flex-end;   
    }
input#mm_chkb_privpol {
    border-radius: 999px;
    }
label#lbl_mm_chkb_privpol {
    width: 85%;
    line-height: 1;
    padding: 5px 0;
    }
/*
** ===================== file upload =====================
*/
#file_upload{
    opacity: 0;
    width: 0.1px;
    height: 0.1px;
    position: absolute;
    }
label#lbl_file_upload {
    width: auto;
    }
#elem_file_upload {
    text-align: center;
    padding: 0 0 2rem 0;
    }
p.file-name {
    font-style: italic;
    font-size: 16px;
    letter-spacing: 1px;
    font-weight: 400!important;
    }
/*
** ===================== optional fields =====================
*/
#subsection_baumn,
#subsection_roadsurf{
    display: none;
    margin-bottom: 5rem;
    }
#subsection_roadsurf input {
    height: 20px;
    width: 20px;
    }
#subsection_roadsurf label {
    padding-left: 5px;
    }
input#mm_inp_treeno {
    width: 75px;
    }
/*
** ===================== captcha =====================
*/
.capbox {
    background-color: white;
    box-sizing: border-box;
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    display: inline-block;
    padding: 0rem;
    border-radius: 0px!important;
    }
#fngm_capbox_i {
    border: #1b42ab 2px solid;
    border-radius: 5px;
    width: max-content;
    margin: 0 auto 15px auto;
    }
.capbox-inner {
    color: #fff;
    background-color: #1b42ab;
    margin: 0px auto 0px auto;
    padding: 10px 10px 15px 10px;
    border-radius: 0px;
    display: inline-block;
    vertical-align: middle;
    font-weight: 400;
    font-style: italic;
    font-size: 16px;
    text-align: center;
    }
#CaptchaDiv {
    color: #000000;
    font-style: italic;
    font-weight: bold;
    text-align: center;
    vertical-align: middle;
    background-color: #FFFFFF;
    user-select: none;
    display: inline-block;
    padding: 5px 15px;
    margin: 0 5px 0 10px;
    border-radius: 0px;
    font-size: 28px;
    }
#CaptchaInput {
    margin: 3px 0px 1px 0px;
    width: 105px;
    border: 0px;
    border-radius: 3px;
    font-size: 18px;
    font-weight: bold;
    letter-spacing: 1px;
    color: green;  
    }
#elem_tag_desc_oblig p {
    font-size: 14px;
    font-weight: 600;
    color: #32509e;
    letter-spacing: 1px;    
    }
/*
** ===================== radio mld cats =====================
*/
#radio_combo_sel_mld_cat {
    padding: 0 0px;
    }
.lbl_rad_mld_cat_ea{
    position: relative;
    width: 100%;
    /*border: 1px solid rgba(41, 98, 255, .25);*/
    margin: 0 0 25px 0;
    border-radius: 5px;
    overflow: hidden;
    }
.lbl_rad_mld_cat_ea:after {
    content: "";
    display: block;
    padding-bottom: 100%;
    }
.lbl_rad_mld_cat_ea_i{
    position: absolute;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -webkit-flex-direction: column;
    flex-direction: column;
    -webkit-justify-content: space-between;
    justify-content: space-between;    
    width: 100%;
    height: 100%;
    }
.lbl_rad_mld_cat_ea_i .elem_c2imp_btn {
    text-align: center;
    padding: 15px 0;
    margin: 0;
    }
img.img_mld_cat_feat {
    width: 50%;
    margin: 20px auto 0 auto;
    height: auto;
    }
label.lbl_rad_mld_cat_ea:hover{
    cursor: pointer;
    }
.combo_sel_mld_cat_ea {
    background-color: white;
    }
.combo_sel_mld_cat_ea.selected {
    margin: 0 auto;
    }
.combo_sel_mld_cat_ea:hover {
    /*background-color: rgba(41, 98, 255, .05)!important;*/
    }
input.rad_mld_cat_ea {
    display: none;
    }
input[type=radio].rad_mld_cat_ea:checked + label.lbl_rad_mld_cat_ea{
    background-color: rgba(41, 98, 255, .05)!important;
    }
#elem_mld_kats_descriptions,
#show_all_mld_cats{
    display: none;
    }
p.p_mld_cat_ea_title {
    text-align: center;
    font-weight: bold!important;
    letter-spacing: 1px;
    color: #2F4F4F;
    }
p.p_mld_cat_ea_tag_sel{
    display: none;
    text-align: center;
    font-style: normal;
    font-size: 15px;
    background-color: #2962ff;
    width: max-content;
    margin: 15px auto 0 auto!important;
    color: white;
    font-weight: 400!important;
    padding: 4px 12px;
    border-radius: 999px;  
    }
span.btn.c2imp_btn.cat_sel {
    padding: 5px 25px;
    margin-top: -15px;
    width: max-content;
    }
#elem_show_all_mld_cats {
    margin: 0;
    padding-top: 0;
    }
button#show_all_mld_cats {
    width: 100%;
    }
/*
============================== c2_process_info ================================
*/
.c2_process_info {
    background-color: black;
    }
.c2_process_info code {
    color: yellow;
    font-size: 12px;
    }
.c2_process_info input.c2imp_inp_proc {
    border: none;
    font-size: 12px;
    background-color: transparent;
    color: yellow;
    }
/*
============================== archive ================================
*/
.tax-mld_kategorie main#primary,
.tax-mld_status main#primary,
.post-type-archive-meldung main#primary {
    margin-top: 100px;
    }
.row.c2imp_mld_row_arch_ea {
    /*border: 1px solid rgba(41, 98, 255, .25);*/
    border-radius: 35px;
    overflow: hidden;
    }
.c2imp_mld_row_arch_ea_feat{
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;    
    position: relative;
    width: 50%;
    padding: 7px 0!important;
    /*background-color: grey;*/
    }
.c2imp_mld_row_arch_ea_feat:after {
    content: "";
    display: block;
    padding-bottom: 100%;
    }
.feat_i{
    position: absolute;
    width: 100%;
    margin: 0!important;
    /*background-color: rgba(0, 0, 0, .5);*/
    display: -moz-flex;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    align-items: center;
    -webkit-flex-direction: inherit;
    flex-direction: inherit;
    -webkit-justify-content: space-between;
    justify-content: space-between;
    height: 100%;
    padding: 3rem 0;
    }
h1.mld_s_mld_title {
    width: max-content;
    font-weight: bold!important;
    }
h2.mld_arch_mld_title{
    background-color: white;
    padding: 5px;
    font-weight: bold;
    font-size: 18px;
    margin: 5px 0;
    white-space: normal;
    width: auto;
    }
p.mld_arch_mld_title{
    background-color: rgba(255, 255, 255, .9);
    color: #005098;
    padding: 5px;
    font-weight: 600!important;
    margin: 5px 0;
    white-space: normal;
    width: initial;
    font-size: 18px;
    }
p.mld_arch_mld_title.empty{
    background-color: transparent!important;
    }
p.mld_arch_mld_postdate {
    background-color: #2b395e;
    color: white;
    padding: 0px 5px;
    font-size: 16px;
    font-weight: 600!important;
    margin: 5px 0!important;
    width: max-content;    
    }
p.mld_arch_cat_title{
    background-color: #005098;
    color: white;
    padding: 0px 5px;
    font-size: 16px;
    font-weight: 600!important;
    margin: 5px 0!important;
    width: max-content; 
    }
p.mld_arch_cat_title a {
    font-size: 16px;
    font-weight: 600;
    color: white;
    padding: 0;
    }
.single.single-meldung a.mld_s_cat_title {
    font-size: 16px;
    font-weight: 600;
    color: white;
    padding: 3px 5px;
    }
.elem_c2imp_btn.archive {
    padding: 0 15px 0 15px;
    width: 100%;
    text-align: right;
    /*
    padding-bottom: 25px;
    width: 100%;
    text-align: center;
    */
    }
.elem_c2imp_btn.archive .c2imp_btn {
    padding: 5px 25px;
    width: max-content;
    }
.c2imp_mld_arch_elem_postnavs{
    padding: 15px;
    }
.c2imp_mld_arch_elem_postnavs a{
    background-color: #2962ff;
    border-radius: 999px;
    color: white!important;
    padding: 5px 10px;
    text-decoration: none;
    margin-top: -15px;
    width: max-content;
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 1px;
    }
.c2imp_mld_arch_elem_postnavs a:hover{
    background-color: #6989e3;
    color: white!important;
    text-decoration: underline;
    }
.post-type-archive-meldung header.page-header.mld_arch_tax_head {
    padding: 20px;
    }
.row.row_arch_mld_ea_prview {
    padding: 15px;
    }
.elem_mld_previews .row.row_arch_mld_ea_prview {
    padding: 0px;
    }
.entry-content.cont_mld_ea_prview {
    margin-top: 0px;
    }    
.mld_arch_tax_head h1.archive-title {
    width: max-content;
    font-weight: bold!important;
    }
.col-12.btncol .c2imp_btn {
    margin: 0 1rem;
    }
span.mld_tax_lbl {
    background-color: #005098;
    padding: 5px 10px;
    color: white;
    }
a.btn.c2imp_btn.nospec{display: none;}
a.btn.c2imp_btn.solved,
span.mld_tax_lbl.solved {
    background-color: green;
    }
a.btn.c2imp_btn.in_process,
span.mld_tax_lbl.in_process {
    background-color: orange;
    }
a.btn.c2imp_btn.toclarify,
span.mld_tax_lbl.toclarify {
    background-color: grey;
    }
.col_arch_mld_ea_prview.hide {
    display: none;
    }
/*
============================== map ================================
*/
.leaflet-control-attribution a {
    font-size: 12px;
    }
.leaflet-popup-content-wrapper {
    border-radius: 0px!important;
    background-color: rgba(255,255,255,.8)!important;
    }
img.prev_pup_img {
    margin: 5px 0 0 0;
    max-width: 100%;
    }
.elem_mappu_link {
    text-align: center;
    padding: 10px 0;
    }
.elem_mappu_link .mappu_appx{
    margin: 15px 0 0 0;
    display: -moz-flex;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -webkit-flex-direction: column;
    flex-direction: column;
    align-items: center;
    }
a.btn.c2imp_btn.mappu {
    padding: 0px 15px;
    width: max-content;
    font-size: 14px;
    font-weight: bold;
    }
#elem_searchControl {
    position: relative;
    height: 75px;
    }
input#elem_geosearch {
    border: 1px solid rgba(41, 98, 255, .25)!important;
    border-radius: 3px!important;
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.5;
    width: 500px;
    height: calc(1.5em + 0.75rem + 2px);
    padding: 0.375rem 0.75rem;
    background-image: none;
    box-shadow: none;
    }
span.mappu_cat_t {
    font-size: 12px;
    font-style: italic;
    font-weight: 600;
    background-color: rgba(0, 0, 0, .3);
    color: white;
    padding: 3px 5px;
    white-space: nowrap;
    width: max-content;
    }
span.date_mappu {
    white-space: nowrap;
    padding: 3px 5px;
    }
.mappu_repl_ind i.fas.fa-comment {
    font-size: 2rem;
    color: lightblue;
    }
.pu_nm_PU .leaflet-popup-content-wrapper{
    background-color: transparent!important;
    border: 0px;
    padding: 0px;
    box-shadow: none;
    }
/*
.pu_nm_PU .leaflet-popup-content {
    */
    /*
    width: 50px;
    height: 20px;
    background-color: red;
    color: white;
    margin: 0;
    display: -moz-flex;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    align-items: center;
    -webkit-flex-direction: column;
    flex-direction: column;
    -webkit-justify-content: center;
    justify-content: center;
    */
    /*
      width: 110px;
      height: 56px;
      box-sizing: content-box;
      padding-top: 15px;
      position: relative;
      background: red;
      color: transparent;
      font-size: 11px;
      letter-spacing: 0.2em;
      text-align: center;
      text-transform: uppercase;    
    }
    */
/*
.pu_nm_PU .leaflet-popup-content:after {
    content: "";
    position: absolute;
    left: 0;
    bottom: 0;
    width: 0;
    height: 0;
    border-bottom: 13px solid #eee;
    border-left: 55px solid transparent;
    border-right: 55px solid transparent;
    }
    */
.pu_nm_PU .leaflet-popup-content{
    background: #005098;
    width: 80px;
    height: 80px;
    position: relative;
    text-align: center;
    -webkit-transform: rotate(20deg);
    -moz-transform: rotate(20deg);
    -ms-transform: rotate(20deg);
    -o-transform: rotate(20deg);
    transform: rotate(20deg);
    display: -moz-flex;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -webkit-flex-direction: column;
    flex-direction: column;
    -webkit-justify-content: center;
    justify-content: center; 
    }
.pu_nm_PU .leaflet-popup-content:before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    height: 80px;
    width: 80px;
    background: #005098;
    -webkit-transform: rotate(135deg);
    -moz-transform: rotate(135deg);
    -ms-transform: rotate(135deg);
    -o-transform: rotate(135deg);
    transform: rotate(135deg);
    }
img.leaflet-marker-icon.leaflet-zoom-animated.leaflet-interactive.newMarkerX {
    visibility: hidden;
    }
.pu_nm_PU .leaflet-popup-tip {
    background-color: #005098;
    }
span.nm_PU {
    font-weight: bold;
    font-style: italic;
    text-transform: uppercase;
    background-color: transparent;
    color: white;
    position: absolute;
    font-size: 30px;
    left: 50%;
    -webkit-transform: translateX(-50%) rotate(-20deg);
    -moz-transform: translateX(-50%) rotate(-20deg);
    -ms-transform: translateX(-50%) rotate(-20deg);
    -o-transform: translateX(-50%) rotate(-20deg);
    transform: translateX(-50%) rotate(-20deg);
    }
.leaflet-map-pane .leaflet-popup-content {
    max-width: 300px;
    min-width: 300px;
    margin: 10px;
    }
.leaflet-map-pane .leaflet-popup-content h4{
    font-weight: bold;
    margin: 0;
    padding: 0 0 5px 0;
    }
.leaflet-map-pane .leaflet-popup-content h4 a{
    color: #f0ab05 !important;
    font-weight: bold;
    margin: 0;
    }
.leaflet-map-pane .leaflet-popup-content p{
    color: #424242 !important;
    margin: 5px 0;
    }
.leaflet-map-pane .leaflet-popup-content a{
    color: #424242 !important;
    text-decoration: none;
    }
.leaflet-map-pane .leaflet-popup-content a:hover{
    color: #424242 !important;
    text-decoration: underline !important;
    }
.leaflet-map-pane .leaflet-popup-content .container_basic_btn_dl a{
    text-decoration: none !important;
    }
.leaflet-map-pane .leaflet-popup-content .container_basic_btn_dl span{
    color: white !important;
    }
.leaflet-popup-content .inner .c2imp-link-btn-wrap,
.marker-card.col-md-4 .inner .c2imp-link-btn-wrap {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin: 8px 0 0 0;
}
.marker-card.col-md-4 .inner .c2imp-link-btn-wrap {
    padding: 0 10px 10px 10px;
}
.leaflet-popup-content .inner .c2imp-link-btn,
.marker-card.col-md-4 .inner .c2imp-link-btn {
    display: inline-block;
    padding: 7px 12px;
    border: 1px solid #f0ab05;
    background-color: #f0ab05;
    color: #fff !important;
    font-size: 13px;
    font-weight: 700;
    line-height: 1.2;
    text-decoration: none !important;
}
.leaflet-popup-content .inner .c2imp-link-btn:hover,
.marker-card.col-md-4 .inner .c2imp-link-btn:hover {
    border-color: #f0ab05;
    background-color: #fff;
    color: #f0ab05 !important;
    text-decoration: none !important;
}
.leaflet-popup-content .inner p.desc,
.marker-card.col-md-4 .inner p.desc {
    display: none;
}
.leaflet-popup-content .inner p.desc.c2imp-desc-visible {
    display: block;
}
.marker-card.col-md-4 .inner p.desc.c2imp-desc-visible {
    display: inline-block;
}
.leaflet-map-pane .leaflet-popup-content p.address .fas,
.leaflet-map-pane .leaflet-popup-content p.phone .fas,
.leaflet-map-pane .leaflet-popup-content p.email .fas,
.leaflet-map-pane .leaflet-popup-content p.address svg,
.leaflet-map-pane .leaflet-popup-content p.phone svg,
.leaflet-map-pane .leaflet-popup-content p.email svg,
.leaflet-map-pane .leaflet-popup-content .route-link svg,
.leaflet-map-pane .leaflet-popup-content .route-link .fas{
    color: #f0ab05;
    }
.marker-card .container_basic_btn_dl {
    position: relative;
    left: 10px;
    }
.marker-card .inner{
    border: 1px solid #f0ab05;
    padding: 0px;
    /*background-color: #f0ab05;*/
    background-color: #fff;
    cursor: pointer;
    height: 100%;
    }
.marker-card h4 {
    color: #fff !important;
    background-color: #f0ab05;
    padding: 5px 10px;
    font-weight: bold;
    margin: 0 0 10px 0;

    /* Fallback für sehr alte Browser */
    display: block;

    /* ältere WebKit / IE10 */
    display: -webkit-box;
    display: -ms-flexbox;

    /* moderne Browser */
    display: flex;

    /* Flex-Richtung */
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;

    /* Vertikal zentrieren */
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    }
.marker-card h4 a{
    color: #fff !important;
    pointer-events: none !important;   /* verhindert Klicks */
    cursor: default !important;        /* kein Hand-Cursor */
    }
.marker-card p.address,
.marker-card p.phone,
.marker-card p.email,
.marker-card p.desc{
    display: inline-block;
    color: #424242;
    padding: 0px 10px;
    margin: 0 0 5px 0;
    font-size: 14px;
    }
.marker-card p.phone a,
.marker-card p.email a{
    color: #424242;
    padding: 0px;
    margin: 0 0 10px 0;
    font-size: 14px;
    }
.marker-card {
    padding: 0px 6px;
    margin: 6px 0;
    }
.marker-card p.address .fas,
.marker-card p.phone .fas,
.marker-card p.email .fas,
.marker-card p.address svg,
.marker-card p.phone svg,
.marker-card p.email svg {
    color: #f0ab05;
    }
.marker-card a.btn.btn-diako {
    background-color: #f0ab05;
    color: #fff;
    }
.marker-card .container_basic_btn_dl .btn-diako [class*="fa-"],
.marker-card a.btn.btn-diako i.far.fa-plus-square::before {
    color: #fff !important;
    }
.marker-card a.btn.btn-diako:hover {
    background-color: #fff;
    color: #f0ab05;
    }
.marker-card .container_basic_btn_dl .btn-diako:hover [class*="fa-"],
.marker-card a.btn.btn-diako:hover i.far.fa-plus-square::before {
    color: #f0ab05 !important;
    }
.marker-filter-wrapper {
    display: -moz-flex;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 15px;
}

#marker-filters {
    display: -moz-flex;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    flex-wrap: wrap;       /* allow wrapping into new rows */
    gap: 4px;             /* spacing between items */
    align-items: center;
}

.marker-filter-label {
    display: -moz-flex;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: inline-flex;
    align-items: center;
    padding: 4px 4px;
    border: 0px solid #f6a800;
    border-radius: 0px;
    cursor: pointer;
    font-size: 14px;
    font-weight: bold;
    background: white;
    color: #f6a800;
    transition: all 0.2s ease;
    width: 100%;           /* no forced width */
    white-space: nowrap;   /* keep label text on one line */
}

.marker-filter-label input[type="checkbox"] {
    display: none; /* hide checkbox */
}

.marker-filter-label.checked {
    background: #f6a800;
    color: white;
}
#marker-list{
    /*display:grid; grid-template-columns: repeat(2, 1fr);*/
    gap:0px;
    margin: -6px;
    }
.marker-filter-label.container_basic_btn_dl svg,
.marker-filter-label.container_basic_btn_dl i{
    -webkit-transition: -webkit-transform 0.5s cubic-bezier(0.165, 0.84, 0.44, 1);
    transition: -webkit-transform 0.5s cubic-bezier(0.165, 0.84, 0.44, 1);
    transition: transform 0.5s cubic-bezier(0.165, 0.84, 0.44, 1);
    transition: transform 0.5s cubic-bezier(0.165, 0.84, 0.44, 1), -webkit-transform 0.5s cubic-bezier(0.165, 0.84, 0.44, 1);
    }
.marker-filter-label.container_basic_btn_dl:hover svg,
.marker-filter-label.container_basic_btn_dl:hover i{
    -webkit-transform: rotate(225deg);
    transform: rotate(225deg);
    }
.leaflet-popup {
    margin-bottom: 30px !important;
    }
.leaflet-popup-tip {
    background: rgba(255, 255, 255, .8) !important;
    }
a.leaflet-popup-close-button span{
    background-color: transparent;
    border-radius: 999px;
    aspect-ratio: 1 / 1;
    display: block;
    color: #000;
    }
a.leaflet-popup-close-button span:hover{
    background-color: #f6a800;
    color: white;
    text-decoration: none !important;
    }
h4.pu-mark-head{
    font-weight: bold;
    padding: 0;
    margin: 0;
    }
p.pu-mark-desc {
    white-space: pre-line;
    }
/*
============================== fbs custom ================================
*/
.row-markermap {
    position: relative;
}

#map-box {
    position: relative;
}

/* Wrapper für Button + Box */
#cat-wrapper {
    position: absolute;
    top: 0;
    right: 15px;
    z-index: 1100;
    height: calc(100% + 33px) !important;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: flex-start;
    -ms-flex-align: start;
    align-items: flex-start;
}

/* Wenn offen: Button links, Box rechts */
#cat-wrapper.filters-open {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
    -ms-flex-direction: row-reverse;
    flex-direction: row-reverse;
}

/* Filterbox */
#cat-box {
    /* NICHT mehr absolute, sondern innerhalb des Wrappers */
    max-width: 260px;
    max-height: calc(100% - 55px); /* nicht höher als Map-Bereich */
    overflow-y: auto;
    overflow-x: hidden;

    background: rgba(255, 255, 255, 0.78); /* leicht transparent */
    border-radius: 4px;
    padding: 5px 8px;
    box-shadow: 0 4px 12px rgba(0,0,0,0.18);

    /* Animations-Basis: raus nach rechts */
    -webkit-transform: translateX(110%);
    -ms-transform: translateX(110%);
    transform: translateX(110%);

    opacity: 0;
    pointer-events: none;

    -webkit-transition: -webkit-transform 0.3s ease, opacity 0.3s ease;
    transition: transform 0.3s ease, opacity 0.3s ease;
}

/* Sichtbar-Zustand */
#cat-box.is-open {
    -webkit-transform: translateX(0);
    -ms-transform: translateX(0);
    transform: translateX(0);

    opacity: 1;
    pointer-events: auto;
}

/* Toggle-Button */
.btn.btn-diako.cat-toggle-btn {
    padding: 6px 10px;
    font-size: 13px;
    font-weight: bold;
    cursor: pointer;

    color: #fff !important;
    border: 1px solid #f6a800 !important;
    background-color: #f6a800 !important;
}
.btn.btn-diako.cat-toggle-btn:hover {
    cursor: pointer;

    color: #f6a800 !important;
    border: 1px solid #f6a800 !important;
    background-color: #fff !important;
}

/* Button aktiv (wenn Box offen) */
.btn.btn-diako.cat-toggle-btn.active {
    min-width: fit-content;
    background-color: #f6a800 !important;
    border: 1px solid #f6a800 !important;
    color: #fff !important;
}

.btn.btn-diako.cat-toggle-btn.active:hover {
    min-width: fit-content;
    background-color: #fff !important;
    color: #f6a800 !important;
}

/* Mobile: Box etwas breiter */
@media (max-width: 575px) {
    #cat-wrapper {
        right: 5%;
    }
    #cat-box {
        max-width: 80vw;
    }
}
.marker-filter-tick {
    display: inline;
    visibility: hidden;
    margin-left: 0.35em;
    font-weight: bold;
}

/* Wenn Label "aktiv" ist, Häkchen zeigen */
.marker-filter-label.checked .marker-filter-tick {
    visibility: visible;
}


.marker-card .route-link{
    display: none;
    }
input.marker-filter.btn-diako {
    display: none;
    }
/*
============================== SWAL ==============================
*/
body.swal2-shown {
    padding: 0!important;
    }
button.swal_c2imp_confBtn {
    background-color: #005098!important;
    border-radius: 0px!important;
    font-size: 20px!important;
    padding: 5px 25px!important;
    }
.swal2-popup.swal_c2imp_popup {
    border-radius: 0px!important;
    }
/*
============================== font style fix ==============================
*/
span.mld_sec_desc {
    font-family: 'Roboto',sans-serif;
    /* font-size: 20px; */
    font-size: 18px;
    font-weight: 300;
    line-height: 1.6em;
    color: #535C62;
    }
/*
####################################################
ooo        ooooo                 .o8   o8o                   .oooooo.                                      o8o                     
`88.       .888'                "888   `"'                  d8P'  `Y8b                                     `"'                     
 888b     d'888   .ooooo.   .oooo888  oooo   .oooo.        888      888    oooo  oooo   .ooooo.  oooo d8b oooo   .ooooo.   .oooo.o 
 8 Y88. .P  888  d88' `88b d88' `888  `888  `P  )88b       888      888    `888  `888  d88' `88b `888""8P `888  d88' `88b d88(  "8 
 8  `888'   888  888ooo888 888   888   888   .oP"888       888      888     888   888  888ooo888  888      888  888ooo888 `"Y88b.  
 8    Y     888  888    .o 888   888   888  d8(  888       `88b    d88b     888   888  888    .o  888      888  888    .o o.  )88b 
o8o        o888o `Y8bod8P' `Y8bod88P" o888o `Y888""8o       `Y8bood8P'Ybd'  `V88V"V8P' `Y8bod8P' d888b    o888o `Y8bod8P' 8""888P' 
####################################################
*/

/*
::::::::::::::::::::::::::::::::::::::::::::::::::::
Bootstrap 4 breakpoints
*/
/* 
Extra small devices (portrait phones, less than 576px) 
No media query since this is the default in Bootstrap because it is "mobile first"
*/
/* 
  oooooooo  ooooooooo     .ooo   
 dP""""""" d"""""""8'   .88'     
d88888b.         .8'   d88'      
    `Y88b       .8'   d888P"Ybo. 
      ]88      .8'    Y88[   ]88 
o.   .88P     .8'     `Y88   88P 
`8bd88P'     .8'       `88bod8' 
Small devices (landscape phones, 576px and up) */
@media (min-width: 576px) {
}
/* 
 ooooooooo     .ooo    .ooooo.   
d"""""""8'   .88'     d88'   `8. 
      .8'   d88'      Y88..  .8' 
     .8'   d888P"Ybo.  `88888b.  
    .8'    Y88[   ]88 .8'  ``88b 
   .8'     `Y88   88P `8.   .88P 
  .8'       `88bod8'   `boood8'  
Medium devices (tablets, 768px and up) The navbar toggle appears at this breakpoint */
@media (min-width: 768px) {
    button#show_all_mld_cats {
        width: max-content;
        }
    label#lbl_mm_chkb_privpol {
        width: auto;
        margin-right: 5px;
        }
    #fngm_capbox {
        width: 100%;
        }
    .col_arch_mld_ea_prview{        
        padding: 15px 30px;
        }
    .single-meldung main#primary {
        padding: 15px;
        }
    .c2imp_mld_s_elem_postnavs {
        padding: 0px;
        }
    /* ============================== map ============================== */
    /*
    .geocoder-control.leaflet-control input {
        border-color: #005098;
        border-width: 3px;
        height: 50px;
        width: 50px;
        background-size: 70%;
        background-position: center;
        background-image: url('../inc/search-solid_005098.svg');
        font-size: 26px;
        color: #005098;
        }
    .geocoder-control.leaflet-control input:focus,
    .geocoder-control.leaflet-control input:hover{
        width: 500px;
        background-size: contain;
        background-image: unset;
        }
        */          
}
/* 
  .oooo.    ooooooooo   oooooooo          .ooooo.     .o    .oooo.   
.dP""Y88b  d"""""""8'  dP"""""""         d88'   `8. o888  .dP""Y88b  
      ]8P'       .8'  d88888b.           Y88..  .8'  888        ]8P' 
    <88b.       .8'       `Y88b           `88888b.   888      .d8P'  
     `88b.     .8'          ]88  8888888 .8'  ``88b  888    .dP'     
o.   .88P     .8'     o.   .88P          `8.   .88P  888  .oP     .o 
`8bd88P'     .8'      `8bd88P'            `boood8'  o888o 8888888888
----------- iPhone X ----------- */
@media only screen 
  and (min-device-width: 375px) 
  and (max-device-width: 812px) 
  and (-webkit-min-device-pixel-ratio: 3)
  and (orientation: landscape) {
}
/* 
 .ooooo.    .ooooo.     .oooo.   
888' `Y88. 888' `Y88. .dP""Y88b  
888    888 888    888       ]8P' 
 `Vbood888  `Vbood888     .d8P'  
      888'       888'   .dP'     
    .88P'      .88P'  .oP     .o 
  .oP'       .oP'     8888888888 
Large devices (desktops, 992px and up) */
/* Nur Desktop – gleiche Höhen schön unterstützen */
@media (min-width: 992px) {
    .marker-card {
        display: flex;
    }

    .marker-card .inner {
        display: flex;
        flex-direction: column;
        width: 100%;
    }

    /* Falls du Button/Route-Link immer unten haben willst: */
    .marker-card .container_basic_btn_dl,
    .marker-card .route-link {
        margin-top: auto;
    }
}
/*
  .o    .oooo.     .oooo.         .o   
o888   d8P'`Y8b  .dP""Y88b      .d88   
 888  888    888       ]8P'   .d'888   
 888  888    888     .d8P'  .d'  888   
 888  888    888   .dP'     88ooo888oo 
 888  `88b  d88' .oP     .o      888   
o888o  `Y8bd8P'  8888888888     o888o
*/
@media (min-width: 1024px) {
    h2.mld_arch_mld_title {
        font-size: 16px;
        }
}
/* 
  .o    .oooo.     .oooo.     .oooo.   
o888  .dP""Y88b   d8P'`Y8b   d8P'`Y8b  
 888        ]8P' 888    888 888    888 
 888      .d8P'  888    888 888    888 
 888    .dP'     888    888 888    888 
 888  .oP     .o `88b  d88' `88b  d88' 
o888o 8888888888  `Y8bd8P'   `Y8bd8P'
Extra large devices (large desktops, 1200px and up) */
@media (min-width: 1200px) {
}
/* 
  .o        .o         .o     .oooo.   
o888      .d88       .d88    d8P'`Y8b  
 888    .d'888     .d'888   888    888 
 888  .d'  888   .d'  888   888    888 
 888  88ooo888oo 88ooo888oo 888    888 
 888       888        888   `88b  d88' 
o888o     o888o      o888o   `Y8bd8P' 
Extra large devices (large desktops, 1440px and up) */
/* Extra large devices (large desktops, 1440px and up) */
@media (min-width: 1440px) {
    span.mld_tax_lbl.in_process {
        float: left;
        margin-right: 10px;
        }
}
/*
  .o      .ooo     .oooo.     .oooo.   
o888    .88'      d8P'`Y8b   d8P'`Y8b  
 888   d88'      888    888 888    888 
 888  d888P"Ybo. 888    888 888    888 
 888  Y88[   ]88 888    888 888    888 
 888  `Y88   88P `88b  d88' `88b  d88' 
o888o  `88bod8'   `Y8bd8P'   `Y8bd8P'                                      
*/
@media (min-width: 1600px) {
}
/* ############################################## */
@media (min-width: 2560px) {

}
@media (min-width: 3440px) {}
