* {
    box-sizing: border-box;
}

body {
    height: 100%;
}

body > .container {
    background: white;
    box-shadow:
            5px 0 rgba(0,0,0,0.05),
            4px 0 rgba(0,0,0,0.05),
            3px 0 rgba(0,0,0,0.05),
            2px 0 rgba(0,0,0,0.05),
            1px 0 rgba(0,0,0,0.05),
            -5px 0 rgba(0,0,0,0.05),
            -4px 0 rgba(0,0,0,0.05),
            -3px 0 rgba(0,0,0,0.05),
            -2px 0 rgba(0,0,0,0.05),
            -1px 0 rgba(0,0,0,0.05);
    min-height: 100vh;

    display: grid;
    grid-template-rows: auto 1fr auto;
}

/*<editor-fold desc="Header" defaultstate="collapsed">*/
#header {
    display: grid;
    grid-template-columns: 30px 550px 310px 30px;
    grid-template-rows: auto 40px;
    gap: 5px 10px;
    margin-bottom: 20px;
}

#header > * {
    margin-bottom: 0;
}

#header > .user-menu-wrapper {
    grid-area: 1 / 1 / auto / span 2;
}

#header > #logo {
    grid-area: 1 / 3 / span 2;
    align-self: end;
    width: 100%;
}

#header > #wahltitel {
    grid-area: 2 / 2;
    align-self: end;
}

#header > hr {
    grid-area: 3 / 2 / auto / span 2;
}

#header > #wahlstatistik {
    grid-area: 4 / 2 / auto / span 2;
}

#header > #wahlstatistik::after {
    content: '\2060';
}

#header > .main-menu-wrapper {
    grid-area: 5 / 2 / auto / span 2;
    justify-self: end;
}
/*</editor-fold>*/

/*<editor-fold desc="Button" defaultstate="collapsed">*/
.button-group {
    display: flex;
    align-items: center;
    gap: 10px;

    margin: 10px 0;

    clear: both;
    width: 100%;
}

.button-group .button-group {
    margin: 0;
    flex-grow: 1;
    width: auto;
}

.button-group.left {
    justify-content: start;
    float: none !important;
}

.button-group.right {
    justify-content: end;
    float: none !important;
}

.button-group.space-between {
    justify-content: space-between;
    float: none !important;
}

table .button-group {
    margin: 0;
    gap: 5px;
}

.button-link {
    background: none;
    border: none;
    padding: 0;
    margin: 0;
    font: inherit;

    color: #06c;
    text-decoration: none;
    cursor: pointer;
}

.button-link:focus, .button-link:hover {
    color: red;
}

.button, input[type=file]::file-selector-button {
    background-color: #dfdfdf;
    border: 1px solid #AAAAAA;
    display: inline-block;
    color: #384585;
    font-family: arial, sans-serif;
    margin: 0;
    text-decoration: none;
    font-size: 12px;
    line-height: 1.5;
    padding: 2px 10px;
    user-select: none;
    cursor: pointer;
}

.button.small {
    padding: 0 7px;
}

.button:hover, .button:focus, input[type=file]::file-selector-button:hover, input[type=file]:focus::file-selector-button {
    background-color: #ededed;
    color: red;
    border-color: red;
}

input[type=file]:not(.disabled, [disabled])::file-selector-button:active {
    border: 1px solid red;
}

.button:not(.disabled, [disabled]):active {
    border: 1px solid red;
    position: relative;
    top: 1px;
}

.button.disabled, .button[disabled], input[type=file].disabled::file-selector-button, input[type=file][disabled]::file-selector-button {
    border-color: gray;
    color: gray;
    cursor: default;
    background-color: #ededed;
}

.button.danger {
    color: red;
    border-color: red;
    background-color: #FFCBCB;
}

.button.danger:hover, .button.danger:focus {
    background-color: #FFDFDF;
}

.button.has-spinner {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 5px;
}

.button .spinner {
    display: inline-block;
    width: 1rem;
    height: 1rem;
    vertical-align: -0.125em;
    border-radius: 50%;
    border: 0.2em solid currentColor;
    border-right-color: transparent;

    animation-name: spinner;
    animation-iteration-count: infinite;
    animation-duration: 0.75s;
    animation-timing-function: linear;
}

@keyframes spinner {
    to {
        transform: rotate(360deg);
    }
}

input[type=file]::file-selector-button {
    margin-right: 10px;
}
/*</editor-fold>*/

/*<editor-fold desc="Tooltip" defaultstate="collapsed">*/
.tooltip-top-right, .tooltip-top-left, .tooltip-bottom-right, .tooltip-bottom-left {
    cursor: help;
    position: relative;
    --tooltip-spacing: 15px;
}

:is(.disabled, [disabled]):is(.tooltip-top-right, .tooltip-top-left, .tooltip-bottom-right, .tooltip-bottom-left),
:is(.tooltip-top-right, .tooltip-top-left, .tooltip-bottom-right, .tooltip-bottom-left):has(.tooltip) {
    cursor: help;
}

:is(.tooltip-top-right, .tooltip-top-left, .tooltip-bottom-right, .tooltip-bottom-left) .tooltip {
    position: absolute;
    width: 250px;
    background-color: #FFFFF0;
    border: 1px solid red;
    padding: 0.8em 1em;
    color: black;
    z-index: 200;
    display: none;
}

/* top */
:is(.tooltip-top-left, .tooltip-top-right) .tooltip {
    top: -1px;
    transform: translateY(calc(-100% - var(--tooltip-spacing)));
}

/* bottom */
:is(.tooltip-bottom-left, .tooltip-bottom-right) .tooltip {
    bottom: -1px;
    transform: translateY(calc(100% + var(--tooltip-spacing)));
}

/* left */
:is(.tooltip-top-left, .tooltip-bottom-left) .tooltip {
    left: -1px;
}

/* right */
:is(.tooltip-top-right, .tooltip-bottom-right) .tooltip {
    right: -1px;
}

:is(.tooltip-top-right, .tooltip-top-left, .tooltip-bottom-right, .tooltip-bottom-left):is(:hover, :focus-visible) .tooltip {
    display: revert;
}
/*</editor-fold>*/

/*<editor-fold desc="Flash-Messsage" defaultstate="collapsed">*/
.flash-message-container {
    margin-left: 0;
    margin-right: 0;
    padding: 0;
    margin-bottom: 0.5em;
}

.flash-message {
    font-weight: bold;
    padding: 10px;
    margin: 5px 0;
    background-color: #FFFFF0;
    display: block;
    list-style-type: none;

    border-top: 1px solid;
    border-bottom: 1px solid;
    border-right: none;
    border-left: none;
}

.flash-message.info {
    color: green;
    border-color: green;
}

.flash-message.warn {
    color: blue;
    border-color: blue;
}

.flash-message.error {
    color: red;
    border-color: red;
}

.flash-message.fatal {
    color: red;
    border-color: red;
}

.flash-message.confirm {
    color: red;
    border-color: red;
}
/*</editor-fold>*/

/*<editor-fold desc="Hauptmenü" defaultstate="collapsed">*/

/*
    <nav class="main-menu-wrapper">
        <ul id="main-menu" class="main-menu">
            <li>
                <span>Aktuelle Wahl</span>
                <ul>
                    <li><a href="">Status anzeigen</a></li>
                    <li><a href="">Wahl auswählen</a></li>
                </ul>
            </li>
            <li>
                <span>Import</span>
                <ul>
                    <li><a href="">Gebietshierarchie</a></li>
                    <li><a href="">Geodaten</a></li>
                </ul>
            </li>
            <li>
                <span>Administration</span>
                <ul>
                    <li><a href="">Anwendungsparameter</a></li>
                    <li><a href="">Testfehlermeldung</a></li>
                </ul>
            </li>
        </ul>
    </nav>
 */

.main-menu {
    --main-menu-border-color: #BBD3EF;
    --main-menu-divider-color: var(--main-menu-border-color);

    --main-menu-color: #0066CC;
    --main-menu-bg-color: transparent;
    --main-menu-hover-color: #FF0000;
    --main-menu-hover-bg-color: #EEF3FB;

    --main-menu-nested-color: var(--main-menu-color);
    --main-menu-nested-bg-color: #EEF3FB;
    --main-menu-nested-hover-color: black;
    --main-menu-nested-hover-bg-color: #FF9393;
}

.main-menu {
    margin: 0;
    padding: 0;
    list-style-type: none;

    display: inline-flex;
    flex-direction: row;
    justify-content: end;

    z-index: 100;
    position: relative;
}

.main-menu :is(span, a, input, button), .main-menu-wrapper::before {
    margin: 0;
    padding: 0.1515151515em 0.606060606em;
    border: 1px solid transparent;

    background: none;
    color: var(--main-menu-color);
    text-align: left;

    font-size: 110%;
    letter-spacing: 0.01em;
    user-select: none;
    line-height: calc(1.5151515151em - 2px);
}

.main-menu-wrapper::before {
    content: '\2060';
    display: inline-block;
    padding-left: 0;
    padding-right: 0;
}

.main-menu > li {
    position: relative;
    display: inline-flex;
    margin-left: -1px;
}

.main-menu > li:not(:last-child)::after {
    content: "";
    border-right: 1px solid var(--main-menu-divider-color);
    position: absolute;
    top: 16.6666666%;
    bottom: 16.6666666%;
    right: 0;
}

.main-menu > li > :is(span, a) {
    display: inline-block;

    font-weight: bold;
    text-transform: uppercase;

    color: var(--main-menu-color);
    background-color: var(--main-menu-bg-color);
}

.main-menu > li > :is(span, a):is(:focus, :hover) {
    color: var(--main-menu-hover-color);
}

.main-menu > li:is(:hover, :focus-within) > :is(span, a),
.main-menu > li > :is(span, a):focus {
    background-color: var(--main-menu-hover-bg-color);
    border-color: var(--main-menu-border-color);
    text-decoration: none;
}

/* Submenu */

.main-menu > li ul {
    /* visually-hidden-focusable */
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0,0,0,0);
    white-space: nowrap;
    border: 0;
}

.main-menu > li:is(:hover, :focus-within) ul {
    display: block;
    padding: 0;
    margin: 0;

    height: unset;
    clip: unset;
    overflow: unset;
    white-space: unset;

    position: absolute;
    top: calc(100% - 1px);
    left: 0;
    width: 30ch;

    background-color: var(--main-menu-nested-bg-color);
    border: solid var(--main-menu-border-color) 1px;
    list-style: none;
    word-wrap: break-word;
}

.main-menu > li ul > li > :is(span, a, input, button) {
    display: block;
    width: 100%;
    cursor: pointer;
    font-family: inherit;
}

.main-menu > li ul > li > :is(span, a, input, button):is(:focus, :hover) {
    color: var(--main-menu-nested-hover-color);
    background-color: var(--main-menu-nested-hover-bg-color);
}

.main-menu > li ul > li > :is(span, a, input, button)::before {
    content: '❯';
    padding-right: 8px;
    font-weight: 600;
}

.main-menu > li ul > li:not(:last-child) {
    border-bottom: solid 1px var(--main-menu-border-color);
}
/*</editor-fold>*/

/*<editor-fold desc="Tree" defaultstate="collapsed">*/

/*
    <aside class="tree-container">
        <form class="quick-nav>
            <label></label>
            <input></input>
            <button></button>
        </form>

        <ul class="tree">
            <li>
                <div  class="tree-item" id="tree-item-900">
                    <a href="">
                        <span class="nummer>900</span>
                        <span class="verarbeitungsstatus grau"></span>
                        <span class="name">Bayern</span>
                    </a>
                </div>
                <ul class="tree">
                    <li>
                        <div class="tree-item" id="tree-item-901">
                            <a href="">
                                <span class="nummer>901</span>
                                <span class="verarbeitungsstatus grau"></span>
                                <span class="name">Oberbayern</span>
                            </a>
                        </div>
                        <ul class="tree">
                            <li>
                                <div class="tree-item leaf" id="tree-item-100">
                                    <a href="">
                                        <span class="nummer>100</span>
                                        <span class="verarbeitungsstatus grau"></span>
                                        <span class="name">Landeshauptstadt München</span>
                                    </a>
                                </div>
                            </li>
                            <li>
                                <div class="tree-item leaf" id="tree-item-101">
                                    <a href="">
                                        <span class="nummer>101</span>
                                        <span class="verarbeitungsstatus grau"></span>
                                        <span class="name">München-Hadern</span>
                                    </a>
                                </div>
                            </li>
                        </ul>
                    </li>
                </ul>
            </li>
        </ul>

        <script src="js/tree.js" type="text/javascript"></script>
    </aside>
 */


.tree-container {
    padding: 1em;

    background-color: #DFE8F2;
    border: solid #BBD3EF;
    border-width: 1px 1px 1px 0;
    min-height: 30em;
    flex-grow: 0;
    flex-shrink: 0;
}

.tree-container .quick-nav {
    display: grid;
    align-items: center;
    grid-template-columns: min-content 1fr min-content;
    gap: 0.5rem;
    margin-bottom: 1em;
}

.tree-container .quick-nav input.is-invalid {
    border-color: #dc3545;
    padding-right: calc(1.5em + .75rem);
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12' width='12' height='12' fill='none' stroke='%23dc3545'%3e%3ccircle cx='6' cy='6' r='4.5'/%3e%3cpath stroke-linejoin='round' d='M5.8 3.6h.4L6 6.5z'/%3e%3ccircle cx='6' cy='8.2' r='.6' fill='%23dc3545' stroke='none'/%3e%3c/svg%3e");
    background-repeat: no-repeat;
    background-position: right calc(.375em + .1875rem) center;
    background-size: calc(.75em + .375rem) calc(.75em + .375rem);
}

.tree-container .tree {
    list-style: none;
    margin: 0;
    padding: 0;
    
    display: grid;
    grid-template-columns: 1em min-content max-content 1fr; /* toggle, nummer, status, name */
}

.tree-container .tree .tree {
    grid-column: 2 / span 3;
}

.tree-container .tree > li {
    display: grid;
    grid-template-columns: subgrid;
    grid-column: span 4;
}

.tree-container .tree-item:not(.leaf)::before {
    content: '⏵';
    width: 1em;
    display: inline-block;
}

.tree-container .tree-item.open:not(.leaf)::before {
    content: '⏷';
}

.tree-container .tree-item + .tree {
    display: none;
}

.tree-container .tree-item.open + .tree {
    display: grid;
}

.tree-container .tree-item {
    line-height: 1.5em;
    display: grid;
    grid-template-columns: subgrid;
    grid-column: span 4;
}

.tree-container .tree-item > :is(a, span) {
    display: grid;
    grid-template-columns: subgrid;
    grid-column: 2 / span 3;
    align-items: baseline;
}

.tree-container .tree-item > :is(a, span) > .name {
    padding-left: 0.4em;
}

.tree-container .tree-item > :is(a, span) > .nummer {
    font-variant-numeric: tabular-nums;
}

.tree-container .tree-item > :is(a, span) > * > .verarbeitungsstatus {
    padding-left: 0.4em;
}
/*</editor-fold>*/

/*<editor-fold desc="Verarbeitungsstatus">*/
.verarbeitungsstatus {
    display: inline-block;
    --verarbeitungsstatus-scale: 1;
}

@supports (width: 1cap) {
    .verarbeitungsstatus {
        --verarbeitungsstatus-size: 1cap;
    }
}

@supports not (width: 1cap) {
    .verarbeitungsstatus {
        --verarbeitungsstatus-size: 0.75em;
    }
}

.verarbeitungsstatus::before {
    content: '';
    display: inline-block;
    width: var(--verarbeitungsstatus-size);
    height: var(--verarbeitungsstatus-size);
    border-radius: var(--verarbeitungsstatus-size);
    line-height: var(--verarbeitungsstatus-size);
}

.verarbeitungsstatus.big::before {
    font-size: 1.5em;
    translate: 0 16.6666666%;
}

.verarbeitungsstatus.blau::before {
    content: '\2713';
    color: blue;
    font-weight: bold;
    background-color: transparent;
}

.verarbeitungsstatus.schwarz::before {
    border-radius: 0;
    background-color: black;
}

.verarbeitungsstatus.rot::before {
    background-color: red;
}

.verarbeitungsstatus.gelb::before {
    background-color: #FFEF00;
}

.verarbeitungsstatus.gruen::before {
    background-color: limegreen;
}

.verarbeitungsstatus.grau::before {
    background-color: gray;
}
/*</editor-fold>*/

/*<editor-fold desc="Footer und Benutzermenü" defaultstate="collapsed">*/
.footer-wrapper, .user-menu-wrapper, .users-online-wrapper {
    border-color: #BBD3EF;
    border-width: 1px;
    padding: 4px 12px;
}

.users-online-wrapper {
    border-top-style: solid;
}

.footer-wrapper {
    border-top-style: solid;
    margin-top: 1em;
}

.user-menu-wrapper {
    background-color: #DFE8F2;
    border-bottom-style: solid;
    border-right-style: solid;
}

.user-menu-wrapper::before {
    content: '\2060';
}

.users-online {
    margin: 0;
}

.footer, .user-menu {
    margin: 0;
    padding: 0;
    display: inline-flex;
    align-items: center;
}

.footer li, .user-menu li {
    display: inline-flex;
    margin: 0;
    padding: 0;
}

.footer li:not(:last-child)::after, .user-menu li:not(:last-child)::after {
    content: '|';
    color: #c4d6ec;
    padding: 0 12px;
}
/*</editor-fold>*/

/*<editor-fold desc="Color-Picker">*/
.color-picker {
    display: inline-flex;
    align-items: center;
    gap: .5em;
    white-space: nowrap;
}

.color-picker .color-picker-wrapper {
    display: inline-flex;
    padding: 4px;
}

.color-picker .empty {
    opacity: 0;
}

.color-picker input[type=color] {
    border: none;
    cursor: pointer;
    width: 1.25em;
    height: 1.25em;
    font-size: inherit;
    background: none;
    padding: 0;
}

.color-picker input[type="color"]::-webkit-color-swatch-wrapper {
    padding: 0;
}

.color-picker input[type=color][disabled] {
    cursor: unset;
}
/*</editor-fold>*/

/*<editor-fold desc="Form">*/
input[type="text"], input[type="password"], input[type="url"], input[type="email"], input[type="number"], input.text, input.title, textarea, select:not([multiple]):not([size]), select:not([multiple])[size="1"] {
    font-size: 0.75rem;
    padding: 0.33333em 0.25em;
    margin: 0;
    border-color: #bbb;
}
/*</editor-fold>*/

/*<editor-fold desc="Table">*/
.table-striped tr:nth-child(even) {
    background-color: #DFE8F2;
}

table table {
    margin-bottom: 0;
}
/*</editor-fold>*/

/*<editor-fold desc="Headings">*/
h1:has(+ hr) {
    margin-bottom: 0.25em;
}

:is(h2, h3, h4, h5, h6):has(+ hr) {
    margin-bottom: 0;
}

hr {
    background: #BBD3EF;
    color: #BBD3EF;
}
/*</editor-fold>*/

.stacktrace {
    overflow-x: auto;
    margin: 0;
    font-size: 80%
}

.password {
    user-select: all;
}

.nowrap {
    white-space: nowrap;
}

.border-box {
    border: 1px solid #BBD3EF;
    padding: 19px;
}

#login-dialog {
    display: grid;
    grid-template-columns: 1fr 2fr;
    align-items: center;
    padding: 10px;
    background-color: #DFE8F2;
    border: 1px solid #BBD3EF;
    gap: 10px;
}

#captcha-image {
    vertical-align: middle;
}

form.form-inline {
    display: inline-block;
}

.hide {
    display: none !important;
}

.text-start {
    text-align: left;
}

.text-end {
    text-align: right;
}

.fw-bold {
    font-weight: bold;
}

.va-top {
   vertical-align: top; 
}

.va-bottom {
    vertical-align: bottom;
}

.no-code {
    font: inherit;
    line-height: inherit;
    margin: 0;
}

.w-0 {
    width: 0;
}

.w-100 {
    width: 100%;
}
