﻿@import url('https://fonts.googleapis.com/css2?family=Inter:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&display=swap');
@font-face {
    font-family: 'neon';
    src: url('/inc/neon.woff2') format('woff2');
}

:root {
    --color-bg: #f7f7f7;
    /*--color-bg: #f6f8fa;*/
    --color-txt: #333;
    --border-color: #333; /*#ccc;*/
    --placeholder-color: #999;
    --border: solid 1px var(--border-color);
    --border-color-focus: #06f;
    --border-radius: 6px;
    --primary-blue: #06f;
    --primary-blue-outline: 1px solid var(--primary-blue);
    --font-size: 14px;
    --error-color: #f00;
    --success-color: #060;
    /*--font-family: system-ui, sans-serif;*/ /* https://modernfontstacks.com/ */
    --font-family: 'Inter', system-ui, sans-serif; /* https://modernfontstacks.com/ */

    --font-regular: 400 var(--font-size) var(--font-family);
    /*--font-medium: 600 var(--font-size) var(--font-family);*/

    --font-medium: 700 18px var(--font-family);
}

html, body {
    margin: 0;
    border: 0;
    padding: 0;
    font: var(--font-regular);
    background-color: var(--color-bg);
    color: var(--color-txt);
    /*height:100%;*/
}

a {
    font: var(--font-medium);
    color: var(--primary-blue);
    text-decoration-color: var(--color-txt);
    outline: none;
    text-decoration: none;
    text-decoration-thickness: 1px;
    text-underline-offset: 3px;
}

    a:hover, a:focus {
        text-decoration: underline
    }

div {
    display: block;
    box-sizing: border-box;
}

fieldset {
    margin: 0;
    border: 0;
    padding: 0;
}

form {
    outline: 0;
}

h1 {
    /*font: var(--font-medium);
    font-size: 2em;*/
    font: 900 32px var(--font-family);

    margin: 0;
    padding: 10px 0;
    text-align: center
}

i.cv-border {
    border-color: #eee;
}

    i.cv-border:hover {
        background-color: #eee;
    }

i.cv-req::before {
    font-size: 0.5em;
    vertical-align: super;
    color: #f00;
    margin-left: 2px
}

label {
    font: var(--font-medium);
    padding-bottom: 5px;
}

p {
    margin: 0;
}

input, select, textarea {
    margin: 0;
    border: var(--border);
    border-radius: var(--border-radius);
    padding: 10px;
    outline: 0;
    color: var(--color-txt);
    font: var(--font-regular);
    /*font-size: 16px;*/
    font-size: 18px;
    flex: 1;
}
textarea {
    resize: none;
}
    input:hover, input:focus, textarea:hover, textarea:focus, select:hover, select:focus {
        border-color: var(--border-color-focus);
        outline: 1px solid var(--border-color-focus);
    }

    input::placeholder, textarea::placeholder, select:has(option[value=""]:checked) {
        color: var(--placeholder-color);
    }

    input[type="radio"] {
        display: none;
    }

.radio-container {
    display: flex;
    border-radius: var(--border-radius);
}

    .radio-container:hover {
        border-color: #06f;
        outline: var(--primary-blue-outline);
    }

    .radio-container label {
        margin: 0 0 0 -1px;
        border: var(--border);
        border-color: var(--border-color);
        padding: 10px;
        outline: 0;
        color: var(--color-txt);
        font: var(--font-regular);
        font-size: 16px;
        flex: 1;
        cursor: pointer;
        white-space: nowrap;
        user-select: none;
    }

    .radio-container input[type="radio"]:checked + label {
        background-color: var(--primary-blue);
        border-color: var(--primary-blue);
        color: #fff;
        z-index: 1;
    }

    .radio-container label:first-of-type {
        border-top-left-radius: var(--border-radius);
        border-bottom-left-radius: var(--border-radius);
        margin-left: 0;
    }

    .radio-container label:last-of-type {
        border-top-right-radius: var(--border-radius);
        border-bottom-right-radius: var(--border-radius);
    }

    .radio-container:hover label {
        border-color: var(--primary-blue);
    }

select {
    -webkit-appearance: none;
    -moz-appearance: none;
    box-sizing: content-box;
    background-image: url('data:image/svg+xml,%3Csvg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" style="fill: rgba(51, 51, 51, 1);transform: ;msFilter:;"%3E%3Cpath d="M16.293 9.293 12 13.586 7.707 9.293l-1.414 1.414L12 16.414l5.707-5.707z"%3E%3C/path%3E%3C/svg%3E');
    background-repeat: no-repeat;
    background-position: right 5px center;
}

    select::-ms-expand {
        display: none;
    }

button {
    font: var(--font-medium);
    /*font-size: 16px;*/
    font-size: 20px;
    background-color: var(--primary-blue);
    color: #fff;
    margin: 0;
    border: var(--border);
    border-radius: var(--border-radius);
    border-color: var(--primary-blue);
    padding: 10px 0;
    cursor: pointer;
    text-align: center;
    user-select: none;
    outline: none;
    flex: 1
}

    button:hover {
        background-color: #0059f2; /*5% darker*/
        text-decoration: underline;
        text-decoration-thickness: 1px;
        text-underline-offset: 3px;
    }

    button.disabled {
        cursor: not-allowed;
    }

.btn-alt, .btn-alt:hover {
    background-color: #fff;
    color: var(--primary-blue);
}

button .anchor {
    font-size: var(--font-size);
    background-color: transparent;
    color: inherit;
    margin: 0;
    border: 0;
    padding: 0;
    text-decoration: underline;
    text-decoration-thickness: 1px;
    text-underline-offset: 3px;
}

.break {
    flex-basis: 100%;
    width: 0;
    height: 0;
}

.button-icon {
    /*margin-left: 10px;*/
    border: 0;
    /*border-radius: 50%;*/
    /*padding: 5px 0;*/
    padding: 5px 0 5px 10px;
    outline: 0;
    color: var(--color-txt);
    font-size: 16px; /*1.25em;*/
    cursor: pointer;
    /*    text-align: center*/
}
/*    .button-icon:hover {
        color: var(--color-txt);
        background-color: #ccc;
    }*/
/*        .button-icon:hover > i {
            color: var(--color-txt);
        }*/
.logo {
    padding: 10px;
    transform: skew(-18deg);
}

    .logo:hover {
        background-color: var(--primary-blue);
        text-decoration: none;
    }

    .logo p {
        transform: skew(18deg);
        font-size: 20px;
    }

div.sec-logo {
    margin: 20px 0 40px 0;
    text-align: center;
    font-size: 18px;
}

div.sec-foot {
    font-size: 12px;
    color: #666;
    margin: 20px auto 0 auto;
    max-width: 375px;
}

/*.err, .success {
    flex-basis: 100%;
    padding-top: 5px;
    color: var(--error-color);
    display: none;
}*/
.err, .success, .info {
    flex-basis: 100%;
    margin-top: 10px;
    padding: 10px;
    border-radius: var(--border-radius);
    color: var(--error-color);
    display: none;


    font-size:18px;
}

.err {
    background-color: #fae9e8;
}

.success {
    background-color: #e7fde7;
}
.info {
    background-color: var(--color-bg);
    color: var(--color-txt);
    display: block;
    font: var(--font-medium);
}

    .err a, .success a {
        color: var(--error-color);
        text-decoration: underline;
    }

    .success, .success a {
        color: var(--success-color);
    }

.field {
    margin: 0;
    border: 0;
    padding: 10px 0;
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    position: relative;
    align-content: flex-start;
}

    .field:focus-within > input {
        border-color: var(--border-color-focus);
    }
    /*.field:focus-within > button i {*/
    .field:focus-within > label i {
        color: var(--text-color);
    }

    .field a {
        padding-top: 5px
    }

    .field i {
        color: var(--border-color);
    }

    .field button i {
        color: #fff;
    }

    .field .hint {
        color: #666;
        font-size: 12px;
        padding-top: 5px
    }

        .field .hint a {
            font-size: 12px;
        }

    .field .mono {
        font-family: 'neon', var(--font-family);
    }

        .field .mono::placeholder {
            font-family: 'neon', var(--font-family);
            /*font: var(--font-regular);*/
        }

div.navbar-container {
    position: sticky;
    top: 0;
    z-index: 100;
    border-bottom: 1px solid #ccc;
    box-shadow: 0 0 3px 3px rgba(0,0,0,0.1);
    background-color: #fff;
    padding: 10px 0
}

div.navbar {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0;
    display: flex;
    align-items: center
}

div.content {
    max-width: 1200px;
    /*margin: 0 auto;*/
    margin: 30px auto 0 auto;
    padding: 0;
}

/*div.security {
    flex: 1;
    display: flex;
    place-content: center;
    margin-top: 100px;
}*/

div.sections {
    max-width: 1024px;
    margin: 0 auto;
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
    justify-content: center;
    /*align-items: center;
    /*align-items: flex-start;
    justify-content: flex-start;*/
    /*align-content: center;*/
}

section.security, section.admin, section.landing {
    background-color: #fff;
    border: 0;
    border-radius: 6px;
    width: 375px;
    margin: auto;
    padding: 10px 20px 20px 20px;
    box-sizing: border-box;
    box-shadow: 0 0 3px 3px rgba(0,0,0,0.1);
    outline: 0;
}

section.landing {
    margin:0;
}

div.land10 {
    display: flex;
    flex-wrap: wrap;
}
div.land20 {
    flex: 1;
    margin: 10px 0 3px 0;
    text-align: center;
    font-size: 16px;

    padding: 3px 0;
    background-color: var(--color-bg);
    border-radius: 6px;
}

div.land21 {
    flex: 1;
    text-align: center;
    padding: 10px 0;
}
div.land22 {
    flex: 1;
    text-align: center;
}
div.land25 {
    flex: 1;
    text-align: center;
    font-size: 20px;
    font-weight: 700;
}
div.land30 {
    flex: 1;
    text-align: center;
    font-size: 16px;
    font-weight: 700;
}
div.land35 {
    flex: 1;
    text-align: center;
    font-size: 16px;
}
div.land40 {
    flex: 1;
    text-align: center;
    font-size: 24px;
    font-weight: 700;
}

section.admin {
    /*width: 1024px;*/
    /*width: auto;*/
    /* flex: 1;*/
    display: block;
    flex-direction: column;
    align-content: flex-start;
    align-items: flex-start;
    justify-content: flex-start;
    align-self: flex-start;
    /*margin-top: 0;*/
    margin: 0;
    min-width: 375px;
    flex: 1;

}

section.container {
    background-color: #fff;
    margin: 0;
    border: 0;
    border-radius: 6px;
    box-sizing: border-box;
    box-shadow: 0 0 3px 3px rgba(0,0,0,0.1);
    padding: 20px 20px 10px 20px;
    width: 375px;
    position: relative;
    outline: 0;
}

section.dialog {
    background-color: #fff;
    margin: 0;
    border: 0;
    border-radius: 6px;
    box-sizing: border-box;
    box-shadow: 0 0 3px 3px rgba(0,0,0,0.1);
    padding: 20px 20px 10px 20px;
    width: 375px;
    position: absolute;
    outline: 0;
}

section.loader {
    background-color: #fff;
    margin: 0;
    border: 0;
    border-radius: 6px;
    box-sizing: border-box;
    box-shadow: 0 0 3px 3px rgba(0,0,0,0.1);
    padding: 20px;
    width: 375px;
    height: 375px;
    display: flex;
    justify-content: center;
    align-content: center;
    outline: 0;
}

section.cvmthyear {
    background-color: #fff;
    margin: 0;
    border: 0;
    border-radius: 6px;
    box-sizing: border-box;
    box-shadow: 0 0 3px 3px rgba(0,0,0,0.1);
    outline: 0;
    padding: 20px 20px 10px 20px;
    position: absolute;
    z-index: 1000;
}

#crud {
    background-color: rgba(204,204,204,0.75);
    position: absolute;
    /*display: none;*/
    display: flex;
    justify-content: center;
    align-items: flex-start;
}

#dialog {
    background-color: rgba(204,204,204,0.75);
    position: absolute;
    display: none;
    justify-content: center;
    align-items: flex-start;
}
/*.picker {
    background-color: red;*/ /*rgba(204,204,204,0.75);*/
/*padding-top: 100px;
    position: absolute;
    inset: 0;*/ /* short for top, right, bottom, left */
/*      width: 100vw;*/
/*height: 100%;
    display: flex;*/ /* none;*/
/*justify-content: center;
    align-items: flex-start;
    z-index: 200;
}*/
modal {
    background-color: rgba(204,204,204,0.75);
    position: fixed;
    inset: 0;
    display: flex;
    justify-content: center;
    z-index: 100;
}

.bg-trans {
    background-color: rgba(0, 0, 0, 0);
}
/* mmyypicker start */
#mmyy-container {
    display: flex;
    margin-top: 50px;
    margin-bottom: 10px;
}

#mm, #yy {
    display: flex;
    flex: 1;
    flex-wrap: wrap;
    align-items: stretch;
    flex-direction: column;
    box-sizing: border-box;
}

#yy {
    margin-left: -1px;
}

m, y {
    border: var(--border);
    margin: -1px 0 0 0;
    padding: 3px 0;
    flex: 1;
    text-align: center;
    cursor: pointer;
    user-select: none;
}

    m:hover, y:hover {
        background-color: var(--color-bg);
    }

    m:first-child, y:first-child {
        margin-top: 0;
    }
    /*m.t, y.t {
            border-radius:var(--border-radius) var(--border-radius) 0 0;
        }
        m.b, y.b {
            border-radius:0 0 var(--border-radius) var(--border-radius);
        }*/
    m.tl {
        border-top-left-radius: 6px;
    }

    y.tr {
        border-top-right-radius: 6px;
    }

    m.bl {
        border-bottom-left-radius: 6px;
    }

    y.br {
        border-bottom-right-radius: 6px;
    }

    m.sel, y.sel {
        background-color: var(--primary-blue);
        border-color: var(--primary-blue);
        color: #fff;
        z-index: 1;
    }

    y.dis, y.dis > i {
        color: #ccc;
        cursor: default;
    }

        y.dis:hover {
            background-color: var(--color-bg);
        }
/* mmyypicker finish */
/* CvMultiRange start */
div.cvmultirange {
    background-color: #fff;
    border: var(--border);
    border-radius: 6px;
    outline: none;
    position: absolute;
    display: flex;
    flex-direction: column;
}

    div.cvmultirange:focus-within, div.cvmultirange:hover {
        border-color: var(--border-color-focus);
        outline: var(--primary-blue-outline);
    }

    div.cvmultirange > input.open {
        border-bottom-left-radius: 0;
        border-bottom-right-radius: 0;
        border: 0;
        border-bottom: var(--border);
        -webkit-appearance: none;
        -moz-appearance: none;
        box-sizing: content-box;
        background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' style='fill: rgba(51, 51, 51, 1);transform: ;msFilter:;'%3E%3Cpath d='m6.293 13.293 1.414 1.414L12 10.414l4.293 4.293 1.414-1.414L12 7.586z'%3E%3C/path%3E%3C/svg%3E");
        background-repeat: no-repeat;
        background-position: right 5px center;
        user-select: none;
        outline: 0;
    }

    div.cvmultirange > input.close {
        border: 0;
        -webkit-appearance: none;
        -moz-appearance: none;
        box-sizing: content-box;
        background-image: url('data:image/svg+xml,%3Csvg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" style="fill: rgba(51, 51, 51, 1);transform: ;msFilter:;"%3E%3Cpath d="M16.293 9.293 12 13.586 7.707 9.293l-1.414 1.414L12 16.414l5.707-5.707z"%3E%3C/path%3E%3C/svg%3E');
        background-repeat: no-repeat;
        background-position: right 5px center;
        user-select: none;
        outline: 0;
    }

    div.cvmultirange > opts {
        background-color: transparent;
        border: 0;
        width: 100%;
        margin: auto;
        padding: 0;
        box-sizing: border-box;
        overflow-y: scroll;
        display: flex;
        flex-direction: column;
        outline: none;
        user-select: none;
        font-size: 16px;
    }

        /*    div.cvmultirange > opts > o {
        border: 0;
        background-color: transparent;
        display: flex;
        align-items: center;
    }

        div.cvmultirange > opts > o.sel::before {
            margin-left: -5px;
            margin-right: 5px;
            content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='21.7' height='21.7' viewBox='0 0 21.7 21.7' style='fill: rgba(51, 51, 51, 1);transform: ;msFilter:;'%3E%3Cpath d='m10 15.586-3.293-3.293-1.414 1.414L10 18.414l9.707-9.707-1.414-1.414z'%3E%3C/path%3E%3C/svg%3E");
        }

        div.cvmultirange > opts > o.hov {
            background-color: var(--primary-blue);
            color: #fff;
        }

            div.cvmultirange > opts > o.hov.sel::before {
                content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='21.7' height='21.7' viewBox='0 0 21.7 21.7' style='fill: rgba(255, 255, 255, 1);transform: ;msFilter:;'%3E%3Cpath d='m10 15.586-3.293-3.293-1.414 1.414L10 18.414l9.707-9.707-1.414-1.414z'%3E%3C/path%3E%3C/svg%3E");
            }

        div.cvmultirange > opts > o.dis {
            background-color: var(--color-bg);
            color: #ccc;
        }

        div.cvmultirange > opts > o:last-child {
            border-bottom-left-radius: 4px;
            border-bottom-right-radius: 4px;
        }*/

        div.cvmultirange > opts > div.noopts {
            color: var(--placeholder-color);
        }
/* CvMultiRange start */
/* CvSelect start */
div.cvselect {
    background-color: #fff;
    border: var(--border);
    border-radius: 6px;
    outline: none;
    /*z-index: 1;*/
    position: absolute;
    display: flex;
    flex-direction: column;
}

    div.cvselect:focus-within, div.cvselect:hover {
        border-color: var(--border-color-focus);
        outline: var(--primary-blue-outline);
    }

    div.cvselect > input.open {
        border-bottom-left-radius: 0;
        border-bottom-right-radius: 0;
        border: 0;
        border-bottom: var(--border);
        -webkit-appearance: none;
        -moz-appearance: none;
        box-sizing: content-box;
        background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' style='fill: rgba(51, 51, 51, 1);transform: ;msFilter:;'%3E%3Cpath d='m6.293 13.293 1.414 1.414L12 10.414l4.293 4.293 1.414-1.414L12 7.586z'%3E%3C/path%3E%3C/svg%3E");
        background-repeat: no-repeat;
        background-position: right 5px center;
        user-select: none;
        outline: 0;
    }

    div.cvselect > input.close {
        border: 0;
        -webkit-appearance: none;
        -moz-appearance: none;
        box-sizing: content-box;
        background-image: url('data:image/svg+xml,%3Csvg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" style="fill: rgba(51, 51, 51, 1);transform: ;msFilter:;"%3E%3Cpath d="M16.293 9.293 12 13.586 7.707 9.293l-1.414 1.414L12 16.414l5.707-5.707z"%3E%3C/path%3E%3C/svg%3E');
        background-repeat: no-repeat;
        background-position: right 5px center;
        user-select: none;
        outline: 0;
    }

    div.cvselect > opts {
        background-color: transparent;
        border: 0;
        width: 100%;
        margin: auto;
        padding: 0;
        box-sizing: border-box;
        overflow-y: scroll;
        display: flex;
        flex-direction: column;
        outline: none;
        user-select: none;
        font-size: 16px;
    }

        div.cvselect > opts > o {
            border: 0;
            background-color: transparent;
            display: flex;
            align-items: center;
        }

            div.cvselect > opts > o.sel::before {
                margin-left: -5px;
                margin-right: 5px;
                content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='21.7' height='21.7' viewBox='0 0 21.7 21.7' style='fill: rgba(51, 51, 51, 1);transform: ;msFilter:;'%3E%3Cpath d='m10 15.586-3.293-3.293-1.414 1.414L10 18.414l9.707-9.707-1.414-1.414z'%3E%3C/path%3E%3C/svg%3E");
            }

            div.cvselect > opts > o.hov {
                background-color: var(--primary-blue);
                color: #fff;
            }

                div.cvselect > opts > o.hov.sel::before {
                    content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='21.7' height='21.7' viewBox='0 0 21.7 21.7' style='fill: rgba(255, 255, 255, 1);transform: ;msFilter:;'%3E%3Cpath d='m10 15.586-3.293-3.293-1.414 1.414L10 18.414l9.707-9.707-1.414-1.414z'%3E%3C/path%3E%3C/svg%3E");
                }

            div.cvselect > opts > o.dis {
                background-color: var(--color-bg);
                color: #ccc;
            }

            div.cvselect > opts > o:last-child {
                border-bottom-left-radius: 4px;
                border-bottom-right-radius: 4px;
            }

        div.cvselect > opts > div.noopts {
            color: var(--placeholder-color);
        }
/* CvSelect finish */
/*https://developer.mozilla.org/en-US/docs/Web/CSS/animation */
.cv-rotate {
    color: var(--primary-blue);
    font-weight: 600;
    margin: auto;
    animation: rotation 1s infinite linear;
    outline: 0;
}

@keyframes rotation {
    from {
        transform: rotate(0deg);
    }

    to {
        transform: rotate(359deg);
    }
}

i.cv {
    padding: 5px;
    border-radius: var(--border-radius);
    background-color: var(--color-bg);
    cursor: pointer;
    outline: none;
}

    i.cv:hover {
        background-color: #ccc;
    }

i.cv-tl, i.cv-tr {
    display: block;
    position: absolute;
    top: 20px;
}

i.cv-tr {
    right: 20px;
}

div .cv-position {
    display: flex;
    margin-bottom: 20px
}

    div.cv-position div:first-child {
        flex: 1
    }
#table {
    margin-top:20px;
    display: flex;
/*    width: 984px;
    height: 492px;*/
    overflow: scroll
}
table {
    border: 0;
    border-collapse: collapse;
    font-size: 12px;
    margin: 0;
    padding: 0;
    table-layout: fixed;
}

th, td {
    border: 0 solid #ccc;
    border-width: 1px;
    margin: 0;
    padding: 5px;
    text-align: left
}

th {
    background-color: #eee
}

#header-10 {
    position: sticky;
    top: 0;
    z-index: 100;
    box-shadow: 0 0 3px 3px rgba(0,0,0,0.1);
    background-color: rgba(247, 247, 247, 0.9);
}

#header-20 {
    max-width: 1024px;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
}

#header-30 {
    display: flex;
    place-content: space-between;
    align-items: center;
    gap: 20px 0;
    /*padding: 10px;*/
}

.header-icons-10 {
    flex: 1;
    display: flex;
    column-gap: 20px;
    padding: 10px;
}
    .header-icons-10 > a, .header-icons-10 > i {
        color: var(--color-txt);
        cursor: pointer;
    }
#menu {
    padding: 0 10px;
    position: fixed;
    background-color: rgba(247, 247, 247, 0.9);
    z-index: 99;
    width: 100%;
}
.menu-10 {
    max-width: 1024px;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
}
.menu-20 {
    border-bottom: 1px solid #ccc;
    display: flex;
    justify-content: right;
}
    .menu-10:first-of-type {
        /*border-top: 1px solid #ccc;*/
    }.menu-10:last-of-type {
    /*border-bottom: 0;*/
}
    .menu-20 > a {
        width: 200px;
        display: flex;
        align-items: center;
        font-size: 20px;
        font-weight: 700;
        color: var(--txt-color);
        padding: 10px 0 10px 10px;
    }
        .menu-20 > a:hover, .menu-20 > a:focus {
            text-decoration: none;
        }
        .menu-20 > a > i {
        margin-right: 10px;
    }

.contact {
    display: flex;
    justify-content: center;
}
    .contact > a {
        display: flex;
        align-items: center;
        font-size: 20px;
        font-weight: 700;
        color: var(--txt-color);
        padding: 10px;
    }

        .contact > a:hover, .contact > a:focus {
            text-decoration: none;
        }

        .contact > a > i {
            margin-right: 10px;
        }
pre.address {
    font: var(--font-medium);
}
