@font-face {
    font-family: Nunito;
    src: url(/content/includes/Nunito_Sans/NunitoSans-Regular.ttf);
}

.code {
    font-family: 'Courier New', serif;
}

.klappbar {
    width: 100%;
    /* max-width: 1000px; */
    margin: 1em auto;
    padding: 0.5em;
    cursor: pointer;
    clear: both;
    display: block;
}

.klappbar .klappbar-arrow {
    float: left;
    width: 1.5em;
    text-align: left;
    line-height: 1.3em;
    font-size: 1.2em;
    color: #666;
    cursor: pointer;
    display: inline;
}

.klappbar .klappbar-heading {
    float: left;
    text-align: left;
    font-weight: bold;
    font-size: 1.2em;
    color: #666;
    line-height: 1.3em;
    display: inline;
}

.klappbar .klappbar-content {
    clear: both;
    width: 100%;
    padding-top: 1em;
}

#warning_wrapper {
    font-size:0.8em;
    display: none;
    margin: 1em auto;
    width: 80%;
    max-width: 1000px;
    padding: 1.5em;
    border-radius: 0.5em;
    border: 1px solid #cdad00;
    background-color: rgba(205,173,0,0.25);
}

/** {
    font-family: sans-serif;
    font-size: 11pt;
    line-height: 1.5em;
}*/
/* 
h1 {
    font-size: 1.6em;
}

h2 {
    font-size: 1.4em;
    width: 100%;
    background-color: #EEE;
    padding: 0.25em;
    border-bottom: 1px solid #CCC;
    margin-top: 2em;
}

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

h3 {
    font-size: 1.2em;
    width: 100%;
    border-bottom: 1px solid #AAA;
    color: #444444;
} */

/* div.table {
    display: table;
    margin: 1em auto;
    width: 100%;
}

div.tr {
    display: table-row;
}

div.td, div.th, div.bigth {
    display: table-cell;
    padding: 0.3em;
}

div.th {
    font-weight: bold;
} */

div.bigth {
    font-weight: bold;
    font-size: 1.2em;
    color: #333333;
}

.code {
    font-family: 'Courier New', serif;
}

/* a:link, a:visited {
    text-decoration: none;
}

a:hover {
    text-decoration: none;
    color: blueviolet;
} */

.buttonAPI {
    position: fixed;
    top: 1em;
    right: 1em;
    z-index: 10;
}
/* 
.button {
    padding: 0.5em;
    background-color: #FFF;
    border: 1px solid #666;
    color: #333;
    border-radius: 0.5em;
    transition: all ease-in-out 0.2s;
}

.button:hover {
    cursor: pointer;
    background-color: #EEE;
    border: 1px solid #000;
    color: #000;
    transition: all ease-in-out 0.2s;
} */

div.wrapper {
    width: 80%;
    margin: 0 auto;
}

.frame {
    margin: 1em auto;
    padding: 0.5em;
    border-radius: 0.5em;
}

.success {
    color: #006600;
    background-color: rgba(0,255,0,0.3);
}

.error {
    color: #660000;
    background-color: rgba(255,100,100,0.3);
}

.f_wrapper {
    margin-bottom: 1em;
}

.f_description {
    padding: 0.1em;
    color: #999999;
    font-size: 0.8em;
}

.f_title {
    padding: 0.1em;
    font-weight: bold;
}

.cm_sidemenu
{
    top: 0;
    left: 0;
    max-height: 100vh;
    overflow: hidden;
    position: sticky;
    background-color: #eee;
    /*float: left;*/
    min-width: 260px;
    padding-top: 6em;
}

@media (max-width:800px){
    .cm_sidemenu
    {
        display: none;
    }
    .api-content
    {
        padding: 1em;
    }
}


.anchor {
    display: block;
    position: relative;
    top: -60px;
    visibility: hidden;
}

.content_container
{
    display: flex;
    flex: 1;
}
.api-content
{
    max-width: 800px;
    margin-left: auto;
    margin-right: auto;
}

.logos_start
{
    display:flex;
    justify-content: center;
    align-items: center;

    width: 100%;
}

.logos_start_parent
{
    border-top: 2px solid #ffeb3b;
    border-bottom: 2px solid #ffeb3b;
}
.logos_start_container
{
    width: 13%;
    height: 13%;
    margin: 0.5em;
}
.logos_start_img
{
    width: 100%;
    height: 100%;
}

.try-container
{
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    flex-direction: column;
    justify-items: center;
    align-items: center;
}

.try-content
{
    display: flex;
    flex-direction: column;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    max-width: 900px;
}


.try-form
{
    padding: 1em;


}

.try-result
{
    width: 100%;
    padding: 1em;
}
.try-values
{
    display: flex;
    justify-content: center;
    width: 100%;
}
.try-values-box
{
    background-color: #DDD;
    color: #111;
    padding: 1em;
    margin-left: 2em;
    margin-right: 2em;
    margin-bottom: 1em;
}

#mapWrapper
{
    max-width:800px;
    height: 400px;
    display: none;
}


.spendenbox_container
{
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
}

.spendenbox
{
    width: 250px;

    color: #FFF;
    background-color: #111;
    margin: 0.4em;
    padding: 0.5em;


    text-align: center;
}

.spendenbox:hover
{
    background-color: #EEE;
    color: #111;
}

/* .footer
{
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    text-align: center;
    box-shadow: 0 2px 5px 0 rgba(0,0,0,0.16),0 2px 10px 0 rgba(0,0,0,0.12);
    background-color: #DDD;
}

a{
    font-weight: bold;
    color: #c1514d;
}
a:hover
{
    color: #ff5722;
} */

.cm-content
{
    max-width: 640px;
    margin-left: auto;
    margin-right: auto;
}

.excel_download
{

    text-align: center;

}
.excel_download a
{

    font-size: 1.2em;
    font-weight: bold;
}

.code_window
{
    background-color: #444;
    padding: 1.2em;
    color: #DDDDDD;
    font-family: monospace;
    width: 100%;
}

.try-container label
{
    background-color: #000;
    color: #fff;
    height: 2em;
    line-height: 2em;
    margin: 0.2em;
    display: inline-block;
    padding-left: 0.3em;
    padding-right: 0;

}

.try-container input
{
    height: 2em;
}
.try-container select
{
    height: 2em;
    background-color: #DDDDDD;
}

/*
.app1 label
{
    background-color: #000;
    color: #fff;
    height: 2em;
    line-height: 2em;
    margin-right: 0.2em;
    display: inline-block;
    padding-left: 0.3em;
    margin-left: 0;
    margin-bottom: 0.3em;
    margin-top: 0.3em;

}
*/
/* .app1 input
{
    height: 2em;
}
.app1 select
{
    height: 2em;
    background-color: #DDDDDD;
} */



/* input, select, textarea {
    padding: 0.25em;
} */

.button_calc
{
    background-color: #000;
    color: #DDDDDD;
    font-weight: bold;
    border: 0px;
    height: 2.5em!important;
    padding: 0.5em;
    cursor: pointer;
    opacity: 1;
}

.button_calc:disabled,
.button_calc[disabled]{
    opacity: 0.5;
}

.button_calc:hover
{
    background-color: #ddd;
    color: #000
}

.results_container
{
    width: 100%;
}


/* App 1 und 2 Styles */
@media (orientation: landscape)
{
    .app-col1 {
        width: 49%;
        float: left;
    }

    .app-col2 {
        width: 49%;
        float: right;
    }

    .app_form_wrapper {
        display: flex;
        float: left;
        padding: 0.5em;
    }

    /*
    .app2_route_wrapper{
        width:40%;
        float:left;
    }

    .app2_result_wrapper {
        width:58%;
        float:right;
    }*/
}

@media (orientation: portrait)
{
    .app-col1 {
        width: 100%;
        margin: 1em auto;
    }

    .app-col2 {
        width: 100%;
        margin: 1em auto;
    }


    .app_form_wrapper {
        display: flex;
        padding: 0.5em;
    }

}

.link-color-header
{
    color: #000;
}

.cm_faq_summary {

}

details
{
    background-color: #fcfff3;
}
details > summary
{
    list-style-type: none;
    cursor: pointer;
}
.cm_faq_details
{
    padding: 1em;
}
.cm_summary_wrapper
{
    display: flex;
    justify-content: space-between;
    font-size: 1em;
    background-color: #EEE;
    padding: 0.5em;
    border-bottom: 1px solid #CCC;
}
.cm_faq_icon {
    transition: transform 0.2s;
}

details[open] .cm_faq_icon {
    transform: rotate(180deg);
}

details[open] summary ~ * {
    animation: sweep 0.2s ease-in-out;
}

@keyframes sweep {
    0% {
        opacity: 0;
        margin-left: -10px;
    }
    100% {
        opacity: 1;
        margin-left: 0px;
    }
}

.detailsReset > summary {
    list-style: none;
}

.detailsReset > summary::before {
    display: none;
}

.detailsReset > summary::-webkit-details-marker {
    display: none;
}

.cm_faq_header
{
    display: flex;
    justify-content: center;
}
.cm_faq_header_element
{
    margin: 1em;
}

.cm_faq_summary {

}

details
{
    background-color: #fcfff3;
}
details > summary
{
    list-style-type: none;
    cursor: pointer;
}
.cm_faq_details
{
    padding: 1em;
}
.cm_summary_wrapper
{
    display: flex;
    justify-content: space-between;
    font-size: 1em;
    background-color: #EEE;
    padding: 0.5em;
    border-bottom: 1px solid #CCC;
}
.cm_faq_icon {
    transition: transform 0.2s;
}

details[open] .cm_faq_icon {
    transform: rotate(180deg);
}

details[open] summary ~ * {
    animation: sweep 0.2s ease-in-out;
}

@keyframes sweep {
    0% {
        opacity: 0;
        margin-left: -10px;
    }
    100% {
        opacity: 1;
        margin-left: 0px;
    }
}

.detailsReset > summary {
    list-style: none;
}

.detailsReset > summary::before {
    display: none;
}

.detailsReset > summary::-webkit-details-marker {
    display: none;
}

.cm_faq_header
{
    display: flex;
    justify-content: center;
}
.cm_faq_header_element
{
    margin: 1em;
}

.app_container
{
    width: 100%;
}

/* 
#navbar
{
    font-size: 1em;
}

#navbar a
{
    font-weight: normal;
} */

.headerlogo
{
    font-weight: bold !important;
    letter-spacing: 2px;
    margin-left: 0.5em;
}

#navDemo
{
    border-bottom: 1px solid black;
    box-shadow: 0 2px 5px 0 rgba(0,0,0,0.16),0 2px 10px 0 rgba(0,0,0,0.12);
}


@media (max-width:1100px){

    #navbar
    {
        font-size: 0.9em;
    }
}


@media (min-width:1920px){
    #navbar
    {
        font-size: 1.5em;
    }
    .headerlogo
    {
        margin-left: 1em;
    }
}

.teilstrecken_remove_td
{
    display: none;
}
.teilstrecken_remove_td:hover
{
    display: inline;
}

.app2_content table tr:hover .teilstrecken_remove_td
{
    display: inline!important;
}

@media screen and (max-width: 600px) {
    .app2_content table thead {
        display: none;
    }
    .app2_content table td {
           display: flex;
       }

    .app2_content table tr td .teilstrecken_remove_td
    {
        display: inline!important;
    }

    .app2_content table td::before {
        content: attr(label);
        font-weight: bold;
        width: 120px;
        min-width: 120px;
    }

    .app2_content table tr {
        border-bottom: 3px solid #ddd;
        display: block;
        margin-bottom: .625em;
    }
}

.w3-jumbo, .text-shadow
{
    text-shadow:
            5px 0px 0px #fed501,   /* Right shadow */
            -5px 0px 0px #fed501,  /* Left shadow */
            0px 5px 0px #fed501,   /* Bottom shadow */
            0px -5px 0px #fed501;  /* Top shadow */

}

.widget_form label input
{
    display: flex;
    flex-direction: column;
}

.widget_form label
{
    padding-left: 0.4em;
    font-size: 1em;
    font-weight: bold;
}
.widget_buttons
{
    margin-top: 1em;
    margin-bottom: 2em;
}
.widget_buttons button
{
    margin: 0.5em;
}

#widget_list table
{
    border-collapse: collapse;
    margin: 25px 0;
    width: 100%;
}
#widget_list tr:nth-child(even)
{
    background-color: #f2f2f2;
}
#widget_list tr:hover {background-color: #ddd;}

#widget_list td
{
    vertical-align: middle;
    padding: 0.3em 0.4em;
    font-size: 0.9em;
    line-height: 1;
}
#widget_list .td_left
{
    text-align: end;
}
#widget_list .td_center
{
    text-align: center;
}
#widget_list .td_right
{
    text-align: start;
}

#widget_list .th_nr
{
    width: 2em;
}

#widget_list .th_actions
{
    width: 5em;
}
#widget_list .th_key
{
    width: 20em;
}
.copy_to_clipboard_div
{
    margin: 0.8em;
    cursor: pointer;
}

.widget_code
{
    resize: none;
    overflow-y: hidden;

}



:root,
:host {
  --ol-background-color: white;
  --ol-accent-background-color: #F5F5F5;
  --ol-subtle-background-color: rgba(128, 128, 128, 0.25);
  --ol-partial-background-color: rgba(255, 255, 255, 0.75);
  --ol-foreground-color: #333333;
  --ol-subtle-foreground-color: #666666;
  --ol-brand-color: #00AAFF;
}

.ol-box {
  box-sizing: border-box;
  border-radius: 2px;
  border: 1.5px solid var(--ol-background-color);
  background-color: var(--ol-partial-background-color);
}

.ol-mouse-position {
  top: 8px;
  right: 8px;
  position: absolute;
}

.ol-scale-line {
  background: var(--ol-partial-background-color);
  border-radius: 4px;
  bottom: 8px;
  left: 8px;
  padding: 2px;
  position: absolute;
}

.ol-scale-line-inner {
  border: 1px solid var(--ol-subtle-foreground-color);
  border-top: none;
  color: var(--ol-foreground-color);
  font-size: 10px;
  text-align: center;
  margin: 1px;
  will-change: contents, width;
  transition: all 0.25s;
}

.ol-scale-bar {
  position: absolute;
  bottom: 8px;
  left: 8px;
}

.ol-scale-bar-inner {
  display: flex;
}

.ol-scale-step-marker {
  width: 1px;
  height: 15px;
  background-color: var(--ol-foreground-color);
  float: right;
  z-index: 10;
}

.ol-scale-step-text {
  position: absolute;
  bottom: -5px;
  font-size: 10px;
  z-index: 11;
  color: var(--ol-foreground-color);
  text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color);
}

.ol-scale-text {
  position: absolute;
  font-size: 12px;
  text-align: center;
  bottom: 25px;
  color: var(--ol-foreground-color);
  text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color);
}

.ol-scale-singlebar {
  position: relative;
  height: 10px;
  z-index: 9;
  box-sizing: border-box;
  border: 1px solid var(--ol-foreground-color);
}

.ol-scale-singlebar-even {
  background-color: var(--ol-subtle-foreground-color);
}

.ol-scale-singlebar-odd {
  background-color: var(--ol-background-color);
}

.ol-unsupported {
  display: none;
}

.ol-viewport,
.ol-unselectable {
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
  -webkit-tap-highlight-color: transparent;
}

.ol-viewport canvas {
  all: unset;
}

.ol-selectable {
  -webkit-touch-callout: default;
  -webkit-user-select: text;
  -moz-user-select: text;
  user-select: text;
}

.ol-grabbing {
  cursor: -webkit-grabbing;
  cursor: -moz-grabbing;
  cursor: grabbing;
}

.ol-grab {
  cursor: move;
  cursor: -webkit-grab;
  cursor: -moz-grab;
  cursor: grab;
}

.ol-control {
  position: absolute;
  background-color: var(--ol-subtle-background-color);
  border-radius: 4px;
}

.ol-zoom {
  top: .5em;
  left: .5em;
}

.ol-rotate {
  top: .5em;
  right: .5em;
  transition: opacity .25s linear, visibility 0s linear;
}

.ol-rotate.ol-hidden {
  opacity: 0;
  visibility: hidden;
  transition: opacity .25s linear, visibility 0s linear .25s;
}

.ol-zoom-extent {
  top: 4.643em;
  left: .5em;
}

.ol-full-screen {
  right: .5em;
  top: .5em;
}

.ol-control button {
  display: block;
  margin: 1px;
  padding: 0;
  color: var(--ol-subtle-foreground-color);
  font-weight: bold;
  text-decoration: none;
  font-size: inherit;
  text-align: center;
  height: 1.375em;
  width: 1.375em;
  line-height: .4em;
  background-color: var(--ol-background-color);
  border: none;
  border-radius: 2px;
}

.ol-control button::-moz-focus-inner {
  border: none;
  padding: 0;
}

.ol-zoom-extent button {
  line-height: 1.4em;
}

.ol-compass {
  display: block;
  font-weight: normal;
  will-change: transform;
}

.ol-touch .ol-control button {
  font-size: 1.5em;
}

.ol-touch .ol-zoom-extent {
  top: 5.5em;
}

.ol-control button:hover,
.ol-control button:focus {
  text-decoration: none;
  outline: 1px solid var(--ol-subtle-foreground-color);
  color: var(--ol-foreground-color);
}

.ol-zoom .ol-zoom-in {
  border-radius: 2px 2px 0 0;
}

.ol-zoom .ol-zoom-out {
  border-radius: 0 0 2px 2px;
}

.ol-attribution {
  text-align: right;
  bottom: .5em;
  right: .5em;
  max-width: calc(100% - 1.3em);
  display: flex;
  flex-flow: row-reverse;
  align-items: center;
}

.ol-attribution a {
  color: var(--ol-subtle-foreground-color);
  text-decoration: none;
}

.ol-attribution ul {
  margin: 0;
  padding: 1px .5em;
  color: var(--ol-foreground-color);
  text-shadow: 0 0 2px var(--ol-background-color);
  font-size: 12px;
}

.ol-attribution li {
  display: inline;
  list-style: none;
}

.ol-attribution li:not(:last-child):after {
  content: " ";
}

.ol-attribution img {
  max-height: 2em;
  max-width: inherit;
  vertical-align: middle;
}

.ol-attribution button {
  flex-shrink: 0;
}

.ol-attribution.ol-collapsed ul {
  display: none;
}

.ol-attribution:not(.ol-collapsed) {
  background: var(--ol-partial-background-color);
}

.ol-attribution.ol-uncollapsible {
  bottom: 0;
  right: 0;
  border-radius: 4px 0 0;
}

.ol-attribution.ol-uncollapsible img {
  margin-top: -.2em;
  max-height: 1.6em;
}

.ol-attribution.ol-uncollapsible button {
  display: none;
}

.ol-zoomslider {
  top: 4.5em;
  left: .5em;
  height: 200px;
}

.ol-zoomslider button {
  position: relative;
  height: 10px;
}

.ol-touch .ol-zoomslider {
  top: 5.5em;
}

.ol-overviewmap {
  left: 0.5em;
  bottom: 0.5em;
}

.ol-overviewmap.ol-uncollapsible {
  bottom: 0;
  left: 0;
  border-radius: 0 4px 0 0;
}

.ol-overviewmap .ol-overviewmap-map,
.ol-overviewmap button {
  display: block;
}

.ol-overviewmap .ol-overviewmap-map {
  border: 1px solid var(--ol-subtle-foreground-color);
  height: 150px;
  width: 150px;
}

.ol-overviewmap:not(.ol-collapsed) button {
  bottom: 0;
  left: 0;
  position: absolute;
}

.ol-overviewmap.ol-collapsed .ol-overviewmap-map,
.ol-overviewmap.ol-uncollapsible button {
  display: none;
}

.ol-overviewmap:not(.ol-collapsed) {
  background: var(--ol-subtle-background-color);
}

.ol-overviewmap-box {
  border: 1.5px dotted var(--ol-subtle-foreground-color);
}

.ol-overviewmap .ol-overviewmap-box:hover {
  cursor: move;
}