/* open-sans-300 - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 300;
  src: url('../fonts/open-sans-v40-latin-300.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* open-sans-300italic - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Open Sans';
  font-style: italic;
  font-weight: 300;
  src: url('../fonts/open-sans-v40-latin-300italic.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* open-sans-regular - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 400;
  src: url('../fonts/open-sans-v40-latin-regular.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* open-sans-italic - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Open Sans';
  font-style: italic;
  font-weight: 400;
  src: url('../fonts/open-sans-v40-latin-italic.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* open-sans-500 - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 500;
  src: url('../fonts/open-sans-v40-latin-500.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* open-sans-500italic - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Open Sans';
  font-style: italic;
  font-weight: 500;
  src: url('../fonts/open-sans-v40-latin-500italic.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* open-sans-600 - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 600;
  src: url('../fonts/open-sans-v40-latin-600.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* open-sans-600italic - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Open Sans';
  font-style: italic;
  font-weight: 600;
  src: url('../fonts/open-sans-v40-latin-600italic.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* open-sans-700 - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 700;
  src: url('../fonts/open-sans-v40-latin-700.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* open-sans-700italic - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Open Sans';
  font-style: italic;
  font-weight: 700;
  src: url('../fonts/open-sans-v40-latin-700italic.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* roboto-300 - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 300;
  src: url('../fonts/roboto-v30-latin-300.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* roboto-regular - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 400;
  src: url('../fonts/roboto-v30-latin-regular.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}

html{line-height:1.15;-ms-text-size-adjust:100%;-webkit-text-size-adjust:100%}body{margin:0}article,aside,footer,header,nav,section{display:block}figcaption,figure,main{display:block}figure{margin:1em 40px}hr{box-sizing:content-box;height:0;overflow:visible}pre{font-family:monospace,monospace;font-size:1em}a{background-color:transparent;-webkit-text-decoration-skip:objects}abbr[title]{border-bottom:none;text-decoration:underline;text-decoration:underline dotted}b,strong{font-weight:inherit}b,strong{font-weight:bolder}code,kbd,samp{font-family:monospace,monospace;font-size:1em}dfn{font-style:italic}mark{background-color:#ff0;color:#000}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}audio,video{display:inline-block}audio:not([controls]){display:none;height:0}img{border-style:none}svg:not(:root){overflow:hidden}button,input,optgroup,select,textarea{font-family:sans-serif;font-size:100%;line-height:1.15;margin:0}button,input{overflow:visible}button,select{text-transform:none}button,html [type="button"],[type="reset"],[type="submit"]{-webkit-appearance:button}button::-moz-focus-inner,[type="button"]::-moz-focus-inner,[type="reset"]::-moz-focus-inner,[type="submit"]::-moz-focus-inner{border-style:none;padding:0}button:-moz-focusring,[type="button"]:-moz-focusring,[type="reset"]:-moz-focusring,[type="submit"]:-moz-focusring{outline:1px dotted ButtonText}fieldset{padding:.35em .75em .625em}legend{box-sizing:border-box;color:inherit;display:table;max-width:100%;padding:0;white-space:normal}progress{display:inline-block;vertical-align:baseline}textarea{overflow:auto}[type="checkbox"],[type="radio"]{box-sizing:border-box;padding:0}[type="number"]::-webkit-inner-spin-button,[type="number"]::-webkit-outer-spin-button{height:auto}[type="search"]{-webkit-appearance:textfield;outline-offset:-2px}[type="search"]::-webkit-search-cancel-button,[type="search"]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}details,menu{display:block}summary{display:list-item}canvas{display:inline-block}template{display:none}[hidden]{display:none}h1,h2,h3,h4,h5,h6,ul,p,li,ul,a{margin:0;padding:0}ul{list-style:none}html{overflow-y:scroll}a:hover,a:active{outline:none}textarea{overflow:auto}label{cursor:pointer}html,body,main{width:100%;height:auto;}*{-moz-box-sizing:border-box;-webkit-box-sizing:border-box;box-sizing:border-box}audio,canvas,iframe,img,svg,video{vertical-align:middle}fieldset{border:0;margin:0;padding:0}textarea{resize:vertical}.browserupgrade{margin:.2em 0;background:#ccc;color:#000;padding:.2em 0}.hidden{display:none!important}.visuallyhidden{border:0;clip:rect(0 0 0 0);-webkit-clip-path:inset(50%);clip-path:inset(50%);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px;white-space:nowrap}.visuallyhidden.focusable:active,.visuallyhidden.focusable:focus{clip:auto;-webkit-clip-path:none;clip-path:none;height:auto;margin:0;overflow:visible;position:static;width:auto;white-space:inherit}.invisible{visibility:hidden}.clearfix:before,.clearfix:after{content:" ";display:table}.clearfix:after{clear:both}@media print,(-webkit-min-device-pixel-ratio:1.25),(min-resolution:1.25dppx),(min-resolution:120dpi){}@media print{*,*:before,*:after{background:transparent!important;color:#000!important;box-shadow:none!important;text-shadow:none!important}a,a:visited{text-decoration:underline}a[href]:after{content:" (" attr(href) ")"}abbr[title]:after{content:" (" attr(title) ")"}a[href^="#"]:after,a[href^="javascript:"]:after{content:""}pre{white-space:pre-wrap!important}pre,blockquote{border:1px solid #999;page-break-inside:avoid}thead{display:table-header-group}tr,img{page-break-inside:avoid}p,h2,h3{orphans:3;widows:3}h2,h3{page-break-after:avoid}}

html,
body,
input,
textarea {
    color: #666666;
    font: 16px/27px 'Open Sans', sans-serif;
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale
}

.wrapper {
    width: 80%;
    margin: 0 auto;
}

html,
section,
body {
    overflow-y: inherit!important;
}

 * {
      box-sizing: border-box;
}

a {
    color: #3F3C39;
    text-decoration: none;
    transition: all 1s ease;
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale
}

a:hover,
a:focus,
a,
footer,
section,
article,
div {
    outline: none!important
}

h1 {
    font-size: 39px;
    line-height: 1.2;
    margin-left: 60px;
}

h2 {
    color: #123883;
    font-size: 39px;
    line-height: 1.2;
    margin-bottom: 15px;
}

h3 {
    font-size: 23px;
    font-weight: 700;
    font-style: italic;
    line-height: 1.3;
    margin-bottom: 15px;
    color: #3a3a3a;
}

h4,
h5,
h6 {}


/* ==========================================================================
   header
   ========================================================================== */

header {
    background: url(../images/projekte-mit-3d-laserscanning.jpg)no-repeat center center / cover;
    width: 100%;
    height: 95vH;
    position: relative;
    background-attachment: fixed;
}

.bg-content-header {
    background: url(../images/bg-header.jpg)no-repeat center center / cover;
    width: 50%;
    height: 95vH;
    position: absolute;
    right: 0;
    z-index: 1;
    mix-blend-mode: multiply;
}


.box-content {
    width: 50%;
    position: absolute;
    right: 0;
    z-index: 2;
    color: #fff;
    bottom: 10vH;
}

header hr {
    border: 1px solid #fff;
    margin-left: 30px;
    margin-bottom: 50px;
}

.logo {
    padding: 0 0 50px 60px;
    width: 360px
}

.box-content p {
    padding: 15px 0 40px 60px;
    width: 650px;
}

.box-content a, .cta a {
    background-color: #fff;
    color: #123883;
    font-size: 18px;
    font-weight: 600;
    font-style: italic;
    padding: 12px 40px;
    margin-left: 60px;
}

.box-content a:hover, .cta a:hover,
#gewerbe a:hover {
    background-color: #091d44;
    color: #fff;
}

/* ==========================================================================
   navi
   ========================================================================== */

aside {
    position: fixed;
    left: 25px;
    bottom: 10vH;
    z-index: 10001
}

aside ul li {
    background-color: #123883;
    padding: 10px;
    margin-bottom: 15px;
    transition: all 1s ease;
}

aside ul li:hover {
    background-color: #091d44;
}

aside ul li img {
    width: 35px;
}

.burger-nav.menu-fixed {
    position: fixed;
    background-color: rgba(18, 56, 131, 0.95);
}

.burger-nav {
    position: fixed;
    right: 3%;
    top: 35px;
    color: #fff;
    z-index: 9999;
    -webkit-transform: rotate(-90deg);
    transform: rotate(-90deg);
    font-size: 50px;
    cursor: pointer;
    transition: all .4s ease-in-out;
    padding: 16px 14px 22px 14px;
    display: block;
}

.burger-nav b {
    transition: all .4s ease-in-out;
    float: left;
    margin-left: 0;
    font-family: 'Roboto';
    font-style: normal;
    font-weight: 300;
}

.burger-nav-anim {
    top: -5px;
    color: #fff;
}

.burger-nav-anim b:first-of-type {
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
}

.burger-nav-anim b:nth-of-type(2) {
    opacity: 0;
}

.burger-nav-anim b:last-of-type {
    -webkit-transform: rotate(-45deg);
    transform: rotate(-45deg);
    margin-left: -80%;
}

.full-screen-nav {
    position: fixed;
    z-index: 9998;
    width: 100%;
    height: 100vh;
    background: url(../images/pattern-bg-nav.png)no-repeat left top / cover;
    display: table;
    visibility: hidden;
    transition: all .4s ease-in-out;
    opacity: 0;
}

.full-screen-nav ul {
    text-align: center;
    display: table-cell;
    vertical-align: middle;
    width: 100%;
}

.full-screen-nav ul .nav-li,
.full-screen-nav ul li a {
    padding: 10px 20px;
    display: block;
    font-size: 20px;
    color: #fff;
    transition: all .4s ease-in-out;
    text-decoration: none;  
    font-weight: 600;
    font-style: italic;
    text-transform: uppercase;
}

.full-screen-nav ul .nav-li {
    text-decoration: underline;
    font-style: italic;
}

.fadeIn {
    opacity: 1 !important;
    visibility: visible !important;
}

.fadeUp {
    opacity: 1 !important;
    margin-top: 0 !important;
}


/******************************* 
section1
*******************************/

#laserscanner, #gewerbe {
    background: url(../images/pattern-bg-weiss.jpg)no-repeat left top / cover;
    padding: 200px 0 150px 0;
    position: relative;
}

.flex-container {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
}

.flex-item:nth-child(1) {
    width: 50%;
    padding-right: 50px;
}

.flex-item:nth-child(2) {
    width: 50%;
    padding-left: 50px;
}

.slider-1, .slider-2 {
    position: relative;
    z-index: 1;
}

.slider-1 img, .slider-2 img {
    width: 100%;
}

video {
    width: 100%;
    position: relative;
    z-index: 1;
}

#laserscanner .flex-item:nth-child(1) {
    padding-left: 10%;
}

#gewerbe .flex-item:nth-child(2) {
    padding-right: 10%;
}

#laserscanner .flex-item:nth-child(2),
#gewerbe .flex-item:nth-child(1) {
    padding-right: 4%;
    padding-left: 100px;
    position: relative;
}

#laserscanner .flex-item:nth-child(1) img,
#gewerbe .flex-item:nth-child(2) img {
    width: 65px;
    margin-bottom: 15px;
}

.blue-bg {
    background-color: #123883;
    width: 82%;
    height: 535px;
    position: absolute;
    top: -53px;
    right: 0;
    z-index: 0;
}

#gewerbe .blue-bg {
    right: auto;
    left: 0;
}

#gewerbe a {
    background-color: #123883;
    color: #fff;
    font-size: 18px;
    font-weight: 600;
    font-style: italic;
    padding: 12px 40px;
}

#gewerbe .accordion {
    padding: 120px 0 0 0;
}

/******************************* 
section2
*******************************/

.cta {
    background: url(../images/ma-beim-auswerten-des-laserscannings.jpg)no-repeat left top / cover;
    background-attachment: fixed;
    padding: 180px 0;
    position: relative;
    text-align: center;
}

.cta h2 {
    color: #fff;
    font-size: 48px;
}

.cta a {
    margin-left: 0;
    font-size: 25px;
    padding: 14px 40px;
}

.cta-2 {
    padding: 50px 0;
    text-align: center;
}

.cta-2 h2 {
    font-size: 24px;
    font-style: italic;
}

.cta-2 a {
    font-weight: 600;
    text-decoration: underline;
}

.cta-2 a:hover {
    text-decoration: none;
    color: #123883;
}

/******************************* 
section3
*******************************/

#vorteile {
    padding: 100px 0 150px 0;
    background: url(../images/pattern-bg.jpg)no-repeat left top / cover;
    color: #fff;
}

.top-content {
    text-align: center;
    margin-bottom: 75px;
}

.top-content h2 {
    color: #fff;
    text-transform: uppercase;
}

.top-content img {
    width: 70px;
    margin-bottom: 10px;
}

#vorteile h3 {
    color: #fff;
    font-size: 20px;
    margin-bottom: 20px;
    font-style: normal;
}

#vorteile h4 {
    color: #fff;
    padding-left: 10px;
    border-left: 3px solid #fff;
    font-weight: 700;
    font-style: italic;
    text-transform: uppercase;
    margin-bottom: 15px;
}

#vorteile .slick-slide {
    padding: 0 50px;
}

#vorteile .slick-dots {
    width: 100%;
    bottom: -70px
}

#vorteile .slick-dots li.slick-active button::before {
    opacity: 1;
    color: #fff;
}

#vorteile .slick-dots li button::before {
    color: #3f5e9a;
    font-size: 35px;
}

#vorteile .slider-content {
    padding: 15px;
    position: relative;
    z-index: 1;  
}

.slider-inline {
    position: relative;
    z-index: 1;    
}

#vorteile .number {
    position: absolute;
    left: -65px;
    font-size: 245px;
    color: #0f295d;
    z-index: 0;  
    top: 77px;
    font-weight: 600;
}

/******************************* 
section4
*******************************/

#kontakt {
    padding: 200px 0 150px 0;
    background: url(../images/3d-laser-scanner.jpg)no-repeat center right / cover;
    color: #fff;    
}

#kontakt .flex-container {
    align-items: flex-start;
}

#kontakt h2 {
    color: #fff;
    font-style: italic;
}

#kontakt iframe {
    border: none;
    width: 100%;
    height: 700px;
}

#kontakt p + p {
    margin-top: 20px;
}

#kontakt a {
    color: #fff;
    text-decoration: underline;
}

/******************************* 
section5
*******************************/

/******************************* 
section6
*******************************/

/******************************* 
section7
*******************************/

/******************************* 
section8
*******************************/

/* ==========================================================================
   Slider
   ========================================================================== */

.slick-slider {
    position: relative;
    display: block;
    box-sizing: border-box;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    -webkit-touch-callout: none;
    -khtml-user-select: none;
    -ms-touch-action: pan-y;
    touch-action: pan-y;
    -webkit-tap-highlight-color: transparent;
}

.slick-list {
    position: relative;
    display: block;
    overflow: hidden;
    margin: 0;
    padding: 0;
}

.slick-list:focus {
    outline: none;
}

.slick-list.dragging {
    cursor: pointer;
    cursor: hand;
}

.slick-slider .slick-track,
.slick-slider .slick-list {
    -webkit-transform: translate3d(0, 0, 0);
    -moz-transform: translate3d(0, 0, 0);
    -ms-transform: translate3d(0, 0, 0);
    -o-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
}

.slick-track {
    position: relative;
    top: 0;
    left: 0;
    display: block;
    margin-left: auto;
    margin-right: auto;
}

.slick-track:before,
.slick-track:after {
    display: table;
    content: '';
}

.slick-track:after {
    clear: both;
}

.slick-loading .slick-track {
    visibility: hidden;
}

.slick-slide {
    display: none;
    float: left;
    height: 100%;
    min-height: 1px;
}

[dir='rtl'] .slick-slide {
    float: right;
}

.slick-slide img {
    display: block;
}

.slick-slide.slick-loading img {
    display: none;
}

.slick-slide.dragging img {
    pointer-events: none;
}

.slick-initialized .slick-slide {
    display: block;
}

.slick-loading .slick-slide {
    visibility: hidden;
}

.slick-vertical .slick-slide {
    display: block;
    height: auto;
    border: 1px solid transparent;
}

.slick-arrow.slick-hidden {
    display: none;
}

.slick-loading .slick-list {
    background: #fff url(../images/ajax-loader.gif) center center no-repeat;
}

/* Icons */
@font-face {
    font-family: 'slick';
    font-weight: normal;
    font-style: normal;
    src: url(../fonts/slick.eot);
    src: url(../fonts/slick.eot?#iefix) format('embedded-opentype'), url(../fonts/slick.woff) format('woff'), url(../fonts/slick.ttf) format('truetype'), url(../fonts/slick.svg#slick) format('svg');
}
/* Arrows */
.slick-prev,
.slick-next {
    font-size: 0;
    line-height: 0;
    position: absolute;
    top: 50%;
    display: block;
    width: 20px;
    height: 20px;
    padding: 0;
    -webkit-transform: translate(0, -50%);
    -ms-transform: translate(0, -50%);
    transform: translate(0, -50%);
    cursor: pointer;
    color: transparent;
    border: none;
    outline: none;
    background: transparent;
}

.slick-prev:hover,
.slick-prev:focus,
.slick-next:hover,
.slick-next:focus {
    color: transparent;
    outline: none;
    background: transparent;
}

.slick-prev:hover:before,
.slick-prev:focus:before,
.slick-next:hover:before,
.slick-next:focus:before {
    opacity: 1;
}

.slick-prev.slick-disabled:before,
.slick-next.slick-disabled:before {
    opacity: .25;
}

.slick-prev:before,
.slick-next:before {
    font-family: 'slick';
    font-size: 20px;
    line-height: 1;
    opacity: .75;
    color: white;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

.slick-prev {
    left: -25px;
}

[dir='rtl'] .slick-prev {
    right: -25px;
    left: auto;
}

.slick-prev:before {
    content: '←';
}

[dir='rtl'] .slick-prev:before {
    content: '→';
}

.slick-next {
    right: -25px;
}

[dir='rtl'] .slick-next {
    right: auto;
    left: -25px;
}

.slick-next:before {
    content: '→';
}

[dir='rtl'] .slick-next:before {
    content: '←';
}

/* Dots */
.slick-dotted.slick-slider {
    margin-bottom: 30px;
}

.slick-dots {
    position: absolute;
    bottom: -25px;
    display: block;
    width: 235px;
    padding: 0;
    margin: 0;
    list-style: none;
    text-align: center;
}

.slick-dots li {
    position: relative;
    display: inline-block;
    width: 25px;
    height: 20px;
    margin: 0 5px;
    padding: 0;
    cursor: pointer;
}

.slick-dots li:nth-child(1) {
    margin-left: 0;
}
.slick-dots li button:nth-child(1) {
    padding-left: 0;
}

.slick-dots li:last-of-type {
    margin-right: 0;
}

.slick-dots li button:last-of-type {
    padding-right: 0;
}

.slick-dots li button {
    font-size: 0;
    line-height: 0;
    display: block;
    width: 20px;
    height: 20px;
    padding: 5px;
    cursor: pointer;
    color: transparent;
    border: 0;
    outline: none;
    background: transparent;
}

.slick-dots li button:hover,
.slick-dots li button:focus {
    outline: none;
}

.slick-dots li button:hover:before,
.slick-dots li button:focus:before {
    opacity: 1;
}

.slick-dots li button:before {
    font-family: 'slick';
    font-size: 40px;
    line-height: 20px;
    position: absolute;
    top: 0;
    left: 0;
    width: 20px;
    height: 20px;
    content: '■';
    text-align: center;
    opacity: 1;
    color: #f4f4f4;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

.slick-dots li.slick-active button:before {
    opacity: 1;
    color: #123883;
}

#gewerbe .slick-dots {
    width: 170px;
    right: 0;
}

/******************************* 
acordeon
*******************************/

.acc {
    text-align: left
}

.tab {
    position: relative;
    margin-bottom: 20px;
    width: 100%;
    color: #666666;
    overflow: hidden;
    border-bottom: 3px solid #123883;
}

.acc input {
    position: absolute;
    opacity: 0;
    z-index: -1;
}

.acc label {
    position: relative;
    display: block;
    padding: 15px 50px 29px 1em;
    font-weight: bold;
    line-height: 1.2;
    cursor: pointer;
    font-size: 24px;
    color: #123883;
}

.tab-content {
    max-height: 0;
    overflow: hidden;
    -webkit-transition: max-height .35s;
    -o-transition: max-height .35s;
    transition: max-height .35s;
}

.tab span {
    margin-left: 20px
}

.tab-content ul {
    margin-left: 15px;
}

.tab-content ul li {
    list-style: square;
    font-size: 14px;
    padding-bottom: 5px;
}

.acc input:checked ~ .tab-content {
    max-height: 50em;
    padding: 20px 50px 30px 1em;
}

.acc label::after {
    position: absolute;
    right: 15px;
    top: 12px;
    display: block;
    width: 30px;
    height: 30px;
    line-height: 3;
    text-align: center;
    -webkit-transition: all .35s;
    -o-transition: all .35s;
    transition: all .35s;
}

.acc input[type=checkbox] + label::after {
    content: url(../images/down-arrow.svg);
}

.acc input[type=radio] + label::after {}

.acc input[type=checkbox]:checked + label::after {
    transform: rotate(180deg);
}

.acc input[type=radio]:checked + label::after {
    transform: rotateX(180deg);
}

/* ==========================================================================
   footer
   ========================================================================== */


.daten {
    position: fixed;
    bottom: 0;
    background-color: #dbdbdb;
    width: 100%;
    height: 30px;
    z-index: 1000;
    padding: 0 10%;
    color: #123883;
    font-size: 14px;
}

.daten a {
    font-size: 14px;
    color: #123883;
}

/******************************* 
textmarkierungen
*******************************/

::selection {
    background: #000;
    color: #fff;
    text-shadow: none
}

::-moz-selection {
    background: #000;
    color: #fff;
    text-shadow: none
}

/* ==========================================================================
   Google Maps und Cookie Hinweis
   ========================================================================== */

.clear{clear:both;}
.cookie-page1{transition: visibility 0s, opacity 0.5s linear;}
.cookie-page2{visibility:hidden; float:none; width:100%; opacity: 0; transition: visibility 0s, opacity 0.5s linear;}
.cookie-page2.show-page{visibility:visible; opacity: 1; transition: visibility 0s, opacity 0.5s linear;}
.cookie-page2 strong{font-size:18px; margin-bottom:10px;}
.cookie-page2 a{color:black; font-size:16px; line-height:24px; display:inline-block; text-decoration: none; padding:10px 10px 10px 30px; border-radius:5px;
background-image: url('data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAABmJLR0QA/wD/AP+gvaeTAAAAmUlEQVRIie2VQQ6DIBQFJ72DpEfS3sQe1y66V+5RN5CaqJ8nUDd2EsKG9wYNAfhzkAfggY8xIsqaFVMiWCxILtigAYZfCRzwCpk4VxMsd/4G7jUFW+VSXhHslVcRWOUSlqC43BKo5Vm/6MjOswRPvufcWeFcAUAvlBcJVFb5W0GZxOkCH+bUlW1d06Ml7NDehL0xAm3Gh16ZGZhnhhStKN5+AAAAAElFTkSuQmCC');
background-size:12px 12px; background-repeat: no-repeat; background-position: 10px 16px; background-color:#d8d8d8;}
.cookie-page2 a.back-to-cookie{ display:block; width:80%; max-width:100px; margin:30px 0;
background-repeat: no-repeat;
background-size: 12px 12px;
background-image:url('data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAABmJLR0QA/wD/AP+gvaeTAAAAY0lEQVRIie2UMQqAMBAEJ2Lhs3yR+hTt/I4f89JEBBHiQa4QdiCkCMzkigSEeCGVFSbfgD0icskNOIExUj5J3kzeVc7tEWxOAlbuKWZFahH3Q+sdAQOWsg/A4bvfd0I/O/FDMq2DH/bYYYYxAAAAAElFTkSuQmCC');
background-position: 10px 16px;
background-color:#d8d8d8}
.cookie-overlay-dsa.show-cookie{display:block;}
.cookie-overlay-dsa{display:none; background-color: rgba(214,214,214, 0.60); position: fixed; z-index:99999999; top:0; height:100vh; width:100vw; line-height:20px;}
.dsa-cookie-notice-form{min-height:300px; width:500px; z-index:9999999999; position: absolute; top: 40%; left:calc(48% - 250px);  background-color:white; border-radius:5px; padding:2%;}
.dsa-cookie-notice-form fieldset p{margin-bottom:15px;text-align: center;}
.dsa-cookie-notice-form  .cookie-item{width:33.33%;float:left; text-align: center}
.cookie-overlay-headline{text-align: center; display:block; font-size:20px; font-weight: 500; font-style: italic; color: #123883; margin-bottom:15px;}
.dsa-cookie-notice-form fieldset label{cursor: pointer;}
#dsa-check-all.dsa-cookie-button{background-color:#123883; margin-top:15px; color: #fff;}
.dsa-cookie-button{border-radius:5px; display:block; margin:0 50px; background-color:#d8d8d8; margin-bottom:5px; padding:10px 20px; text-align: center; text-decoration: none; color:#123883;}
.dsa-cookie-notice-form input[type="checkbox"] {display:none;}
.dsa-cookie-notice-form input[type="checkbox"] + label::before {width: 15px;height: 15px; border: 2px solid #123883; background-color: #fff; display: block; content: ""; margin: 10px auto;}
.dsa-cookie-notice-form input[type="checkbox"]:checked+label::before {  box-shadow: inset 0px 0px 0px 3px #fff;  background-color: #123883;}
.dsa-cookie-notice-form input[type="checkbox"]:disabled+label::before{box-shadow: inset 0px 0px 0px 3px #fff; background-color:grey;}
.cookie-notice-verwendung, .cookie-notice-link{display:inline-block; text-align: center; margin:10px auto 0 auto; text-decoration: none; color:grey;}
.cookie-end-links{width:80%; margin:auto; text-align: center}
@media screen and (max-width: 550px){.dsa-cookie-notice-form{width:86%; left:2.0%; padding:5%;}.cookie-notice-link{margin-top:25px;}}
@media screen and (max-height: 570px){.dsa-cookie-notice-form{top:20%;}}

/* ==========================================================================
   media Queries
   ========================================================================== */

@media screen and (max-width: 1800px) {
    .blue-bg {
        height: 400px;
    }
}

@media screen and (max-width: 1400px) {
    .bg-content-header, .box-content {
        width: 70%;
    }
    .wrapper {
        width: 90%;
    }
    #laserscanner, #gewerbe {
        padding: 150px 0
    }
    #laserscanner .flex-item:nth-child(1),
    #gewerbe .flex-item:nth-child(1) {
        padding-left: 5%;
    }
    #laserscanner .flex-item:nth-child(2),
    #gewerbe .flex-item:nth-child(2) {
        padding-right: 5%;
    }
    .blue-bg {
        height: 300px;
    }
}

@media screen and (max-width: 1366px) {
    header, .cta {
        background-attachment: scroll;
    }
}

@media screen and (max-width: 1100px) {
    .blue-bg {
        height: 250px;
    }
}

@media screen and (max-width: 980px) {
    .bg-content-header, .box-content {
        width: 90%;
    } 
    .box-content p {
        width: 100%;
        padding: 15px 5% 40px 60px
    }
    h1 {
        padding-right: 5%;
        font-size: 30px;
    }
    #laserscanner .flex-item:nth-child(1),
    #gewerbe .flex-item:nth-child(1),
    #kontakt .flex-item:nth-child(1),
    #laserscanner .flex-item:nth-child(2),
    #gewerbe .flex-item:nth-child(2),
    #kontakt .flex-item:nth-child(2) {
        width: 100%;
        padding-left: 0;
        padding-right: 0;
    }
    #laserscanner .flex-container,
    #gewerbe .flex-container {
        margin: 0 5%;
    }
    #laserscanner .flex-item:nth-child(1),
    #kontakt .flex-item:nth-child(1) {
        margin-bottom: 50px;
    }
    #gewerbe .flex-container {
        flex-direction: column-reverse;
    }
    #gewerbe .flex-item:nth-child(2) {
        margin-bottom: 70px;
    }
    #gewerbe .accordion .flex-item:nth-child(2) {
        margin-bottom: 0;
    }
    .blue-bg {
        display: none;
    }
    #kontakt {
        padding: 120px 0;
    }
    .cta {
        padding: 150px 0;
    }
    h2, .cta h2 {
        font-size: 30px;
    }
    .cta a {
        font-size: 18px;
    }
    #kontakt iframe {
        height: 600px;
    }
    #vorteile .slick-slide {
        padding: 0;
    }
    #vorteile .number {
        left: -10px;
    }
}

@media screen and (max-width: 560px) {
    .bg-content-header, .box-content {
        width: 100%;
    }
    .logo {
        width: 300px;
        padding: 0 0 30px 60px;
    }
    header hr {
        margin-bottom: 30px;
    }
    h1, header hr, .box-content a {
        margin-left: 5%;
    }
    h1 {
        font-size: 26px;
    }
    .box-content p, .logo {
        padding-left: 5%;
    }
    aside {
        bottom: 5vH;
        left: 5%;
    }
    aside ul li {
        display: inline-block;
        margin-right: 15px;
    }
    .daten {
        padding: 0 5%;
    }
    .acc label {
        font-size: 18px;
    }
    #gewerbe a, .cta a, .box-content a {
        font-size: 16px;
        padding: 12px 30px;
    }
}


@media screen and (max-width: 400px) {
    
    * {
        hyphens: auto;
        -moz-hyphens: auto;
        -o-hyphens: auto;
        -webkit-hyphens: auto;
        -ms-hyphens: auto;
    }
}
