﻿@-webkit-keyframes mainmenu-bg-fade {
    from {
        opacity: 0;
        right: 40px;
    }

    to {
        opacity: 1;
        right: 75px;
    }
}

@keyframes mainmenu-bg-fade {
    from {
        opacity: 0;
        right: 40px;
    }

    to {
        opacity: 1;
        right: 75px;
    }
}

@-webkit-keyframes popup-slide-in {
    from {
        transform: translateY(50px);
        opacity: 0;
    }

    to {
        transform: translateY(0);
        opacity: 1;
    }
}

@keyframes popup-slide-in {
    from {
        transform: translateY(50px);
        opacity: 0;
    }

    to {
        transform: translateY(0);
        opacity: 1;
    }
}

html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
b,
u,
i,
center,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
embed,
figure,
figcaption,
footer,
header,
hgroup,
menu,
nav,
output,
ruby,
section,
summary,
time,
mark,
audio,
video {
    margin: 0;
    padding: 0;
    border: 0;
    font-size: 100%;
    font: inherit;
    vertical-align: baseline;

}



article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
    display: block;
}

body {
    line-height: 1;
}

blockquote,
q {
    quotes: none;
}

    blockquote:before,
    blockquote:after,
    q:before,
    q:after {
        content: "";
        content: none;
    }

table {
    border-collapse: collapse;
    border-spacing: 0;
}

::-moz-selection {
    background: rgba(86, 217, 205, 0.99);
    color: #fff;
}

::selection {
    background: rgba(86, 217, 205, 0.99);
    color: #fff;
}

::-moz-selection {
    background: #56d9cd;
    color: #fff;
}

* {
    box-sizing: border-box;
}

html,
body {
    margin: 0;
    padding: 0;
    height: 100%;
}

body {
    background: #fafafa;
}

ul {
    list-style: disc;
}

ol {
    list-style: decimal;
}

a {
    color: inherit;
    text-decoration: none;
    transition: 0.3s;
}

img {
    max-width: 100%;
    height: auto;
    vertical-align: bottom;
}

@font-face {
    font-family: "Poppins";
    font-style: normal;
    font-weight: 300;
    src: url("../fonts/poppins-v15-latin-300.eot");
    src: local(""), url("../fonts/poppins-v15-latin-300.eot?#iefix") format("embedded-opentype"), url("../fonts/poppins-v15-latin-300.woff2") format("woff2"), url("../fonts/poppins-v15-latin-300.woff") format("woff"), url("../fonts/poppins-v15-latin-300.ttf") format("truetype"), url("../fonts/poppins-v15-latin-300.svg#Poppins") format("svg");
}

@font-face {
    font-family: "Poppins";
    font-style: italic;
    font-weight: 300;
    src: url("../fonts/poppins-v15-latin-300italic.eot");
    src: local(""), url("../fonts/poppins-v15-latin-300italic.eot?#iefix") format("embedded-opentype"), url("../fonts/poppins-v15-latin-300italic.woff2") format("woff2"), url("../fonts/poppins-v15-latin-300italic.woff") format("woff"), url("../fonts/poppins-v15-latin-300italic.ttf") format("truetype"), url("../fonts/poppins-v15-latin-300italic.svg#Poppins") format("svg");
}

@font-face {
    font-family: "Poppins";
    font-style: normal;
    font-weight: 400;
    src: url("../fonts/poppins-v15-latin-regular.eot");
    src: local(""), url("../fonts/poppins-v15-latin-regular.eot?#iefix") format("embedded-opentype"), url("../fonts/poppins-v15-latin-regular.woff2") format("woff2"), url("../fonts/poppins-v15-latin-regular.woff") format("woff"), url("../fonts/poppins-v15-latin-regular.ttf") format("truetype"), url("../fonts/poppins-v15-latin-regular.svg#Poppins") format("svg");
}

@font-face {
    font-family: "Poppins";
    font-style: italic;
    font-weight: 400;
    src: url("../fonts/poppins-v15-latin-italic.eot");
    src: local(""), url("../fonts/poppins-v15-latin-italic.eot?#iefix") format("embedded-opentype"), url("../fonts/poppins-v15-latin-italic.woff2") format("woff2"), url("../fonts/poppins-v15-latin-italic.woff") format("woff"), url("../fonts/poppins-v15-latin-italic.ttf") format("truetype"), url("../fonts/poppins-v15-latin-italic.svg#Poppins") format("svg");
}

@font-face {
    font-family: "Poppins";
    font-style: normal;
    font-weight: 500;
    src: url("../fonts/poppins-v15-latin-500.eot");
    src: local(""), url("../fonts/poppins-v15-latin-500.eot?#iefix") format("embedded-opentype"), url("../fonts/poppins-v15-latin-500.woff2") format("woff2"), url("../fonts/poppins-v15-latin-500.woff") format("woff"), url("../fonts/poppins-v15-latin-500.ttf") format("truetype"), url("../fonts/poppins-v15-latin-500.svg#Poppins") format("svg");
}

@font-face {
    font-family: "Poppins";
    font-style: italic;
    font-weight: 500;
    src: url("../fonts/poppins-v15-latin-500italic.eot");
    src: local(""), url("../fonts/poppins-v15-latin-500italic.eot?#iefix") format("embedded-opentype"), url("../fonts/poppins-v15-latin-500italic.woff2") format("woff2"), url("../fonts/poppins-v15-latin-500italic.woff") format("woff"), url("../fonts/poppins-v15-latin-500italic.ttf") format("truetype"), url("../fonts/poppins-v15-latin-500italic.svg#Poppins") format("svg");
}

@font-face {
    font-family: "Poppins";
    font-style: normal;
    font-weight: 600;
    src: url("../fonts/poppins-v15-latin-600.eot");
    src: local(""), url("../fonts/poppins-v15-latin-600.eot?#iefix") format("embedded-opentype"), url("../fonts/poppins-v15-latin-600.woff2") format("woff2"), url("../fonts/poppins-v15-latin-600.woff") format("woff"), url("../fonts/poppins-v15-latin-600.ttf") format("truetype"), url("../fonts/poppins-v15-latin-600.svg#Poppins") format("svg");
}

@font-face {
    font-family: "Poppins";
    font-style: italic;
    font-weight: 600;
    src: url("../fonts/poppins-v15-latin-600italic.eot");
    src: local(""), url("../fonts/poppins-v15-latin-600italic.eot?#iefix") format("embedded-opentype"), url("../fonts/poppins-v15-latin-600italic.woff2") format("woff2"), url("../fonts/poppins-v15-latin-600italic.woff") format("woff"), url("../fonts/poppins-v15-latin-600italic.ttf") format("truetype"), url("../fonts/poppins-v15-latin-600italic.svg#Poppins") format("svg");
}

@font-face {
    font-family: "Poppins";
    font-style: normal;
    font-weight: 700;
    src: url("../fonts/poppins-v15-latin-700.eot");
    src: local(""), url("../fonts/poppins-v15-latin-700.eot?#iefix") format("embedded-opentype"), url("../fonts/poppins-v15-latin-700.woff2") format("woff2"), url("../fonts/poppins-v15-latin-700.woff") format("woff"), url("../fonts/poppins-v15-latin-700.ttf") format("truetype"), url("../fonts/poppins-v15-latin-700.svg#Poppins") format("svg");
}

@font-face {
    font-family: "Poppins";
    font-style: italic;
    font-weight: 700;
    src: url("../fonts/poppins-v15-latin-700italic.eot");
    src: local(""), url("../fonts/poppins-v15-latin-700italic.eot?#iefix") format("embedded-opentype"), url("../fonts/poppins-v15-latin-700italic.woff2") format("woff2"), url("../fonts/poppins-v15-latin-700italic.woff") format("woff"), url("../fonts/poppins-v15-latin-700italic.ttf") format("truetype"), url("../fonts/poppins-v15-latin-700italic.svg#Poppins") format("svg");
}

@font-face {
    font-family: "Poppins";
    font-style: normal;
    font-weight: 800;
    src: url("../fonts/poppins-v15-latin-800.eot");
    src: local(""), url("../fonts/poppins-v15-latin-800.eot?#iefix") format("embedded-opentype"), url("../fonts/poppins-v15-latin-800.woff2") format("woff2"), url("../fonts/poppins-v15-latin-800.woff") format("woff"), url("../fonts/poppins-v15-latin-800.ttf") format("truetype"), url("../fonts/poppins-v15-latin-800.svg#Poppins") format("svg");
}

@font-face {
    font-family: "Poppins";
    font-style: italic;
    font-weight: 800;
    src: url("../fonts/poppins-v15-latin-800italic.eot");
    src: local(""), url("../fonts/poppins-v15-latin-800italic.eot?#iefix") format("embedded-opentype"), url("../fonts/poppins-v15-latin-800italic.woff2") format("woff2"), url("../fonts/poppins-v15-latin-800italic.woff") format("woff"), url("../fonts/poppins-v15-latin-800italic.ttf") format("truetype"), url("../fonts/poppins-v15-latin-800italic.svg#Poppins") format("svg");
}

html {
    font-size: 10px;
}

body {
    font-family: "Poppins", "Arial", sans-serif;
    -webkit-font-smoothing: antialiased;

    line-height: 2.6rem;
    font-style: normal;
    font-weight: 400;
    color: #013146;
}

strong {
    font-weight: 700;
}

em {
    font-style: italic;
}

h1,
h2,
h3,
h4,
h5,
h6 {
    color: #013146;
    margin-bottom: 4rem;
}

.form h1,
.form h2,
.form h3,
.form h4,
.form h5,
.form h6 {
    margin-bottom: 3rem;
}

h1.mb0,
h2.mb0,
h3.mb0,
h4.mb0,
h5.mb0,
h6.mb0 {
    margin-bottom: 0;
}

p {
    margin-bottom: 3.5rem;
}

    p a:not(.button) {
        font-weight: 600;
        color: #013146;
        text-decoration: underline;
    }

        p a:not(.button):hover {
            color: #56d9cd;
        }

.headline-white-box,
.formular .form form > h2 {
    display: table;
    border-radius: 16px;
    background: #fff;
    padding: 6px 16px;
}

.headline-ultra {
    font-size: 12rem;
    line-height: 13rem;
    font-weight: 800;
}

@media (max-width: 580px) {
    .headline-ultra {
        font-size: 5.5rem;
        line-height: 6.5rem;
    }
}

h1,
.headline-1 {
    font-size: 7.2rem;
    line-height: 8rem;
    font-weight: 800;
}

@media (max-width: 580px) {
    h1,
    .headline-1 {
        font-size: 4rem;
        line-height: 5rem;
    }
}

h2,
.headline-2 {
    font-size: 4.8rem;
    line-height: 6rem;
    font-weight: 800;
}

@media (max-width: 580px) {
    h2,
    .headline-2 {
        font-size: 3rem;
        line-height: 4rem;
    }
}

h3,
.headline-3 {
    font-size: 3rem;
    line-height: 3.6rem;
    font-weight: 800;
}

@media (max-width: 580px) {
    h3,
    .headline-3 {
        font-size: 2.5rem;
        line-height: 3.3rem;
    }
}

h4,
.headline-4 {
    font-size: 3rem;
    line-height: 3.6rem;
    font-weight: 300;
}

@media (max-width: 580px) {
    h4,
    .headline-4 {
        font-size: 2.5rem;
        line-height: 3.3rem;
    }
}

h5,
.headline-5 {
    font-size: 1.8rem;
    line-height: 2.5rem;
    font-weight: 700;
}

@media (max-width: 580px) {
    h5,
    .headline-5 {
        font-size: 1.6rem;
        line-height: 2.4rem;
    }
}

h6,
.headline-6 {
    font-size: 1.4rem;
    line-height: 2.1rem;
    font-weight: 700;
}

@media (max-width: 580px) {
    h6,
    .headline-6 {
        font-size: 1.2rem;
        line-height: 1.8rem;
    }
}

@media (max-width: 580px) {
    h1.headline-mobile {
        font-size: 3rem !important;
        line-height: 4rem !important;
    }
}

.text-large {
    font-size: 2.2rem;
    line-height: 3.4rem;
}

@media (max-width: 580px) {
    .text-large {
        font-size: 1.8rem;
        line-height: 3rem;
    }
}

.text-standard {
    font-size: 1.6rem;
    line-height: 2.6rem;
}

@media (max-width: 580px) {
    .text-standard {
        font-size: 1.5rem;
        line-height: 2.4rem;
    }
}

.text-small {
    font-size: 1.1rem;
    line-height: 2.2rem;
    font-weight: 500;
}

@media (max-width: 580px) {
    .text-small {
        font-weight: 600;
        font-size: 1.1rem;
        line-height: 2rem;
    }
}

.underlined {
    text-decoration: underline;
}

.uppercased {
    text-transform: uppercase;
}

.fw-300 {
    font-weight: 300;
}

.fw-400 {
    font-weight: 400;
}

.fw-600 {
    font-weight: 600;
}

.fw-700 {
    font-weight: 700;
}

#toggle-mainmenu {
    position: absolute;
    left: -9999px;
}

    #toggle-mainmenu:checked + .mainmenu {
        opacity: 1;
        visibility: visible;
    }

.mainmenu {
    transition: 0.2s;
    opacity: 0;
    visibility: hidden;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 90;
    background: #013146;
    color: #fff;
    overflow: hidden;
}

    .mainmenu::before {
        content: "";
        position: absolute;
        left: 0;
        right: 0;
        height: 200px;
        pointer-events: none;
        background: linear-gradient(to bottom, #013146, rgba(1, 49, 70, 0));
    }

@media (max-width: 580px) {
    .mainmenu::before {
        height: 100px;
    }
}

.mainmenu .container {
    display: flex;
    flex-flow: column;
    justify-content: space-between;
    height: 100%;
    padding-left: 50px;
    padding-right: 50px;
    overflow-y: auto;
}

@media (max-width: 580px) {
    .mainmenu .container {
        padding-left: 20px;
        padding-right: 20px;
    }
}

.mainmenu__nav {
    padding-top: 180px;
}

@media (max-width: 580px) {
    .mainmenu__nav {
        padding-top: 120px;
    }
}

.mainmenu__nav ul {
    margin: 0;
    list-style: none;
}

    .mainmenu__nav ul li {
        margin-bottom: 1.6rem;
    }

        .mainmenu__nav ul li a {
            font-size: 4.8rem;
            line-height: 6rem;
            font-weight: 800;
            color: #fff;
            text-decoration: none;
            transition: 0.3s;
        }

@media (max-width: 580px) {
    .mainmenu__nav ul li a {
        font-size: 3rem;
        line-height: 4rem;
    }
}

.mainmenu__nav ul li a:hover,
.mainmenu__nav ul li a.active {
    color: #56d9cd;
}

.mainmenu__meta {
    padding: 40px 0;
    margin-top: auto;
   /* opacity: 0.3;*/
}

@media (max-width: 580px) {
    .mainmenu__meta {
        padding: 40px 0 20px;
    }
}

.mainmenu__logo-bg {
    background: url(../images/olav-bg.svg) no-repeat center right;
    background-size: contain;
    position: absolute;
    z-index: 91;
    pointer-events: none;
    top: -40px;
    bottom: -80px;
    right: 40px;
    width: 100%;
    opacity: 0;
    overflow: hidden;
}

.mainmenu-visible .mainmenu__logo-bg {
    -webkit-animation: mainmenu-bg-fade 1.2s 0.1s forwards ease;
    animation: mainmenu-bg-fade 1.2s 0.1s forwards ease;
}

@media (max-width: 767px) {
    .mainmenu__logo-bg {
        display: none;
    }
}

.container {
    padding-right: 80px;
    padding-left: 80px;
    margin-right: auto;
    margin-left: auto;
}

@media (max-width: 992px) {
    .container {
        padding-right: 40px;
        padding-left: 40px;
    }
}

@media (max-width: 580px) {
    .container {
        padding-right: 20px;
        padding-left: 20px;
    }
}

.row {
    margin-right: -80px;
    margin-left: -80px;
}

@media (max-width: 992px) {
    .row {
        margin-right: -40px;
        margin-left: -40px;
    }
}

@media (max-width: 580px) {
    .row {
        margin-right: -20px;
        margin-left: -20px;
    }
}

.row-no-gutters {
    margin-right: 0;
    margin-left: 0;
}

    .row-no-gutters[class*="col-"] {
        padding-right: 0;
        padding-left: 0;
    }

.col-xs-1,
.col-sm-1,
.col-md-1,
.col-lg-1,
.col-xs-2,
.col-sm-2,
.col-md-2,
.col-lg-2,
.col-xs-3,
.col-sm-3,
.col-md-3,
.col-lg-3,
.col-xs-4,
.col-sm-4,
.col-md-4,
.col-lg-4,
.col-xs-5,
.col-sm-5,
.col-md-5,
.col-lg-5,
.col-xs-6,
.col-sm-6,
.col-md-6,
.col-lg-6,
.col-xs-7,
.col-sm-7,
.col-md-7,
.col-lg-7,
.col-xs-8,
.col-sm-8,
.col-md-8,
.col-lg-8,
.col-xs-9,
.col-sm-9,
.col-md-9,
.col-lg-9,
.col-xs-10,
.col-sm-10,
.col-md-10,
.col-lg-10,
.col-xs-11,
.col-sm-11,
.col-md-11,
.col-lg-11,
.col-xs-12,
.col-sm-12,
.col-md-12,
.col-lg-12 {
    position: relative;
    min-height: 1px;
    padding-right: 80px;
    padding-left: 80px;
    padding-bottom: 80px;
}

@media (max-width: 992px) {
    .col-xs-1,
    .col-sm-1,
    .col-md-1,
    .col-lg-1,
    .col-xs-2,
    .col-sm-2,
    .col-md-2,
    .col-lg-2,
    .col-xs-3,
    .col-sm-3,
    .col-md-3,
    .col-lg-3,
    .col-xs-4,
    .col-sm-4,
    .col-md-4,
    .col-lg-4,
    .col-xs-5,
    .col-sm-5,
    .col-md-5,
    .col-lg-5,
    .col-xs-6,
    .col-sm-6,
    .col-md-6,
    .col-lg-6,
    .col-xs-7,
    .col-sm-7,
    .col-md-7,
    .col-lg-7,
    .col-xs-8,
    .col-sm-8,
    .col-md-8,
    .col-lg-8,
    .col-xs-9,
    .col-sm-9,
    .col-md-9,
    .col-lg-9,
    .col-xs-10,
    .col-sm-10,
    .col-md-10,
    .col-lg-10,
    .col-xs-11,
    .col-sm-11,
    .col-md-11,
    .col-lg-11,
    .col-xs-12,
    .col-sm-12,
    .col-md-12,
    .col-lg-12 {
        padding-right: 40px;
        padding-left: 40px;
        padding-bottom: 40px;
    }
}

@media (max-width: 580px) {
    .col-xs-1,
    .col-sm-1,
    .col-md-1,
    .col-lg-1,
    .col-xs-2,
    .col-sm-2,
    .col-md-2,
    .col-lg-2,
    .col-xs-3,
    .col-sm-3,
    .col-md-3,
    .col-lg-3,
    .col-xs-4,
    .col-sm-4,
    .col-md-4,
    .col-lg-4,
    .col-xs-5,
    .col-sm-5,
    .col-md-5,
    .col-lg-5,
    .col-xs-6,
    .col-sm-6,
    .col-md-6,
    .col-lg-6,
    .col-xs-7,
    .col-sm-7,
    .col-md-7,
    .col-lg-7,
    .col-xs-8,
    .col-sm-8,
    .col-md-8,
    .col-lg-8,
    .col-xs-9,
    .col-sm-9,
    .col-md-9,
    .col-lg-9,
    .col-xs-10,
    .col-sm-10,
    .col-md-10,
    .col-lg-10,
    .col-xs-11,
    .col-sm-11,
    .col-md-11,
    .col-lg-11,
    .col-xs-12,
    .col-sm-12,
    .col-md-12,
    .col-lg-12 {
        padding-right: 20px;
        padding-left: 20px;
        padding-bottom: 20px;
    }
}

.col-xs-1,
.col-xs-2,
.col-xs-3,
.col-xs-4,
.col-xs-5,
.col-xs-6,
.col-xs-7,
.col-xs-8,
.col-xs-9,
.col-xs-10,
.col-xs-11,
.col-xs-12 {
    float: left;
}

.col-xs-12 {
    width: 100%;
}

.col-xs-11 {
    width: 91.66666667%;
}

.col-xs-10 {
    width: 83.33333333%;
}

.col-xs-9 {
    width: 75%;
}

.col-xs-8 {
    width: 66.66666667%;
}

.col-xs-7 {
    width: 58.33333333%;
}

.col-xs-6 {
    width: 50%;
}

.col-xs-5 {
    width: 41.66666667%;
}

.col-xs-4 {
    width: 33.33333333%;
}

.col-xs-3 {
    width: 25%;
}

.col-xs-2 {
    width: 16.66666667%;
}

.col-xs-1 {
    width: 8.33333333%;
}

.col-xs-pull-12 {
    right: 100%;
}

.col-xs-pull-11 {
    right: 91.66666667%;
}

.col-xs-pull-10 {
    right: 83.33333333%;
}

.col-xs-pull-9 {
    right: 75%;
}

.col-xs-pull-8 {
    right: 66.66666667%;
}

.col-xs-pull-7 {
    right: 58.33333333%;
}

.col-xs-pull-6 {
    right: 50%;
}

.col-xs-pull-5 {
    right: 41.66666667%;
}

.col-xs-pull-4 {
    right: 33.33333333%;
}

.col-xs-pull-3 {
    right: 25%;
}

.col-xs-pull-2 {
    right: 16.66666667%;
}

.col-xs-pull-1 {
    right: 8.33333333%;
}

.col-xs-pull-0 {
    right: auto;
}

.col-xs-push-12 {
    left: 100%;
}

.col-xs-push-11 {
    left: 91.66666667%;
}

.col-xs-push-10 {
    left: 83.33333333%;
}

.col-xs-push-9 {
    left: 75%;
}

.col-xs-push-8 {
    left: 66.66666667%;
}

.col-xs-push-7 {
    left: 58.33333333%;
}

.col-xs-push-6 {
    left: 50%;
}

.col-xs-push-5 {
    left: 41.66666667%;
}

.col-xs-push-4 {
    left: 33.33333333%;
}

.col-xs-push-3 {
    left: 25%;
}

.col-xs-push-2 {
    left: 16.66666667%;
}

.col-xs-push-1 {
    left: 8.33333333%;
}

.col-xs-push-0 {
    left: auto;
}

.col-xs-offset-12 {
    margin-left: 100%;
}

.col-xs-offset-11 {
    margin-left: 91.66666667%;
}

.col-xs-offset-10 {
    margin-left: 83.33333333%;
}

.col-xs-offset-9 {
    margin-left: 75%;
}

.col-xs-offset-8 {
    margin-left: 66.66666667%;
}

.col-xs-offset-7 {
    margin-left: 58.33333333%;
}

.col-xs-offset-6 {
    margin-left: 50%;
}

.col-xs-offset-5 {
    margin-left: 41.66666667%;
}

.col-xs-offset-4 {
    margin-left: 33.33333333%;
}

.col-xs-offset-3 {
    margin-left: 25%;
}

.col-xs-offset-2 {
    margin-left: 16.66666667%;
}

.col-xs-offset-1 {
    margin-left: 8.33333333%;
}

.col-xs-offset-0 {
    margin-left: 0%;
}

@media (min-width: 768px) {
    .col-sm-1,
    .col-sm-2,
    .col-sm-3,
    .col-sm-4,
    .col-sm-5,
    .col-sm-6,
    .col-sm-7,
    .col-sm-8,
    .col-sm-9,
    .col-sm-10,
    .col-sm-11,
    .col-sm-12 {
        float: left;
    }

    .col-sm-12 {
        width: 100%;
    }

    .col-sm-11 {
        width: 91.66666667%;
    }

    .col-sm-10 {
        width: 83.33333333%;
    }

    .col-sm-9 {
        width: 75%;
    }

    .col-sm-8 {
        width: 66.66666667%;
    }

    .col-sm-7 {
        width: 58.33333333%;
    }

    .col-sm-6 {
        width: 50%;
    }

    .col-sm-5 {
        width: 41.66666667%;
    }

    .col-sm-4 {
        width: 33.33333333%;
    }

    .col-sm-3 {
        width: 25%;
    }

    .col-sm-2 {
        width: 16.66666667%;
    }

    .col-sm-1 {
        width: 8.33333333%;
    }

    .col-sm-pull-12 {
        right: 100%;
    }

    .col-sm-pull-11 {
        right: 91.66666667%;
    }

    .col-sm-pull-10 {
        right: 83.33333333%;
    }

    .col-sm-pull-9 {
        right: 75%;
    }

    .col-sm-pull-8 {
        right: 66.66666667%;
    }

    .col-sm-pull-7 {
        right: 58.33333333%;
    }

    .col-sm-pull-6 {
        right: 50%;
    }

    .col-sm-pull-5 {
        right: 41.66666667%;
    }

    .col-sm-pull-4 {
        right: 33.33333333%;
    }

    .col-sm-pull-3 {
        right: 25%;
    }

    .col-sm-pull-2 {
        right: 16.66666667%;
    }

    .col-sm-pull-1 {
        right: 8.33333333%;
    }

    .col-sm-pull-0 {
        right: auto;
    }

    .col-sm-push-12 {
        left: 100%;
    }

    .col-sm-push-11 {
        left: 91.66666667%;
    }

    .col-sm-push-10 {
        left: 83.33333333%;
    }

    .col-sm-push-9 {
        left: 75%;
    }

    .col-sm-push-8 {
        left: 66.66666667%;
    }

    .col-sm-push-7 {
        left: 58.33333333%;
    }

    .col-sm-push-6 {
        left: 50%;
    }

    .col-sm-push-5 {
        left: 41.66666667%;
    }

    .col-sm-push-4 {
        left: 33.33333333%;
    }

    .col-sm-push-3 {
        left: 25%;
    }

    .col-sm-push-2 {
        left: 16.66666667%;
    }

    .col-sm-push-1 {
        left: 8.33333333%;
    }

    .col-sm-push-0 {
        left: auto;
    }

    .col-sm-offset-12 {
        margin-left: 100%;
    }

    .col-sm-offset-11 {
        margin-left: 91.66666667%;
    }

    .col-sm-offset-10 {
        margin-left: 83.33333333%;
    }

    .col-sm-offset-9 {
        margin-left: 75%;
    }

    .col-sm-offset-8 {
        margin-left: 66.66666667%;
    }

    .col-sm-offset-7 {
        margin-left: 58.33333333%;
    }

    .col-sm-offset-6 {
        margin-left: 50%;
    }

    .col-sm-offset-5 {
        margin-left: 41.66666667%;
    }

    .col-sm-offset-4 {
        margin-left: 33.33333333%;
    }

    .col-sm-offset-3 {
        margin-left: 25%;
    }

    .col-sm-offset-2 {
        margin-left: 16.66666667%;
    }

    .col-sm-offset-1 {
        margin-left: 8.33333333%;
    }

    .col-sm-offset-0 {
        margin-left: 0%;
    }
}

@media (min-width: 992px) {
    .col-md-1,
    .col-md-2,
    .col-md-3,
    .col-md-4,
    .col-md-5,
    .col-md-6,
    .col-md-7,
    .col-md-8,
    .col-md-9,
    .col-md-10,
    .col-md-11,
    .col-md-12 {
        float: left;
    }

    .col-md-12 {
        width: 100%;
    }

    .col-md-11 {
        width: 91.66666667%;
    }

    .col-md-10 {
        width: 83.33333333%;
    }

    .col-md-9 {
        width: 75%;
    }

    .col-md-8 {
        width: 66.66666667%;
    }

    .col-md-7 {
        width: 58.33333333%;
    }

    .col-md-6 {
        width: 50%;
    }

    .col-md-5 {
        width: 41.66666667%;
    }

    .col-md-4 {
        width: 33.33333333%;
    }

    .col-md-3 {
        width: 25%;
    }

    .col-md-2 {
        width: 16.66666667%;
    }

    .col-md-1 {
        width: 8.33333333%;
    }

    .col-md-pull-12 {
        right: 100%;
    }

    .col-md-pull-11 {
        right: 91.66666667%;
    }

    .col-md-pull-10 {
        right: 83.33333333%;
    }

    .col-md-pull-9 {
        right: 75%;
    }

    .col-md-pull-8 {
        right: 66.66666667%;
    }

    .col-md-pull-7 {
        right: 58.33333333%;
    }

    .col-md-pull-6 {
        right: 50%;
    }

    .col-md-pull-5 {
        right: 41.66666667%;
    }

    .col-md-pull-4 {
        right: 33.33333333%;
    }

    .col-md-pull-3 {
        right: 25%;
    }

    .col-md-pull-2 {
        right: 16.66666667%;
    }

    .col-md-pull-1 {
        right: 8.33333333%;
    }

    .col-md-pull-0 {
        right: auto;
    }

    .col-md-push-12 {
        left: 100%;
    }

    .col-md-push-11 {
        left: 91.66666667%;
    }

    .col-md-push-10 {
        left: 83.33333333%;
    }

    .col-md-push-9 {
        left: 75%;
    }

    .col-md-push-8 {
        left: 66.66666667%;
    }

    .col-md-push-7 {
        left: 58.33333333%;
    }

    .col-md-push-6 {
        left: 50%;
    }

    .col-md-push-5 {
        left: 41.66666667%;
    }

    .col-md-push-4 {
        left: 33.33333333%;
    }

    .col-md-push-3 {
        left: 25%;
    }

    .col-md-push-2 {
        left: 16.66666667%;
    }

    .col-md-push-1 {
        left: 8.33333333%;
    }

    .col-md-push-0 {
        left: auto;
    }

    .col-md-offset-12 {
        margin-left: 100%;
    }

    .col-md-offset-11 {
        margin-left: 91.66666667%;
    }

    .col-md-offset-10 {
        margin-left: 83.33333333%;
    }

    .col-md-offset-9 {
        margin-left: 75%;
    }

    .col-md-offset-8 {
        margin-left: 66.66666667%;
    }

    .col-md-offset-7 {
        margin-left: 58.33333333%;
    }

    .col-md-offset-6 {
        margin-left: 50%;
    }

    .col-md-offset-5 {
        margin-left: 41.66666667%;
    }

    .col-md-offset-4 {
        margin-left: 33.33333333%;
    }

    .col-md-offset-3 {
        margin-left: 25%;
    }

    .col-md-offset-2 {
        margin-left: 16.66666667%;
    }

    .col-md-offset-1 {
        margin-left: 8.33333333%;
    }

    .col-md-offset-0 {
        margin-left: 0%;
    }
}

@media (min-width: 1200px) {
    .col-lg-1,
    .col-lg-2,
    .col-lg-3,
    .col-lg-4,
    .col-lg-5,
    .col-lg-6,
    .col-lg-7,
    .col-lg-8,
    .col-lg-9,
    .col-lg-10,
    .col-lg-11,
    .col-lg-12 {
        float: left;
    }

    .col-lg-12 {
        width: 100%;
    }

    .col-lg-11 {
        width: 91.66666667%;
    }

    .col-lg-10 {
        width: 83.33333333%;
    }

    .col-lg-9 {
        width: 75%;
    }

    .col-lg-8 {
        width: 66.66666667%;
    }

    .col-lg-7 {
        width: 58.33333333%;
    }

    .col-lg-6 {
        width: 50%;
    }

    .col-lg-5 {
        width: 41.66666667%;
    }

    .col-lg-4 {
        width: 33.33333333%;
    }

    .col-lg-3 {
        width: 25%;
    }

    .col-lg-2 {
        width: 16.66666667%;
    }

    .col-lg-1 {
        width: 8.33333333%;
    }

    .col-lg-pull-12 {
        right: 100%;
    }

    .col-lg-pull-11 {
        right: 91.66666667%;
    }

    .col-lg-pull-10 {
        right: 83.33333333%;
    }

    .col-lg-pull-9 {
        right: 75%;
    }

    .col-lg-pull-8 {
        right: 66.66666667%;
    }

    .col-lg-pull-7 {
        right: 58.33333333%;
    }

    .col-lg-pull-6 {
        right: 50%;
    }

    .col-lg-pull-5 {
        right: 41.66666667%;
    }

    .col-lg-pull-4 {
        right: 33.33333333%;
    }

    .col-lg-pull-3 {
        right: 25%;
    }

    .col-lg-pull-2 {
        right: 16.66666667%;
    }

    .col-lg-pull-1 {
        right: 8.33333333%;
    }

    .col-lg-pull-0 {
        right: auto;
    }

    .col-lg-push-12 {
        left: 100%;
    }

    .col-lg-push-11 {
        left: 91.66666667%;
    }

    .col-lg-push-10 {
        left: 83.33333333%;
    }

    .col-lg-push-9 {
        left: 75%;
    }

    .col-lg-push-8 {
        left: 66.66666667%;
    }

    .col-lg-push-7 {
        left: 58.33333333%;
    }

    .col-lg-push-6 {
        left: 50%;
    }

    .col-lg-push-5 {
        left: 41.66666667%;
    }

    .col-lg-push-4 {
        left: 33.33333333%;
    }

    .col-lg-push-3 {
        left: 25%;
    }

    .col-lg-push-2 {
        left: 16.66666667%;
    }

    .col-lg-push-1 {
        left: 8.33333333%;
    }

    .col-lg-push-0 {
        left: auto;
    }

    .col-lg-offset-12 {
        margin-left: 100%;
    }

    .col-lg-offset-11 {
        margin-left: 91.66666667%;
    }

    .col-lg-offset-10 {
        margin-left: 83.33333333%;
    }

    .col-lg-offset-9 {
        margin-left: 75%;
    }

    .col-lg-offset-8 {
        margin-left: 66.66666667%;
    }

    .col-lg-offset-7 {
        margin-left: 58.33333333%;
    }

    .col-lg-offset-6 {
        margin-left: 50%;
    }

    .col-lg-offset-5 {
        margin-left: 41.66666667%;
    }

    .col-lg-offset-4 {
        margin-left: 33.33333333%;
    }

    .col-lg-offset-3 {
        margin-left: 25%;
    }

    .col-lg-offset-2 {
        margin-left: 16.66666667%;
    }

    .col-lg-offset-1 {
        margin-left: 8.33333333%;
    }

    .col-lg-offset-0 {
        margin-left: 0%;
    }
}

.clearfix:before,
.clearfix:after,
.container:before,
.container:after,
.container-fluid:before,
.container-fluid:after,
.row:before,
.row:after {
    display: table;
    content: " ";
}

.clearfix:after,
.container:after,
.container-fluid:after,
.row:after {
    clear: both;
}

@-ms-viewport {
    width: device-width;
}

.visible-xs,
.visible-sm,
.visible-md,
.visible-lg {
    display: none !important;
}

.visible-xs-block,
.visible-xs-inline,
.visible-xs-inline-block,
.visible-sm-block,
.visible-sm-inline,
.visible-sm-inline-block,
.visible-md-block,
.visible-md-inline,
.visible-md-inline-block,
.visible-lg-block,
.visible-lg-inline,
.visible-lg-inline-block {
    display: none !important;
}

@media (max-width: 767px) {
    .visible-xs {
        display: block !important;
    }

    table.visible-xs {
        display: table;
    }

    tr.visible-xs {
        display: table-row !important;
    }

    th.visible-xs,
    td.visible-xs {
        display: table-cell !important;
    }
}

@media (max-width: 767px) {
    .visible-xs-block {
        display: block !important;
    }
}

@media (max-width: 767px) {
    .visible-xs-inline {
        display: inline !important;
    }
}

@media (max-width: 767px) {
    .visible-xs-inline-block {
        display: inline-block !important;
    }
}

@media (min-width: 768px) and (max-width: 991px) {
    .visible-sm {
        display: block !important;
    }

    table.visible-sm {
        display: table;
    }

    tr.visible-sm {
        display: table-row !important;
    }

    th.visible-sm,
    td.visible-sm {
        display: table-cell !important;
    }
}

@media (min-width: 768px) and (max-width: 991px) {
    .visible-sm-block {
        display: block !important;
    }
}

@media (min-width: 768px) and (max-width: 991px) {
    .visible-sm-inline {
        display: inline !important;
    }
}

@media (min-width: 768px) and (max-width: 991px) {
    .visible-sm-inline-block {
        display: inline-block !important;
    }
}

@media (min-width: 992px) and (max-width: 1199px) {
    .visible-md {
        display: block !important;
    }

    table.visible-md {
        display: table;
    }

    tr.visible-md {
        display: table-row !important;
    }

    th.visible-md,
    td.visible-md {
        display: table-cell !important;
    }
}

@media (min-width: 992px) and (max-width: 1199px) {
    .visible-md-block {
        display: block !important;
    }
}

@media (min-width: 992px) and (max-width: 1199px) {
    .visible-md-inline {
        display: inline !important;
    }
}

@media (min-width: 992px) and (max-width: 1199px) {
    .visible-md-inline-block {
        display: inline-block !important;
    }
}

@media (min-width: 1200px) {
    .visible-lg {
        display: block !important;
    }

    table.visible-lg {
        display: table;
    }

    tr.visible-lg {
        display: table-row !important;
    }

    th.visible-lg,
    td.visible-lg {
        display: table-cell !important;
    }
}

@media (min-width: 1200px) {
    .visible-lg-block {
        display: block !important;
    }
}

@media (min-width: 1200px) {
    .visible-lg-inline {
        display: inline !important;
    }
}

@media (min-width: 1200px) {
    .visible-lg-inline-block {
        display: inline-block !important;
    }
}

@media (max-width: 767px) {
    .hidden-xs {
        display: none !important;
    }
}

@media (min-width: 768px) and (max-width: 991px) {
    .hidden-sm {
        display: none !important;
    }
}

@media (min-width: 992px) and (max-width: 1199px) {
    .hidden-md {
        display: none !important;
    }
}

@media (min-width: 1200px) {
    .hidden-lg {
        display: none !important;
    }
}

.visible-print {
    display: none !important;
}

@media print {
    .visible-print {
        display: block !important;
    }

    table.visible-print {
        display: table;
    }

    tr.visible-print {
        display: table-row !important;
    }

    th.visible-print,
    td.visible-print {
        display: table-cell !important;
    }
}

.visible-print-block {
    display: none !important;
}

@media print {
    .visible-print-block {
        display: block !important;
    }
}

.visible-print-inline {
    display: none !important;
}

@media print {
    .visible-print-inline {
        display: inline !important;
    }
}

.visible-print-inline-block {
    display: none !important;
}

@media print {
    .visible-print-inline-block {
        display: inline-block !important;
    }
}

@media print {
    .hidden-print {
        display: none !important;
    }
}

.header {
    position: fixed;
    top: 40px;
    left: 0;
    right: 0;
    z-index: 99;
}

.header--static {
    position: absolute;
}

@media (max-width: 580px) {
    .header {
        top: 0;
    }
}

.header .wrap {
    position: relative;
    z-index: 95;
    display: flex;
    align-items: center;
    padding-left: 50px;
    padding-right: 50px;
}

@media (max-width: 580px) {
    .header .wrap {
        height: 72px;
        background: #fff;
        padding-left: 0;
        padding-right: 0;
        justify-content: flex-end;
    }

    .mainmenu-visible .header .wrap {
        background: transparent;
    }
}

.header .logo {
    display: inline-block;
    width: 170px;
    height: 58px;
    transition: none;
    flex: 0 0 auto;
}

@media (max-width: 580px) {
    .header .logo {
        width: 110px;
        height: auto;
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
    }
}

.mainmenu-visible .header .logo {
    display: none;
}

@media (max-width: 580px) {
    .mainmenu-visible .header .logo {
        display: block;
        left: 0;
        transform: translate(20px, -50%);
    }
}

.header .extension {
    display: flex;
    margin-left: auto;
    align-items: center;
}

@media (max-width: 1024px) {
    .header .extension {
        display: none;
    }
}

.mainmenu-visible .header .extension {
    display: none;
}

.header .extension p {
    text-align: right;
    margin: 0;
}

.header .extension__images {
    display: flex;
    margin-top: -20px;
    align-items: flex-end;
    margin-left: 20px;
}

    .header .extension__images img {
        margin-left: 10px;
    }

.header .menu-text {
    color: #fff;
    text-transform: uppercase;
    font-size: 1.4rem;
    line-height: 2.1rem;
    font-weight: 700;
    display: none;
    width: 170px;
    height: 58px;
    line-height: 58px;
    letter-spacing: 2px;
}

.mainmenu-visible .header .menu-text {
    display: block;
}

@media (max-width: 580px) {
    .mainmenu-visible .header .menu-text {
        display: none;
    }
}

.StopSelectMessage {
    text-align: center;
    background: rgba(86, 217, 205, 0.99);
    position: absolute;
    width: 100%;
    z-index: 20;
}


@media (max-width: 580px) {
    .StopSelectMessage {
        padding-top: 70px;
    }
}



.header .toggle-menu {
    border-width: 0px;
    font-size: 2.2rem;
    line-height: 2.4rem;
    flex: 0 0 auto;
    color: #fff;
    padding: 16px 26px;
    border-radius: 8px;
    margin-left: 80px;
    cursor: pointer;
    font-weight: 300;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    background: rgba(1, 49, 70, 0.5);
    transition: 0.1s;
    display: flex;
    align-items: center;
    border-width: 1px;
    border-color: #fff;
    border-style: groove;
}

@media (max-width: 580px) {
    .header .toggle-menu {
        background: transparent;
        padding: 16px 20px;
        font-size: 1.8rem;
    }
}

.mainmenu-visible .header .toggle-menu__span-menu,
.mainmenu-visible .header .toggle-menu__span-login {
    display: none;
}

@media (max-width: 580px) {
    .header .toggle-menu__span-menu {
        color: #9fa2ab;
    }
}

@media (max-width: 580px) {
    .header .toggle-menu__span-login {
        display: none;
    }
}

.header .toggle-menu__span-close {
    display: none;
}

.mainmenu-visible .header .toggle-menu__span-close {
    display: block;
}

@media (max-width: 580px) {
    .mainmenu-visible .header .toggle-menu__span-close {
        display: none;
    }
}

.header .toggle-menu__icon {
    display: block;
    width: 24px;
    height: 24px;
    margin-left: 16px;
    background: url(../images/sprite.svg) no-repeat;
}

@media (max-width: 580px) {
    .header .toggle-menu__icon {
        margin-left: 10px;
        background-position: -24px -144px;
    }
}

.mainmenu-visible .header .toggle-menu__icon {
    background-position: 0 -24px;
}

@media (max-width: 580px) {
    .mainmenu-visible .header .toggle-menu__icon {
        margin-left: 0;
    }
}

.header .toggle-menu.menu-active {
    background: rgba(255, 255, 255, 0.2);
}

@media (max-width: 580px) {
    .header .toggle-menu.menu-active {
        background: transparent;
    }
}

.footer {
    padding: 0 0 40px;
    font-weight: 300;
    color: #013146;
}

.home .footer {
    padding-top: 80px;
}

.social-links {
    margin: 0;
    list-style: none;
    padding-bottom: 20px;
    display: flex;
}

    .social-links li {
        margin-right: 20px;
    }

        .social-links li a {
            display: block;
            width: 24px;
            height: 24px;
            background: url(../images/sprite.svg) no-repeat;
            line-height: 0;
            font-size: 0;
            color: transparent;
        }

            .social-links li a.link-facebook {
                background-position: 0 -48px;
            }

            .social-links li a.link-linkedin {
                background-position: 0 -72px;
            }

            .social-links li a.link-twitter {
                background-position: 0 -96px;
            }

            .social-links li a.link-youtube {
                background-position: 0 -120px;
            }

            .social-links li a.link-instagram {
                background-position: 0 -144px;
            }

.metamenu {
    margin: 0;
    list-style: none;
    padding-bottom: 5px;
}

@media (max-width: 580px) {
    .metamenu {
        padding-bottom: 0;
    }
}

.metamenu li {
    display: inline-block;
}

    .metamenu li::after {
        content: "  •  ";
    }

@media (max-width: 580px) {
    .metamenu li::after {
        font-size: 1.1rem;
        line-height: 2.2rem;
        padding-left: 2px;
    }
}

.metamenu li:last-child::after {
    content: none;
}

.metamenu li a {
    font-weight: 300;
    text-decoration: underline;
}

@media (max-width: 580px) {
    .metamenu li a {
        font-size: 1.1rem;
        line-height: 2.2rem;
    }
}

.metamenu li a:hover {
    text-decoration: none;
}

.copy {
    font-weight: 300;
}

@media (max-width: 580px) {
    .copy {
        font-size: 1.1rem;
        line-height: 2.2rem;
    }
}

.table-wrap {
    overflow-x: auto;
    margin-bottom: 3.5rem;
}

.table {
    border-collapse: separate;
    border-spacing: 0 1.6rem;
    margin-top: -1.6rem;
    width: 100%;
    max-width: 430px;
}

    .table tr th {
        font-size: 1.4rem;
        line-height: 2.1rem;
        font-weight: 700;
        text-align: center;
        padding: 1.6rem 7px 0;
        text-transform: uppercase;
    }

    .table tr td {
        padding: 7px;
        text-align: center;
    }

        .table tr td:first-child {
            border-top-left-radius: 8px;
            border-bottom-left-radius: 8px;
        }

        .table tr td:last-child {
            border-top-right-radius: 8px;
            border-bottom-right-radius: 8px;
        }

::-webkit-input-placeholder {
    opacity: 1;
}

:-moz-placeholder {
    opacity: 1;
}

::-moz-placeholder {
    opacity: 1;
}

:-ms-input-placeholder {
    opacity: 1;
}

.field {
    position: relative;
    margin-bottom: 2rem;
}

.field__label {
    display: inline-block;
    cursor: pointer;
}

.field__text,
.field__textarea {
    font: inherit;
    display: block;
    width: 100%;
    padding: 12px 14px;
    margin: 5px 0;
    border-radius: 8px;
    transition: 0.3s;
    outline: none;
    background: #fff;
    border: 1px solid #bfbfbf;
}

    .field__text:focus,
    .field__textarea:focus {
        border-color: #013146;
    }

    .field__text:disabled,
    .field__textarea:disabled {
        background: #fff;
        cursor: not-allowed;
        opacity:0.2;
    }

.field__textarea {
    height: 105px;
    resize: none;
}

.field__checkbox,
.field__radio {
    position: absolute;
    left: -9999px;
}

    .field__checkbox:checked ~ .checkbox-label::before,
    .field__checkbox:checked ~ .radio-label::before,
    .field__radio:checked ~ .checkbox-label::before,
    .field__radio:checked ~ .radio-label::before {
        opacity: 1;
        transform: scale(1);
    }


.field .checkbox-label,
.field .radio-label {
    position: relative;
    padding-left: 40px;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}

    .field .checkbox-label::before,
    .field .checkbox-label::after,
    .field .radio-label::before,
    .field .radio-label::after {
        content: "";
        position: absolute;
        left: 0;
        display: block;
        border-radius: 100%;
    }

    .field .checkbox-label::after,
    .field .radio-label::after {
        top: -2px;
        width: 24px;
        height: 24px;
        border: 2px solid #013146;
    }

    .field .checkbox-label::before,
    .field .radio-label::before {
        transition: 0.1s;
        top: 6px;
        left: 8px;
        z-index: 2;
        width: 12px;
        height: 12px;
        background: #56d9cd;
        opacity: 0;
        transform: scale(0);
    }

.field-helper {
    display: block;
    color: #9fa2ab;
    font-weight: 400;
}

.select {
    margin-bottom: 2rem;
}

.select__wrapper {
    position: relative;
    width: 100%;
}

    .select__wrapper select {
        -webkit-appearance: none;
        -moz-appearance: none;
        appearance: none;
        position: absolute;
        left: -9999px;
    }

    .select__wrapper .selected {
        padding: 12px 40px 12px 14px;
        margin: 5px 0;
        border-radius: 8px;
        border: 1px solid #9fa2ab;
        transition: 0.3s;
        outline: none;
        background: #fff;
        cursor: pointer;
        position: relative;
        text-overflow: ellipsis;
        -webkit-user-select: none;
        -moz-user-select: none;
        -ms-user-select: none;
        user-select: none;
    }

        .select__wrapper .selected::after {
            content: "";
            position: absolute;
            background: url(../images/sprite.svg) no-repeat;
            background-position: -24px 0;
            width: 24px;
            height: 24px;
            right: 14px;
            top: 50%;
            margin-top: -10px;
        }

    .select__wrapper .selected--open::after {
        transform: rotate(-180deg);
        margin-top: -12px;
    }

    .select__wrapper .select-list {
        position: absolute;
        top: calc(100% - 14px);
        left: 0;
        right: 0;
        display: none;
        background: #fff;
        border-bottom-left-radius: 8px;
        border-bottom-right-radius: 8px;
        border: solid #9fa2ab;
        border-width: 0 1px 1px 1px;
        margin: 0;
        list-style: none;
        z-index: 10;
        max-height: 300px;
        overflow: auto;
        padding-top: 14px;
    }

        .select__wrapper .select-list li {
            cursor: pointer;
            -webkit-user-select: none;
            -moz-user-select: none;
            -ms-user-select: none;
            user-select: none;
            padding: 12px 14px;
            transition: 0.3s;
        }

            .select__wrapper .select-list li:last-child {
                border-bottom-left-radius: 8px;
                border-bottom-right-radius: 8px;
            }

            .select__wrapper .select-list li:hover {
                background: #f0f0f0;
            }

@media (max-width: 580px) {
    .select--up .select-list {
        padding-top: 0;
        padding-bottom: 14px;
        top: auto;
        bottom: calc(100% - 14px);
        border-width: 1px 1px 0 1px;
        border-top-left-radius: 8px;
        border-top-right-radius: 8px;
        border-bottom-left-radius: 0;
        border-bottom-right-radius: 0;
    }

        .select--up .select-list li:last-child {
            border-bottom-left-radius: 0;
            border-bottom-right-radius: 0;
        }
}

.login-form {
    background: #fff;
    border-radius: 40px;
    padding: 40px 20px;
    width: 375px;
    margin: 0 20px;
    text-align: center;
}

@media (max-width: 580px) {
    .login-form {
        background: transparent;
        padding: 0 0 60px;
        width: 100%;
        box-shadow: none !important;
        border-radius: 0;
    }
}

.login-form .headline {
    margin-left: auto;
    margin-right: auto;
}

.login-form .field {
    text-align: left;
}

.login-form .button {
    margin: 0;
}

.autocomplete-suggestions {
    background: #fff;
    border-bottom-left-radius: 8px;
    border-bottom-right-radius: 8px;
    border: solid #013146;
    border-width: 0 1px 1px 1px;
    margin-top: -6px;
    overflow: auto;
}

    .autocomplete-suggestions .autocomplete-suggestion {
        padding: 12px 14px;
        cursor: pointer;
        transition: 0.3s;
    }

        .autocomplete-suggestions .autocomplete-suggestion:hover,
        .autocomplete-suggestions .autocomplete-suggestion.autocomplete-selected {
            background: #f0f0f0;
        }

        .autocomplete-suggestions .autocomplete-suggestion:last-child {
            border-bottom-left-radius: 8px;
            border-bottom-right-radius: 8px;
        }

.datepicker-panel ul > li.picked {
    color: #56d9cd;
    font-weight: 600;
}

    .datepicker-panel ul > li.picked:hover {
        color: #56d9cd !important;
    }

.accordion {
    margin-bottom: 60px;
}

.accordion__item {
    margin: 3rem 0;
}

.accordion__headline {
    margin-bottom: 1.5rem;
    position: relative;
    padding-left: 65px;
    text-align: left;
    font-size: 4.8rem;
    line-height: 6rem;
    font-weight: 800;
}

@media (max-width: 767px) {
    .accordion__headline {
        font-size: 2.5rem;
        line-height: 3.3rem;
        padding-left: 35px;
    }
}

.accordion__headline::before,
.accordion__headline::after {
    content: "";
    position: absolute;
    left: 0;
    top: 28px;
    height: 5px;
    width: 40px;
    background: #56d9cd;
    border-radius: 18px;
    transition: 0.1s;
}

@media (max-width: 767px) {
    .accordion__headline::before,
    .accordion__headline::after {
        height: 3px;
        width: 18px;
        top: 14px;
    }
}

.accordion__headline::before {
    width: 5px;
    height: 40px;
    top: 10px;
    left: 17px;
}

@media (max-width: 767px) {
    .accordion__headline::before {
        height: 18px;
        width: 3px;
        top: 6px;
        left: 8px;
    }
}

.accordion__headline--expanded::before {
    content: none;
}

.accordion__headline--expanded::after {
    background: #f5a503;
}

.accordion__headline button {
    display: block;
    font: inherit;
    text-align: left;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    cursor: pointer;
    border: 0;
    padding: 0;
    background: transparent;
    color: #013146;
}

.accordion__panel {
    padding-left: 65px;
    width: 90%;
}

@media (max-width: 1200px) {
    .accordion__panel {
        width: 100%;
    }
}

@media (max-width: 767px) {
    .accordion__panel {
        padding-left: 35px;
    }
}

.link {
    font-size: 1.8rem;
    line-height: 2.5rem;
    display: inline-block;
    color: #222;
    font-weight: 700;
    text-decoration: underline;
}

@media (max-width: 580px) {
    .link {
        font-size: 1.1rem;
        line-height: 2.2rem;
        font-weight: 400;
    }
}

.link--small {
    font-weight: 400;
    font-size: 1.1rem;
    line-height: 2.2rem;
}

.link:hover {
    color: #56d9cd;
}

.change-link {
    display: inline-block;
    margin-top: 15px;
    font-size: 1.1rem;
    line-height: 2.2rem;
    font-weight: 500 !important;
    color: #9fa2ab !important;
    text-decoration: underline;
}

    .change-link:hover {
        text-decoration: none;
    }

.button {
    font: inherit;
    cursor: pointer;
    line-height: 2.5rem;
    font-weight: 700;
    display: inline-block;
    border-radius: 8px;
    transition: 0.3s;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    border: 0;
    padding: 12px 29px;
    background: #fff;
    margin: 0 20px 20px 0;
}

@media (max-width: 580px) {
    .button {
        line-height: 2.4rem;
        padding: 8px 13px;
    }
}

.button--primary {
    background: #56d9cd;
    color: #013146;
}

    .button--primary:hover {
        opacity: 0.8;
    }

.button--alert {
    background: #f2385a;
    color: #013146;
}

    .button--alert:hover {
        opacity: 0.8;
    }

.button--warning {
    background: #f5a503;
    color: #013146;
}

    .button--warning:hover {
        opacity: 0.8;
    }

.button--border {
    color: #222;
    background: transparent;
    box-shadow: inset 0px 0px 0px 1px #f0f0f0;
}

    .button--border:hover {
        box-shadow: inset 0px 0px 0px 4px #f0f0f0;
    }

    .button--border:disabled:hover {
        box-shadow: inset 0px 0px 0px 1px #f0f0f0;
    }

.button--grey {
    background: #f0f0f0;
    color: #222;
    box-shadow: inset 0px 0px 0px 4px #f0f0f0;
}

    .button--grey:hover {
        background: #fff;
    }

    .button--grey:disabled:hover {
        background: inherit;
    }

.button:disabled {
    cursor: not-allowed;
    opacity: 0.2;
}

.popup {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(1, 49, 70, 0.75);
    z-index: 999;
    transition: 0.3s;
    opacity: 0;
    visibility: hidden;
    overflow: auto;
    display: flex;
    justify-content: center;
}

@media (min-height: 1020px) {
    .popup {
        align-items: center;
    }
}

.popup--visible {
    opacity: 1;
    visibility: visible;
}

    .popup--visible .popup__content {
        -webkit-animation: popup-slide-in 0.6s forwards;
        animation: popup-slide-in 0.6s forwards;
    }

.popup .wrap {
    padding: 40px 20px;
}

.popup__close {
    font: inherit;
    cursor: pointer;
    display: block;
    padding: 0;
    height: 24px;
    width: 24px;
    background: url(../images/sprite.svg) no-repeat;
    background-position: -24px -24px;
    border: 0;
    position: absolute;
    top: 30px;
    right: 40px;
}

.popup__content {
    transition: 0.3s;
    position: relative;
    width: 100%;
    max-width: 540px;
    padding: 60px 40px 40px;
    border-radius: 40px;
    background: #fff;
    margin-bottom: 40px;
}

    .popup__content.large {
        max-width: 660px;
    }

@media (max-width: 580px) {
    .popup__content {
        padding: 60px 20px 20px;
    }
}

.popup__content > .popup-headline {
    padding-right: 40px;
}

.speech-bubble {
    background: #fff;
    border-radius: 16px;
    padding: 16px;
    position: relative;
    margin-bottom: 4rem;
}

    .speech-bubble::after {
        content: "";
        display: block;
        width: 24px;
        height: 24px;
        background: url(../images/sprite.svg) no-repeat;
        background-position: -24px -120px;
        position: absolute;
        bottom: -18px;
    }

.speech-bubble--small {
    max-width: 290px;
}

    .speech-bubble--small::after {
        left: 25px;
    }

.speech-bubble--big {
    max-width: 440px;
}

    .speech-bubble--big::after {
        left: 90px;
    }

.steps {
    margin: auto auto 80px;
    max-width: 420px;
}

@media (max-width: 992px) {
    .steps {
        max-width: 120px;
    }
}

@media (max-width: 580px) {
    .steps {
        margin-bottom: 20px;
    }
}

.steps__dots {
    width: 100%;
    display: flex;
    justify-content: space-between;
    height: 24px;
    margin: 0;
    list-style: none;
    position: relative;
}

    .steps__dots::after {
        content: "";
        width: 100%;
        border-top: 2px dashed #f0f0f0;
        position: absolute;
        top: 50%;
        margin-top: -1px;
        z-index: 1;
    }

@media (max-width: 992px) {
    .steps__dots::after {
        margin-top: -2px;
        border-top: 2px solid #f0f0f0;
    }
}

.steps .step {
    flex: 0 0 auto;
    position: relative;
    z-index: 2;
    border-radius: 100%;
    display: inline-block;
    margin-top: 4px;
    width: 16px;
    height: 16px;
    background: #9fa2ab;
}

@media (max-width: 992px) {
    .steps .step {
        width: 12px;
        height: 12px;
        margin-top: 5px;
    }
}

.steps .step.completed {
    background: #56d9cd;
}

.steps .step.current {
    margin-top: 0;
    width: 24px;
    height: 24px;
    background: url(../images/sprite.svg) no-repeat;
    background-position: -48px 0;
}

@media (max-width: 992px) {
    .steps .step.current {
        background-position: -51px -27px;
        margin-top: 2px;
        width: 18px;
        height: 18px;
    }
}

.steps .step.current span {
    top: 29px;
    font-weight: 700;
}

.steps .step span {
    position: absolute;
    top: 25px;
    left: 50%;
    transform: translateX(-50%);
    font-size: 1.1rem;
    line-height: 2.2rem;
    font-weight: 500;
}

@media (max-width: 992px) {
    .steps .step span {
        display: none;
    }
}

.steps .step-current-text {
    display: none;
    margin-top: -2px;
    font-size: 1.1rem;
    line-height: 2.2rem;
    font-weight: 600;
    text-align: center;
}

@media (max-width: 992px) {
    .steps .step-current-text {
        display: block;
    }
}

.prev-next-navigation {
    display: flex;
    justify-content: space-between;
    padding: 25px 50px;
    position: fixed;
    z-index: 3;
    bottom: 0;
    width: 557px;
    right: 0;
    background: #fafafa;
    background: linear-gradient(0deg, #fafafa 35%, rgba(255, 255, 255, 0) 100%);
    filter: progid:DXImageTransform.Microsoft.gradient(startColorstr="#fafafa",endColorstr="#ffffff",GradientType=1);
}

@media (max-width: 992px) {
    .prev-next-navigation {
        width: 470px;
    }
}

@media (max-width: 767px) {
    .prev-next-navigation {
        width: 100%;
        background: #fff;
        padding: 15px 20px;
        background: #fff;
    }
}

.prev-next-navigation .button {
    margin: 0;
}

.prev-next-navigation .next {
    margin-left: auto;
}

.notification {
    border-radius: 8px;
    border: 1px solid #f0f0f0;
    padding: 12px 10px 12px 40px;
    margin-bottom: 3rem;
    position: relative;
}

    .notification::before {
        content: "";
        width: 24px;
        height: 24px;
        background: url(../images/sprite.svg) no-repeat;
        position: absolute;
        top: 10px;
        left: 8px;
    }

.notification--warning::before {
    background-position: -24px -48px;
}

.notification--alert::before {
    background-position: -24px -72px;
}

.notification--info::before {
    background-position: -24px -96px;
}

.styleguide .color-palette {
    display: flex;
    margin-left: -80px;
    margin-right: -80px;
}

    .styleguide .color-palette span {
        display: block;
        height: 40px;
        width: 14.285714286%;
    }

.styleguide .logo {
    width: 100%;
    display: block;
    margin: 160px 0;
}

.styleguide .rectangles {
    display: flex;
    margin: 160px 0;
}

.styleguide .rectangles__box {
    margin-right: 50px;
    width: 100px;
    height: 100px;
}

.styleguide .spacer {
    margin-bottom: 40px;
}

.styleguide .speech-bubbles {
    background: #bdbdbd;
    padding: 35px 20px 0;
    display: flex;
    align-items: flex-end;
}

    .styleguide .speech-bubbles .speech-bubble:first-child {
        margin-right: 30px;
    }

.styleguide .headline-boxed {
    background: #9fa2ab;
    padding: 20px;
}

.page-content {
    padding-top: 180px;
}

@media (max-width: 580px) {
    .page-content {
        padding-top: 110px;
    }
}

.home .page-content {
    padding-top: 0;
}

.home .page-header {
    background: url(../images/olav-desktop-background.jpg) no-repeat top center;
    background-size: cover;
    padding-top: 240px;
    position: relative;
    height: 720px;
    padding-bottom: 100px;
    margin-bottom: 80px;
}

@media (max-width: 580px) {
    .home .page-header {
        margin-top: 72px;
        background-image: url(../images/olav-mobile-background.jpg);
        padding-top: 40px;
        padding-bottom: 40px;
        height: auto;
        margin-bottom: 110px;
    }
}

.home .page-header::after {
    content: "";
    background: #fafafa;
    display: block;
    height: 200px;
    position: absolute;
    left: 0;
    right: 0;
    bottom: -200px;
    transform: skewY(-4deg);
    transform-origin: 0 0;
}

.home .page-header .column {
    position: relative;
    z-index: 2;
}

@media (max-width: 580px) {
    .home .page-header .column {
        position: static;
    }
}

.home .page-header .text-wrap {
    padding-right: 25%;
}

@media (max-width: 420px) {
    .home .page-header .text-wrap {
        padding-right: 0;
    }
}

.home .page-header .olav {
    pointer-events: none;
    position: absolute;
    z-index: 1;
    top: -40px;
    right: -80px;
}

@media (max-width: 580px) {
    .home .page-header .olav {
        top: auto;
        bottom: -80px;
        right: -35px;
    }
}

.home .page-header .olav img {
    width: auto;
    height: 434px;
}

@media (max-width: 580px) {
    .home .page-header .olav img {
        height: 266px;
    }
}

.formular-wrap {
    min-height: 900px;
}

.formular-content {
    display: flex;
    height: 100%;
    width: 100%;
    justify-content: flex-end;
}

@media (max-width: 767px) {
    .formular-content {
        display: block;
    }
}

.formular .olav {
    position: fixed;
    top: 0;
    left: 0;
    height: 100%;
    min-height: 900px;
    width: calc(100% - 557px);
    flex: 1 1 auto;
    display: flex;
    justify-content: center;
    align-items: center;
    background: url(../images/olav-desktop-background.jpg) no-repeat top center;
    background-size: cover;
}

@media (max-width: 992px) {
    .formular .olav {
        width: calc(100% - 470px);
    }
}

@media (max-width: 767px) {
    .formular .olav {
        position: relative;
        min-height: auto;
        width: 100%;
        padding-top: 200px;
        padding-bottom: 20px;
    }
}



@media (max-width: 580px) {
    .formular .olav {
        background-image: url(../images/olav-mobile-background.jpg);
        flex-wrap: wrap;
        align-items: flex-start;
        height: auto;
        padding: 100px 20px 20px;
    }
}

.formular .olav .headline-mobile {
    display: none;
    margin-bottom: 3rem;
}

@media (max-width: 580px) {
    .formular .olav .headline-mobile {
        display: block;
    }
}

.formular .olav__image {
    position: absolute;
    width: 100%;
    left: 50%;
    transform: translateX(-50%);
    bottom: 70px;
    padding: 0 20px;
}

@media (max-width: 767px) {
    .formular .olav__image {
        position: relative;
        left: 0;
        transform: translateX(0);
        bottom: 0;
    }
}


@media (max-width: 580px) {
    .formular .olav__image {
        position: relative;
        bottom: auto;
        top: 0;
    }
}

.formular .olav__image figcaption {
    display: block;
    margin: auto auto 10px;
    max-width: 432px;
}

.formular .olav__image img {
    display: block;
    margin: auto;
    width: auto;
    max-height: 434px;
}

@media (max-width: 767px) {
    .formular .olav__image img {
        max-height: 250px;
    }
}

.formular .map {
    position: fixed;
    top: 0;
    left: 0;
    height: 100%;
    min-height: 900px;
    width: calc(100% - 557px);
    background: #ccc;
    justify-content: center;
    align-items: center;
    color: #fff;
}

@media (max-width: 992px) {
    .formular .map {
        width: calc(100% - 470px);
    }
}

@media (max-width: 767px) {
    .formular .map {
        position: relative;
        min-height: auto;
        width: 100%;
        height: 830px;
    }
}

.formular .form {
    flex: 0 0 auto;
    min-height: 900px;
    position: relative;
    width: 557px;
    padding: 50px;
    background: #fafafa;
    box-shadow: 0 0 40px rgba(0, 0, 0, 0.25);
}

@media (max-width: 992px) {
    .formular .form {
        width: 470px;
    }
}

@media (max-width: 767px) {
    .formular .form {
        width: 100%;
        min-height: auto;
    }
}

@media (max-width: 580px) {
    .formular .form {
        padding: 20px 20px 120px;
    }
}

@media (min-width: 581px) {
    .formular .form form {
        padding-bottom: 50px;
    }
}

@media (max-width: 580px) {
    .formular .form form > h2:not(.visible-mobile) {
        display: none;
    }
}

.formular .form .edit-link {
    color: #9fa2ab;
    text-decoration: underline;
    font-size: 1.1rem;
    line-height: 2.2rem;
    font-weight: 400;
}

    .formular .form .edit-link:hover {
        text-decoration: none;
    }

.dropzone {
    background: #fff;
    border: 3px dashed #9fa2ab;
    border-radius: 8px;
    text-align: center;
    font-size: 1.8rem;
    line-height: 3rem;
    color: #013146;
    padding: 100px 20px;
    margin-bottom: 3rem;
}

.passport-photo-container {
    margin: auto;
    width: 291px;
    position: relative;
    z-index: 2;
}

@media screen and ( max-height: 825px ) {
    #canvas,
    #result {
        max-height: 140px;
    }
}

@media (max-width: 580px) {
    .passport-photo-container {
        position: absolute;
    }
}

.passport-photo-container .passport-photo {
    margin-top: 60px;
    border-radius: 4px;
    border: 5px solid #fff;
}

@media (max-width: 767px) {
    .passport-photo-container .passport-photo {
        margin-top: 90px;
    }
}

@media (max-width: 580px) {
    .passport-photo-container .passport-photo {
        margin-top: 3px;
    }
}

.login main {
    height: 100%;
}

.login .page-content {
    background: url(../images/olav-desktop-background.jpg) no-repeat top center;
    background-size: cover;
    height: 100%;
    display: flex;
    align-items: flex-start;
    justify-content: center;
    padding-top: 240px;
}

@media (max-width: 580px) {
    .login .page-content {
        height: auto;
        padding-top: 110px;
        background: #fafafa;
    }
}

.login .footer {
   /* display: none;*/
   position:absolute;
   left:0;
   right:0;
   bottom:0;
}

@media (max-width: 580px) {
    .login .footer {
        display: block;
    }
}

body.mainmenu-visible {
    overflow: hidden;
}

.hidden {
    display: none;
}

.shadow-low {
    box-shadow: 0 2px 2px rgba(0, 0, 0, 0.24);
}

.shadow-mid {
    box-shadow: 0 8px 8px rgba(0, 0, 0, 0.24);
}

.shadow-high {
    box-shadow: 0 24px 24px rgba(0, 0, 0, 0.24);
}

.bg-black {
    background-color: #013146;
}

.bg-grey {
    background-color: #9fa2ab;
}

.bg-snow {
    background-color: #f0f0f0;
}

.bg-orange {
    background-color: #f5a503;
}

.bg-red {
    background-color: #f2385a;
}

.bg-green {
    background-color: #56d9cd;
}

.bg-blue {
    background-color: #3aa1bf;
}

.bg-white {
    background-color: #fff;
}

.bg-primary {
    background-color: #56d9cd;
}

.color-grey {
    color: #9fa2ab !important;
}

.color-warning {
    color: #f5a503 !important;
}

.color-alert {
    color: #f2385a !important;
}

.color-info {
    color: #56d9cd !important;
}

.logo-column {
    width: 100%;
    margin-top: 105px;
    vertical-align: middle;
}

@media (max-width: 1200px) {
    .logo-column {
        margin-top: 0;
    }
}

/*************/
/* Accordion */
/*************/

/* neuen Block hinzufügen */

.accordion {
    margin-bottom: 60px;
}

.accordion__item {
    margin: 3rem 0;
}

.accordion__headline {
    margin-bottom: 1.5rem;
    position: relative;
    padding-left: 65px;
    text-align: left;
    font-size: 2.8rem;
    line-height: 6rem;
    font-weight: 800;
}

@media (max-width: 767px) {
    .accordion__headline {
        font-size: 2.5rem;
        line-height: 3.3rem;
        padding-left: 35px;
    }
}

.accordion__headline::before,
.accordion__headline::after {
    content: "";
    position: absolute;
    left: 0;
    top: 28px;
    height: 5px;
    width: 40px;
    background: #56d9cd;
    border-radius: 18px;
    transition: 0.1s;
}

@media (max-width: 767px) {
    .accordion__headline::before,
    .accordion__headline::after {
        height: 3px;
        width: 18px;
        top: 14px;
    }
}

.accordion__headline::before {
    width: 5px;
    height: 40px;
    top: 10px;
    left: 17px;
}

@media (max-width: 767px) {
    .accordion__headline::before {
        height: 18px;
        width: 3px;
        top: 6px;
        left: 8px;
    }
}

.accordion__headline--small {
    font-size: 3rem;
    line-height: 3.6rem;
    padding-left: 35px;
}

    .accordion__headline--small + .accordion__panel {
        padding-left: 35px;
        width: 100%;
    }

@media (max-width: 580px) {
    .accordion__headline--small + .accordion__panel {
        padding-left: 0;
    }
}

@media (max-width: 580px) {
    .accordion__headline--small {
        font-size: 2.5rem;
        line-height: 3.3rem;
    }
}

.accordion__headline--small::before,
.accordion__headline--small::after {
    height: 3px;
    width: 18px;
    top: 17px;
}

@media (max-width: 580px) {
    .accordion__headline--small::before,
    .accordion__headline--small::after {
        top: 15px;
    }
}

.accordion__headline--small::before {
    height: 18px;
    width: 3px;
    top: 9px;
    left: 8px;
}

@media (max-width: 580px) {
    .accordion__headline--small::before {
        top: 7px;
    }
}

.accordion__headline--expanded::before {
    content: none;
}

.accordion__headline--expanded::after {
    background: #f5a503;
}

.accordion__headline button {
    display: block;
    font: inherit;
    text-align: left;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    cursor: pointer;
    border: 0;
    padding: 0;
    background: transparent;
    color: #013146;
}

.accordion__panel {
    padding-left: 65px;
    width: 90%;
}

@media (max-width: 1200px) {
    .accordion__panel {
        width: 100%;
    }
}

@media (max-width: 767px) {
    .accordion__panel {
        padding-left: 35px;
    }
}

/*****************/
/* Speech Bubble */
/*****************/

/* neuen Block hinzufügen */

.speech-bubble--text-big {
    font-size: 1.8rem;
    line-height: 3rem;
}

@media (max-width: 580px) {
    .speech-bubble--text-big {
        font-size: 1.5rem;
        line-height: 2.4rem;
    }
}

/***************/
/* FORM FIELDS */
/***************/

/* neuen Block hinzufügen */

.field--disabled {
    cursor: not-allowed;
}

    .field--disabled .field__label {
        opacity: 0.3;
    }
/* ändern, angepasste transition von .2s auf .1s */

.mainmenu {
    -webkit-transition: 0.1s;
    transition: 0.1s;
}

/*****************/
/* Formular Form */
/*****************/
/* Verlauf fix */
.formular .form {
    min-height: 100vh; /* an bestehendem Block ändern */
}

/*****************/
/* Ende Seite */
/*****************/

/* neuen Block hinzufügen */

.timetable {
    width: 100%;
    border: solid #f0f0f0;
    border-width: 1px 0 0;
    padding: 25px 0;
}

    .timetable .track {
        display: flex;
        align-items: center;
        flex-wrap: wrap;
        justify-content: space-between;
        cursor: pointer;
        border-radius: 6px;
        padding: 5px;
        transition: 0.1s;
        margin-left: -5px;
        margin-right: -5px;
    }

    .timetable .track--active {
        background: #f0f0f0;
        margin-bottom: 50px;
    }

    .timetable .track__time {
        width: 100%;
        display: flex;
        align-items: center;
        justify-content: space-between;
        margin-bottom: 15px;
    }

        .timetable .track__time .time-period {
            font-size: 1.8rem;
            line-height: 2.5rem;
            font-weight: 700;
        }

        .timetable .track__time .duration {
            font-size: 1.6rem;
            line-height: 2.6rem;
            font-weight: 400;
        }

    .timetable .track__columns {
        padding-top: 10px;
        display: flex;
        width: 100%;
    }

        .timetable .track__columns .column {
            flex: 0 0 auto;
            display: flex;
            align-items: center;
            justify-content: space-between;
            width: 27%;
            min-height: 1px;
        }

        .timetable .track__columns .column--small {
            width: 10%;
        }

    .timetable .track .bus {
        display: flex;
        align-items: center;
        min-width: 106px;
    }

    .timetable .track .bus__icon {
        display: inline-block;
        width: 48px;
        height: 48px;
        background: url(../images/sprite.svg) center center no-repeat;
        background-position: -48px -48px;
        margin-right: 5px;
    }

@media (max-width: 992px) {
    .timetable .track .bus__icon {
        width: 24px;
        height: 24px;
        background-position: -96px -48px;
    }
}

.timetable .track .bus__number {
    min-width: 53px;
    font-size: 1.6rem;
    line-height: 2.4rem;
    font-weight: 700;
    display: inline-flex;
    padding: 4px 13px;
    border: 1px solid #f0f0f0;
    align-content: center;
    justify-content: center;
    border-radius: 8px;
}

.timetable .track .pedestrian {
    width: 48px;
    height: 48px;
    background: url(../images/sprite.svg) center no-repeat;
    background-position: -48px -96px;
}

@media (max-width: 992px) {
    .timetable .track .pedestrian {
        width: 24px;
        height: 24px;
        background-position: -96px -96px;
    }
}

.timetable .track .arrow {
    margin: auto;
    width: 24px;
    height: 24px;
    background: url(../images/sprite.svg) center no-repeat;
    background-position: -72px 0;
}

@media (max-width: 992px) {
    .timetable .track .arrow {
        background-position: -72px -24px;
    }
}

.timetable__routes {
    margin-top: 50px;
}

    .timetable__routes .route {
        margin-bottom: 5px;
        position: relative;
        overflow: hidden;
    }

        .timetable__routes .route::before {
            content: "";
            position: absolute;
            left: 91px;
            top: 12px;
            height: 100%;
            width: 0;
            border-left: 1px dotted #013146;
        }

    .timetable__routes .bus-stop {
        display: flex;
        width: 100%;
        font-size: 1.6rem;
        line-height: 2.4rem;
        font-weight: 700;
    }

    .timetable__routes .bus-stop__time {
        width: 60px;
    }

    .timetable__routes .bus-stop__icon {
        margin: 0 20px;
        background: url(../images/sprite.svg) center no-repeat;
        background-position: -48px 0;
        width: 24px;
        height: 24px;
        position: relative;
    }

    .timetable__routes .bus-info {
        font-size: 1.1rem;
        line-height: 2rem;
        font-weight: 600;
        display: flex;
        align-items: center;
        padding: 50px 0;
        margin-left: 120px;
    }

    .timetable__routes .bus-info__icon {
        background: url(../images/sprite.svg) center no-repeat;
        background-position: -96px -48px;
        width: 24px;
        height: 24px;
    }

    .timetable__routes .bus-info__number {
        display: inline-block;
        margin: 0 10px 0 5px;
    }

/*****************/
/* Cropperjs */
/*****************/

/* neuen Block hinzufügen */

.canvas_wrapper {
    display: none;
}

#canvas,
#result {
    max-height: 650px;
    max-width: 400px;
}

.btn-group-cropper {
    margin-top: 10px;
    display: flex;
    justify-content: space-between;
}

    .btn-group-cropper > .button-crop {
        display: flex;
        flex-direction: column;
        align-items: center;
    }

.button-crop {
    padding: 10px;
    margin-right: 0;
    margin-bottom: 10px;
}

    .button-crop span {
        height: 24px;
        width: 24px;
        display: block;
        background-image: url("../images/iconsset-imagecropped-iconset.svg");
    }

#btnCrop span {
    background-position: -168px 0;
}

#btnRestore span {
    background-position: 0px 0;
}

#btnLeft span {
    background-position: -190px 0;
}

#btnRight span {
    background-position: -216px 0;
}

#btnZoomIn span {
    background-position: -120px 0;
}

#btnZoomOut span {
    background-position: -96px 0;
}

.dropzone {
    position: relative;
}

#fileInput {
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    opacity: 0;
    cursor: pointer;
}

.e-datepicker {
    font-family: "Poppins", "Arial", sans-serif !important;
    -webkit-font-smoothing: antialiased !important;
    font-size: 1.6rem !important;
    line-height: 2.6rem !important;
    font-style: normal !important;
    font-weight: 400 !important;
    color: #013146 !important;
    padding-left : 14px !important;
}


/* Alternative Checkbox mit modernem Hakenstil */
.field__checkbox_alt {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.checkbox-label-alt {
    position: relative;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    cursor: pointer;
    user-select: none;
    color: #013146;
}

/* Box */
.checkbox-box {
    position: relative;
    width: 22px;
    height: 22px;
    border: 2px solid #013146;
    border-radius: 5px;
    background: #fff;
    flex-shrink: 0;
    transition: all 0.25s ease;
    display: flex;
    justify-content: center;
    align-items: center;
}

    /* Haken */
    .checkbox-box::after {
        content: "";
        position: absolute;
        top: 2px;
        width: 6px;
        height: 10px;
        border-right: 3px solid #fff;
        border-bottom: 3px solid #fff;
        transform: rotate(35deg) scale(0);
        opacity: 0;
        transition: all 0.2s ease;
    }

/* Aktivzustand: türkisfarbener Hintergrund + weißer Haken */
.field__checkbox_alt:checked + .checkbox-label-alt .checkbox-box {
    background: #56d9cd;
    border-color: #000000;
}

/* Unsichtbar aber fokussierbar lassen */
.field__checkbox_alt {
    position: absolute;
    opacity: 0;
    /* pointer-events: none;  <- muss WEG */
}

    /* Fallback: funktioniert, wenn :focus-visible auf dem Input feuert */
    .field__checkbox_alt:focus-visible + .checkbox-label-alt .checkbox-box {
        outline: 3px solid #56d9cd;
        outline-offset: 2px;
    }

/* Robust in Chrome: nutze :has() auf dem Wrapper */
.field:has(> .field__checkbox_alt:focus-visible) .checkbox-box {
    outline: 3px solid #56d9cd;
    outline-offset: 2px;
}



 .field__checkbox_alt:checked + .checkbox-label-alt .checkbox-box::after {
        opacity: 1;
        transform: rotate(35deg) scale(1);
 }

/* Hover */
.checkbox-label-alt:hover .checkbox-box {
    background-color: #f0f0f0;
}


/* ✅ Fokusrahmen für Checkbox */
.field__checkbox:focus-visible + .checkbox-label::after,
.field__checkbox_alt:focus-visible + .checkbox-label-alt .checkbox-box {
    outline: 3px solid #2F54DA;
    outline-offset: 2px;
}

/* ✅ Fokusrahmen für Radio */
.field__radio:focus-visible + .radio-label::after {
    outline: 3px solid #2F54DA;
    outline-offset: 2px;
}


.mainmenu {
    opacity: 0;
    visibility: hidden;
    /* transition: opacity 0.3s ease;*/
}

.mainmenu--open {
    opacity: 1;
    visibility: visible;
}

.header .toggle-menu:focus-visible {
    outline: 3px solid #2F54DA;
    outline-offset: 4px;
}

.button:focus-visible {
    outline: 3px solid #2F54DA;
    outline-offset: 4px;
}
/* Language select button (analog zu toggle-menu, aber links) */
.header .language-select {
    display: flex;
    align-items: center;
    gap: .5rem;
    line-height: 2.4rem;
    color: #fff;
    padding: 16px 20px;
    border-radius: 8px;
    cursor: pointer;
    font-weight: 300;
    user-select: none;
    background: rgba(1,49,70,0.5);
    margin-right: auto;
    margin-left: 20px;
    border-width: 1px;
    border-color: #fff;
    border-style: groove;
    /* schiebt Element nach links im Flex-Container */
}
    .header .language-select:focus-visible {
        outline: 3px solid var(--focus-outline-color);
        outline-offset: 2px;
    }
@media (max-width:580px) {
    .header .language-select {
        position: absolute;
        top: 50%;
        left: 0px;
        background: transparent;
        transform: translate(0%, -50%);
        padding: 16px 20px;
        z-index: 96; /* über anderen Header-Inhalten */
        margin-right: 0;
        margin-left: 0px;
        padding-left: 15px;
    }
    .mainmenu-visible .header .language-select { /* ausblenden wenn Menü offen */
        display: none;
    }
    .language-select-text {
        visibility:collapse;
        display: none;
    }
}


.lang-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    border: none;
    border-radius: 8px;
    padding: 6px 12px;
    font-size: 14px;
    font-weight: 500;
    color: #222;
    cursor: pointer;
    box-shadow: 0 1px 3px rgba(0,0,0,0.1);
    transition: background 0.2s, transform 0.1s;
}



.flag {
    width: 30px;
    height: 16px;
    padding-left: 5px;
    border-radius: 2px;
    object-fit: cover;
}


:root {
    --focus-outline-color: #2F54DA;
}

.field__text:focus-visible, .field__textarea:focus-visible, .button:focus-visible, .lang-item:focus-visible, .language-select:focus-visible, .header .toggle-menu:focus-visible, .e-control-wrapper.e-dropdownlist.e-input-focus, .e-control-wrapper.e-ddl.e-input-focus, .e-input-group.e-control-wrapper:focus-within, .blazored-typeahead__input:focus-visible, .blazored-typeahead__results li:focus-visible, .blazored-typeahead__result-item:focus-visible {
    outline: 3px solid var(--focus-outline-color);
    outline-offset: 2px;
    box-shadow: none;
    border-color: var(--focus-outline-color) !important;
}

.blazored-typeahead__controls {
    position: relative;
    border: 1px solid #f0f0f0;
    border-radius:5px; /* normale Abrundung */
}

    /* Fokus-Layer */
    .blazored-typeahead__controls:focus-within::after {
        content: "";
        position: absolute;
        inset: -7px; /* 4 px Abstand außen */
        border: 3px solid var(--focus-outline-color); /* Fokusfarbe */
        border-radius: 10px; /* Radius für den Fokusrahmen */
        pointer-events: none; /* blockiert keine Klicks */
  
        /* box-shadow: 0 0 6px rgba(26, 115, 232, .3);*/ /* optional Glow */
    }


*:focus,
*:focus-within {
    transition: none !important;
}


.dropzone:focus-within {
    outline: 4px solid var(--focus-outline-color);
    outline-offset: 4px;
    border-radius: 8px;
}