.navigation {
    display: contents;
    font-size: 2.5rem;
    left: 0;
    line-height: 1;
    position: fixed;
    top: 0;
    -webkit-transition: background-color 0.3s;
    transition: background-color 0.3s;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    z-index: 10;
}

.navigation--no-logo {
    width: 100%;
}

.navigation:before {
    background-color: #fff;
    content: "";
    display: block;
    height: calc(1em + 1.68rem);
    opacity: 0;
    padding-right: 17.2rem;
    pointer-events: none;
    position: fixed;
    -webkit-transition: opacity 0.3s;
    transition: opacity 0.3s;
    width: 100%;
    z-index: 8;
}

.navigation--dark:before {
    opacity: 1;
}

.navigation__toggle {
    -webkit-box-sizing: content-box;
    -moz-box-sizing: content-box;
    box-sizing: content-box;
    cursor: pointer;
    height: 1em;
    padding: 0.84rem 1.2rem;
    position: fixed;
    width: 1em;
    z-index: 10000000;
    -webkit-box-flex: 0;
    -webkit-flex: 0 0 auto;
    -moz-box-flex: 0;
    -ms-flex: 0 0 auto;
    flex: 0 0 auto;
}

.navigation__toggle>* {
    color: #fff;
    height: 100%;
    position: relative;
    z-index: 10;
}

.navigation--dark .navigation__toggle>*,
.navigation--open .navigation__toggle>* {
    color: #000;
}

.navigation__sections {
    -webkit-box-flex: 1;
    -webkit-flex: 1 1 auto;
    -moz-box-flex: 1;
    -ms-flex: 1 1 auto;
    flex: 1 1 auto;
    opacity: 0;
    pointer-events: none;
}

.navigation__content {
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    pointer-events: none;
    position: fixed;
    z-index: 101;
    -webkit-box-pack: end;
    -webkit-justify-content: flex-end;
    -moz-box-pack: end;
    -ms-flex-pack: end;
    color: #fff;
    height: 100%;
    justify-content: flex-end;
    left: 0;
    padding: 0.84rem 17.2rem 0.84rem calc(1em + 3.6rem);
    top: 0;
    -webkit-transition: background-color 0.3s;
    transition: background-color 0.3s;
    width: 100%;
}

.navigation--open .navigation__content {
    background-color: #fff;
    z-index: 100000;
}

.navigation--open .navigation__sections {
    opacity: 1;
    pointer-events: auto;
}

.navigation--dark .navigation__content,
.navigation--open .navigation__content {
    color: #000;
}

.navigation__content .sub-menu {
    padding-left: 1.2rem;
    display: none;
}

.navigation__content .sub-menu a {
    color: #d3d3d3;
}

.navigation--open .navigation__content .small {
    font-size: 1.7rem;
}

.navigation--open .navigation__content .separator {
    margin-top: .5em;
    pointer-events: none;
    opacity: 0;
    visibility: hidden;
}

.navigation--open .navigation__content .separator a {
    display: none;
}

.navigation__anchors {
    height: 1em;
    padding-right: 1em;
    pointer-events: auto;
    width: 50%;
    -webkit-box-flex: 1;
    -webkit-flex: 1 1 auto;
    -moz-box-flex: 1;
    -ms-flex: 1 1 auto;
    flex: 1 1 auto;
    -webkit-box-pack: end;
    -webkit-justify-content: flex-end;
    -moz-box-pack: end;
    -ms-flex-pack: end;
    display: none;
    justify-content: flex-end;
}

.navigation--dark .navigation__anchors {
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
}

.navigation--open .navigation__anchors {
    display: none;
}

.navigation__anchor {
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    font-size: 1.35rem;
    white-space: nowrap;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -moz-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    max-width: 10em;
    overflow: hidden;
    -webkit-transition: max-width 0.3s;
    transition: max-width 0.3s;
}

.navigation__anchor a {
    display: block;
    overflow: hidden;
    text-overflow: ellipsis;
    width: 100%;
}

.navigation__anchor:hover {
    color: #d3d3d3;
    max-width: 20em;
}

.navigation__anchor+.navigation__anchor {
    margin-left: 1em;
}

.navigation__languages {
    color: #fff;
    display: none;
    height: 1em;
    pointer-events: auto;
    position: relative;
    z-index: 1000;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -moz-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}

.navigation--open .navigation__languages {
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
}

.navigation--dark .navigation__languages,
.navigation--open .navigation__languages {
    color: #000;
}

.navigation__language {
    font-size: 1.35rem;
}

.navigation__language+.navigation__language {
    margin-left: 0.5em;
}

.navigation__options {
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    height: 1em;
    pointer-events: auto;
}

.navigation--open .navigation__options {
    display: none;
}

.navigation--dark .navigation__options {
    -webkit-filter: invert(1);
    filter: invert(1);
}

.navigation__options img {
    height: 100%;
    width: 1.5rem;
}

.navigation__icon {
    cursor: pointer;
}

.navigation__icon+.navigation__icon {
    margin-left: 1rem;
}

.navigation__search {
    position: relative;
}

.search {
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
}

.search input {
    background-color: rgba(0, 0, 0, 0);
    border: none;
    border-bottom: 1px solid;
    -webkit-filter: invert(1);
    filter: invert(1);
    font-family: inherit;
    font-size: 1.5rem;
    height: 2rem;
    outline: none;
    overflow: hidden;
    padding: 0;
    -webkit-transition: width 0.3s ease-in-out, margin 0.3s ease-in-out;
    transition: width 0.3s ease-in-out, margin 0.3s ease-in-out;
    width: 0;
}

.search--active input {
    margin-left: 1rem;
    width: 18rem;
}

.search :-ms-input-placeholder {
    color: red;
    opacity: 1;
}

.search ::-ms-input-placeholder {
    color: red;
    opacity: 1;
}

.search :-ms-input-placeholder,
.search ::-ms-input-placeholder,
.search ::placeholder {
    color: red;
    opacity: 1;
}

.search img {
    -webkit-filter: invert(1);
    filter: invert(1);
}

.navigation__search-button {
    height: 100%;
}

.navigation__search-results {
    position: absolute;
    right: 0;
    width: 18rem;
    font-size: 1.5rem;
    z-index: 100;
    background-color: #fff;
    color: #000;
}

.hidden {
    display: none !important;
}

.navigation__search-results li {
    border-bottom: 1px solid;
    margin: 0;
    padding: 0.5rem;
    white-space: nowrap;
    width: 100%;
    color: #000;
}

.navigation__search-results li a {
    display: block;
    color: inherit;
    text-overflow: ellipsis;
    overflow: hidden;
}

.navigation__search-results li:hover {
    color: #fff;
    background-color: #000;
}

.navigation__search-result {
    display: block;
    width: 100%;
    word-wrap: none;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}