
#page-footer h4,#page-footer p,#page-footer ul {
    margin: 0px;
    display: inline-block;
}

#page-footer{
    position: relative;
    border: solid 1px red;
    width:calc( 100% - 6px );
    background: #ddd;
    font-style:italic;
    font-size: 80%;
    margin: 5px;
    margin-right:9px;
    padding: 2px;
}
#page-footer p{
    text-align: center;
    width: 100%;
}
#login{
    color: black;
    text-decoration: none;
    font-size: 10px;
    font-weight: normal;
    border: .5ex #0f0 outset;
    font-family: sans-serif;
    padding: 2px;
    background: #ccccff;
    position: absolute;
    right:3px;
    top:3px;
}
#page-mask{
    position:absolute;
    width:100%;
    height:100%;
    background: #ddd;
    opacity: .5;
    display: none;
    z-index: 30;
}
#login-ctl{
    position: absolute;
    left: 30%;
    top:30%;
    background: white;
    border:1px black solid;
    border-radius: 3px;
    z-index: 31;
    display: none;
}
#login-ctl.logged-out,#login-ctl.logged-in {display: block}
.logged-out #login-form {display: grid}
.logged-in #login-form {display: none}
.logged-in #logout-form {display: grid}
.logged-out #logout-form {display: none}
#login-form, #logout-form {
    min-width: 300px;
    //min-height: 200px;
    grid-template-columns: 1fr 1fr;
}
#login-form input {
    grid-column-start: 2;
}
#login-form a, #logout-form a {
    grid-column-start: 2;
    justify-self: end;
}
#login-form label {
    grid-column-start: 1;
}
#login-form h4, #logout-form h4 {
    grid-column-start: 1 / span 2;
    justify-self: center;
}
