@import url('https://fonts.googleapis.com/css2?family=Quicksand:wght@300&family=Roboto:wght@300&display=swap');

/* -- Base -- */
*:not(ul) {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
    outline: 0;
    vertical-align: baseline;
}
html, body {
    min-height: 100%;
}
body, p, input, textarea, select {
    font-family: 'Quicksand', sans-serif;
}
h1, h2, h3, h4, h5, h6 {
    font-family: 'Roboto', sans-serif;
}
a.ul:hover {
    text-decoration: underline;
}
a {
    text-decoration: none;
}
a img {
    border: none;
}
a:link {
    color: var(--link);
}
a:visited {
    color: var(--link-visited);
}
a:hover {
    color: var(--link-hover);
}

/* -- Header -- */
.header {
    box-sizing: border-box;
    position: sticky;
    top: var(--header-top);
    z-index: 100;
    width: 100%;
    height: var(--header-height);
    background-color: var(--header);
}
.header header {
    padding: 5px;
}
.header .header-line {
    display: inline-block;
    vertical-align: top;
}
.header .header-logo img {
    max-height: 46px;
}
.header .header-navs {
    padding-left: 20px;
}
.header .header-navs .navs-item {
    display: inline-block;
    margin: 8px;
    padding: 5px;
    font-size: 1.25rem;
    color: var(--navs);
    cursor: pointer;
}
.header .header-buns {
    float: left;
    padding: 8px 15px 0 5px;
    cursor: pointer;
}
.header .burger-hide {
    display: none !important;
}
.header .header-drop {
    display: inline-block;
    margin-top: -5px;
    background-color: rgba(0,0,0,0.6);
}
.header .header-drop .navs-item {
    display: block;
    padding: 10px 18px;
    min-width: 100px;
    border-top: 1px solid #aaa;
    font-size: 1.25rem;
    color: #fff;
}
.header .header-drop .navs-item:hover {
    background-color: rgba(245,228,82,0.8);
}
.header .header-search {
    float: right;
    padding-top: 8px;
    padding-right: 10px;
}
.header .header-search img, .header .header-buns img {
    width: 28px;
}

/* -- Content -- */
.content {
    box-sizing: border-box;
    position: relative;
    margin-bottom: var(--footer-height);
}

/* -- footer -- */
.footer {
    box-sizing: border-box;
    position: fixed;
    bottom: 0;
    width: 100%;
    height: var(--footer-height);
    background-color: #fff;
    text-align: center;
}

/* -- Forms -- */
form fieldset {
    margin: 15px 0;
    padding: 5px;
}
form label {
    font-size: 1.15rem;
    color: #444;
}
form input[type=text],
form input[type=email],
form input[type=password],
form input[type=date],
form input[type=number],
form input[type=url],
form input[type=tel],
form select {
    box-sizing: border-box;
    padding: 3px;
    border: 0;
    border-bottom: 1px solid #999;
    line-height: 1.5;
    font-size: 1.15rem;
}
@media screen and (orientation: portrait){
    form input[type=text],
    form input[type=email],
    form input[type=password],
    form input[type=date],
    form input[type=number],
    form input[type=url],
    form input[type=tel],
    form select {
        margin-bottom: 5px;
        width: 100%;
    }
}
form label.req:after {
    vertical-align: text-top;
    color: red;
    content: " *";
}

/* -- buttons -- */
.bttn {
    display: inline-block;
    padding: 8px 18px;
    border-radius: 15px;
    background-color: var(--bttn);
    color: var(--bttn-word);
    cursor: pointer;
}
.bttn:hover {
    background-color: var(--bttn-hov);
    color: var(--bttn-hov-word);
}
.button {
    display: inline-block;
    padding: 8px 18px;
    border-radius: 15px;
    background-color: var(--bttn);
    color: var(--bttn-word);
    cursor: pointer;
}
.button:hover {
    background-color: var(--bttn-hov);
    color: var(--bttn-hov-word);
}

/* -- All -- */
.hidden {
    display: none !important;
}
.missing {
    background-color: var(--missing-back);
    border: 1px solid;
    border-color: var(--missing-wall);
}
.notification {
    background-color: var(--notification);
    color: #222;
}
@media screen and (orientation: landscape){
    .site-mobile {
        display: none !important;
    }
}
@media screen and (orientation: portrait){
    .site-desktop {
        display: none !important;
    }
}