@charset "UTF-8";
/*

@font-face { // light
	font-family: "source";
	src: url("../css_fonts/SourceSerifPro_lt.woff2") format("woff2");
	font-weight: 200;
	font-style: normal;
}

@font-face { // regular
	font-family: "source";
	src: url("../css_fonts/SourceSerifPro_rg.woff2") format("woff2");
	font-weight: 400;
	font-style: normal;
}

@font-face { // semibold
	font-family: "source";
	src: url("../css_fonts/SourceSerifPro_sb.woff2") format("woff2");
	font-weight: 500;
	font-style: normal;
}

@font-face { // bold
	font-family: "source";
	src: url("../css_fonts/SourceSerifPro_bd.woff2") format("woff2");
	font-weight: 700;
	font-style: normal;
}

@font-face { // italic
	font-family: "source";
	src: url("../css_fonts/SourceSerifPro_it.woff2") format("woff2");
	font-weight: 200;
	font-style: italic;
}

@font-face { // light
	font-family: "redhat";
	src: url("../css_fonts/RedHatDisplay_lt.woff2") format("woff2");
	font-weight: 200;
	font-style: normal;
}

@font-face { // regular
	font-family: "redhat";
	src: url("../css_fonts/RedHatDisplay_rg.woff2") format("woff2");
	font-weight: 400;
	font-style: normal;
}

@font-face { // semibold
	font-family: "redhat";
	src: url("../css_fonts/RedHatDisplay_md.woff2") format("woff2");
	font-weight: 500;
	font-style: normal;
}

@font-face { // bold
	font-family: "redhat";
	src: url("../css_fonts/RedHatDisplay_sb.woff2") format("woff2");
	font-weight: 700;
	font-style: normal;
}

@font-face { // light italic
	font-family: "redhat";
	src: url("../css_fonts/RedHatDisplay_li.woff2") format("woff2");
	font-weight: 200;
	font-style: italic;
}

@font-face { // italic
	font-family: "redhat";
	src: url("../css_fonts/RedHatDisplay_it.woff2") format("woff2");
	font-weight: 400;
	font-style: italic;
}

*/
@font-face {
  font-family: 'notoserif';
  src: url("../css_fonts/notoserif-lt.woff2") format("woff2");
  font-weight: 200;
  font-style: normal; }

@font-face {
  font-family: 'notoserif';
  src: url("../css_fonts/notoserif-rg.woff2") format("woff2");
  font-weight: 400;
  font-style: normal; }

@font-face {
  font-family: 'notoserif';
  src: url("../css_fonts/notoserif-sb.woff2") format("woff2");
  font-weight: 500;
  font-style: normal; }

@font-face {
  font-family: 'notoserif';
  src: url("../css_fonts/notoserif-bd.woff2") format("woff2");
  font-weight: 700;
  font-style: normal; }

@font-face {
  font-family: 'notoserif';
  src: url("../css_fonts/notoserif-li.woff2") format("woff2");
  font-weight: 200;
  font-style: italic; }

@font-face {
  font-family: 'notoserif';
  src: url("../css_fonts/notoserif-it.woff2") format("woff2");
  font-weight: 400;
  font-style: italic; }

@font-face {
  font-family: 'opensans';
  src: url("../css_fonts/opensans-lt.woff2") format("woff2");
  font-weight: 200;
  font-style: normal; }

@font-face {
  font-family: 'opensans';
  src: url("../css_fonts/opensans-rg.woff2") format("woff2");
  font-weight: 400;
  font-style: normal; }

@font-face {
  font-family: 'opensans';
  src: url("../css_fonts/opensans-sb.woff2") format("woff2");
  font-weight: 500;
  font-style: normal; }

@font-face {
  font-family: 'opensans';
  src: url("../css_fonts/opensans-bd.woff2") format("woff2");
  font-weight: 700;
  font-style: normal; }

@font-face {
  font-family: 'opensans';
  src: url("../css_fonts/opensans-li.woff2") format("woff2");
  font-weight: 200;
  font-style: italic; }

@font-face {
  font-family: 'opensans';
  src: url("../css_fonts/opensans-it.woff2") format("woff2");
  font-weight: 400;
  font-style: italic; }

@font-face {
  font-family: 'opensans';
  src: url("../css_fonts/opensans-si.woff2") format("woff2");
  font-weight: 500;
  font-style: italic; }

@font-face {
  font-family: 'opensans';
  src: url("../css_fonts/opensans-bi.woff2") format("woff2");
  font-weight: 700;
  font-style: italic; }

@font-face {
  font-family: 'icon';
  src: url("../css_fonts/icons.woff") format("woff");
  font-weight: normal;
  font-style: normal; }

* {
  border: 0;
  margin: 0;
  padding: 0;
  text-decoration: none;
  background: transparent;
  box-sizing: border-box; }

html {
  min-height: 100%;
  font-size: 100%;
  font-weight: 400;
  line-height: 1.5rem;
  height: -webkit-fill-available;
  font-style: normal; }
  html.iframe {
    font-size: 90%; }
  html.medium {
    font-size: 85%; }
  html.small {
    font-size: 80%; }
  html.tiny {
    font-size: 75%; }
  html.microscopic {
    font-size: 70%; }

body {
  background: #283750;
  font-family: 'notoserif', serif;
  font-weight: 400;
  font-size: 1.125rem;
  line-height: 1.625rem;
  margin: 0 0 calc(320px - 1.0rem) 0;
  margin: 0;
  min-height: 100vh;
  min-height: -webkit-fill-available; }
  body.modal {
    overflow: hidden; }
  body.photos, body.photos_album {
    background-color: #283750; }
  body.fixed {
    position: fixed;
    left: 0;
    top: 0;
    width: 100vw;
    height: 100vh; }

header, main, footer {
  width: 100%; }

img {
  display: block; }

span.copyright {
  position: absolute;
  font-family: 'opensans', sans-serif;
  font-weight: 400;
  font-size: 0.625rem;
  line-height: 0.875rem;
  left: 0.875rem;
  top: 0;
  color: white;
  text-transform: uppercase;
  max-height: 0.875rem;
  background: rgba(0, 0, 0, 0.8);
  padding: 0 0.25rem;
  opacity: 1;
  overflow: hidden;
  transform: rotate(90deg);
  transform-origin: top left; }

ul li {
  list-style-type: none;
  position: relative;
  margin: 0;
  padding: 0; }

button {
  cursor: pointer; }

.xx {
  display: none; }

.clear {
  clear: both; }

.preloader {
  width: 100vw;
  height: 100vh;
  background: white;
  position: fixed;
  z-index: 9999;
  pointer-events: none; }
  .preloader .custom-loader {
    position: absolute;
    top: calc(50% - 25px);
    left: calc(50% - 25px);
    width: 50px;
    height: 50px;
    display: grid;
    border: 4px solid white;
    border-radius: 50%;
    border-color: #dc6400 white;
    animation: s6 1s infinite linear; }
    .preloader .custom-loader::before, .preloader .custom-loader::after {
      content: "";
      grid-area: 1/1;
      margin: 2px;
      border: inherit;
      border-radius: 50%; }
    .preloader .custom-loader::before {
      border-color: #283750 white;
      animation: inherit;
      animation-duration: .5s;
      animation-direction: reverse; }
    .preloader .custom-loader::after {
      margin: 8px; }

@keyframes s6 {
  100% {
    transform: rotate(1turn); } }
  .preloader.gone {
    opacity: 0;
    transition: opacity 0.25s; }

header {
  height: 12.0rem;
  position: relative;
  z-index: 30;
  background-color: transparent; }
  header nav.main {
    width: 100%;
    max-width: none;
    margin-left: auto;
    margin-right: auto;
    bottom: 0;
    position: relative;
    height: 6.0rem; }
    header nav.main img.full {
      position: absolute;
      left: 0;
      display: block;
      pointer-events: auto;
      width: 18.5rem !important;
      height: auto !important;
      display: block; }
    header nav.main img.sticky {
      display: block;
      position: absolute;
      left: 0;
      pointer-events: auto;
      width: auto !important;
      height: 3.0rem !important;
      display: none; }
    header nav.main ul.menu {
      font-family: 'opensans', sans-serif;
      font-weight: 400;
      font-size: 1rem;
      line-height: 1.625rem;
      position: fixed;
      left: 0;
      top: 0;
      width: 100vw;
      height: 4.0rem; }
      header nav.main ul.menu li {
        display: inline-block;
        margin: 0 0 0 1.5rem;
        padding: 0;
        height: 100%;
        letter-spacing: 0.05rem; }
      header nav.main ul.menu a {
        color: white;
        display: block;
        height: 100%;
        padding-top: 0.5rem;
        border-top: 0.5rem solid transparent;
        text-transform: uppercase; }
        header nav.main ul.menu a.active {
          border-color: #ace3fd; }
      header nav.main ul.menu::before {
        content: ' ';
        position: absolute;
        width: 100%;
        height: 100%;
        left: 0;
        top: 0;
        right: 0;
        bottom: 0;
        background-color: #283750;
        opacity: 0.85; }
    header nav.main div.search {
      width: 32.0rem;
      font-family: 'opensans', sans-serif;
      font-weight: 400;
      font-size: 1.0625rem;
      line-height: 1.625rem;
      position: absolute;
      right: 8.0rem;
      top: 2.75rem;
      text-align: right;
      height: 100%; }
      header nav.main div.search input {
        background: rgba(40, 55, 80, 0.25);
        background: transparent;
        width: 100%;
        padding: 0.5rem 4.5rem 0.25rem 0.5rem;
        font-family: 'opensans', sans-serif;
        font-weight: 400;
        font-size: 1.0625rem;
        line-height: 1.625rem;
        position: absolute;
        left: 0;
        top: 0;
        border-bottom: 1px solid rgba(40, 55, 80, 0.7); }
        header nav.main div.search input::-webkit-input-placeholder {
          font-family: 'opensans', sans-serif;
          font-weight: 400;
          font-size: 1.0625rem;
          line-height: 1.625rem;
          color: rgba(40, 55, 80, 0.5);
          opacity: 1; }
        header nav.main div.search input:-moz-placeholder {
          font-family: 'opensans', sans-serif;
          font-weight: 400;
          font-size: 1.0625rem;
          line-height: 1.625rem;
          color: rgba(40, 55, 80, 0.5);
          opacity: 1; }
        header nav.main div.search input::-moz-placeholder {
          font-family: 'opensans', sans-serif;
          font-weight: 400;
          font-size: 1.0625rem;
          line-height: 1.625rem;
          color: rgba(40, 55, 80, 0.5);
          opacity: 1; }
        header nav.main div.search input:-ms-input-placeholder {
          font-family: 'opensans', sans-serif;
          font-weight: 400;
          font-size: 1.0625rem;
          line-height: 1.625rem;
          color: rgba(40, 55, 80, 0.5);
          opacity: 1; }
        header nav.main div.search input:focus {
          background: rgba(40, 55, 80, 0.5); }
      header nav.main div.search button {
        padding: 0.5rem 1.5rem;
        font-family: 'opensans', sans-serif;
        font-weight: 400;
        font-size: 1.0625rem;
        line-height: 1.625rem;
        color: #283750;
        height: 2.5rem;
        position: absolute;
        right: 1.0rem;
        top: 0;
        cursor: pointer; }
        header nav.main div.search button::before {
          font-family: 'icon';
          -webkit-font-smoothing: antialiased;
          -moz-osx-font-smoothing: grayscale;
          font-weight: 400;
          font-size: 1.25rem;
          line-height: 1.5rem;
          position: absolute;
          top: 50%;
          left: 50%;
          -webkit-transform: translate(-50%, -50%);
          -ms-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
          content: "\e807"; }
        header nav.main div.search button:hover {
          color: #ace3fd; }
        header nav.main div.search button span {
          display: block;
          width: 0;
          height: 0;
          overflow: hidden; }
    header nav.main ul.menu.visible, header nav.main div.search.visible {
      opacity: 1;
      transition: opacity 0.5s ease-out; }
    header nav.main ul.menu.hidden, header nav.main div.search.hidden {
      top: -20.0rem;
      opacity: 0;
      transition: opacity 0.5s ease-out; }
    header nav.main ul.navswitch {
      width: 1.5rem;
      height: 1.5rem;
      color: #283750;
      position: absolute;
      top: 0;
      right: 0;
      height: 100%; }
      header nav.main ul.navswitch span {
        display: block;
        width: 0;
        height: 0;
        overflow: hidden; }
      header nav.main ul.navswitch li {
        position: absolute;
        left: 0;
        top: 0;
        width: 100%;
        height: 100%; }
        header nav.main ul.navswitch li.hidden, header nav.main ul.navswitch li.mobile {
          display: block;
          width: 0;
          height: 0;
          overflow: hidden; }
        header nav.main ul.navswitch li a {
          display: block;
          height: 100%;
          padding-top: 3.25rem;
          border: none;
          color: #283750; }
          header nav.main ul.navswitch li a::before {
            font-family: 'icon';
            -webkit-font-smoothing: antialiased;
            -moz-osx-font-smoothing: grayscale;
            font-weight: 400;
            font-size: 1.25rem;
            line-height: 1.625rem;
            content: "\e804"; }
          header nav.main ul.navswitch li a.search::before {
            content: "\e801";
            transition: opacity 0.5s ease-out; }
          header nav.main ul.navswitch li a.mobile::before {
            font-family: 'icon';
            -webkit-font-smoothing: antialiased;
            -moz-osx-font-smoothing: grayscale;
            font-weight: 400;
            font-size: 1.5rem;
            line-height: 1.75rem;
            position: absolute;
            top: 50%;
            left: 50%;
            -webkit-transform: translate(-50%, -50%);
            -ms-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%); }
          header nav.main ul.navswitch li a.mobile.visible::before {
            content: "\e802"; }
          header nav.main ul.navswitch li a.mobile.hidden::before {
            content: "\e801"; }
  header div.logo {
    width: calc(92vw - 7.5rem);
    max-width: calc(1320px - 7.5rem);
    margin-left: auto;
    margin-right: auto;
    text-align: right; }
    header div.logo div.title {
      font-family: 'opensans', sans-serif;
      font-weight: 200;
      font-size: 2.5rem;
      line-height: 2.625rem;
      color: white;
      text-transform: uppercase; }
    header div.logo div.subtitle {
      font-family: 'opensans', sans-serif;
      font-weight: 200;
      font-size: 1.125rem;
      line-height: 1.5rem;
      color: #ace3fd;
      letter-spacing: 0.05rem; }

@media screen and (min-width: 1025px) {
  header.newpos, header.sticky {
    min-height: 3.0rem;
    max-height: 3.0rem;
    background-color: rgba(172, 227, 253, 0.9);
    overflow: hidden;
    position: fixed;
    top: -300px;
    z-index: 30;
    transition: all 0.5s ease-out; }
    header.newpos nav.main img.full, header.sticky nav.main img.full {
      display: none; }
    header.newpos nav.main img.sticky, header.sticky nav.main img.sticky {
      display: block; }
    header.newpos nav.main ul.menu, header.sticky nav.main ul.menu {
      font-family: 'opensans', sans-serif;
      font-weight: 400;
      font-size: 1rem;
      line-height: 1.5625rem; }
      header.newpos nav.main ul.menu li a, header.sticky nav.main ul.menu li a {
        color: rgba(255, 255, 255, 0.8);
        display: block;
        height: 100%;
        padding-top: 1.0em;
        border-top: 0.25rem solid transparent; }
        header.newpos nav.main ul.menu li a:hover, header.newpos nav.main ul.menu li a.active, header.sticky nav.main ul.menu li a:hover, header.sticky nav.main ul.menu li a.active {
          color: white; }
        header.newpos nav.main ul.menu li a.active, header.sticky nav.main ul.menu li a.active {
          color: white;
          border-color: white; }
      header.newpos nav.main ul.menu.hidden, header.sticky nav.main ul.menu.hidden {
        width: calc(100% - 24.0rem);
        height: auto; }
    header.newpos nav.main div.search, header.newpos nav.main ul.navswitch, header.sticky nav.main div.search, header.sticky nav.main ul.navswitch {
      display: block;
      width: 0;
      height: 0;
      overflow: hidden; }
  header.sticky {
    top: 0; } }

main {
  width: 92vw;
  max-width: 1320px;
  margin-left: auto;
  margin-right: auto;
  background: white;
  position: relative;
  height: auto;
  padding: 0 0 8.0rem 0;
  /*
	.headlines {
		@include width(wide);
		.label { 
			display: inline-block; padding: 0.25rem 1.0rem; background: $darkblue; color: white; margin-bottom: 0.5rem;
			@include font(14,16,dis); text-transform: uppercase; letter-spacing: 0.125rem; 
		}
		h1, h2 { padding: 0; margin: 0; }
		h1 { color: $brightblue; }
		h2 { @include font(35,40,dis,rg); }
		&.standard, &.contact_form, &.searchresult { padding: 3.0rem 0 3.0rem 0; }
		&.product { @include width(narrow); padding-top: 1.5rem; }
		&.contact { width: calc((100% - 1.0rem) / 2); margin: 0; }
		&.album { 
			padding: 3.0rem 0 3.0rem 0; 
			.label { background: $white; color: $darkblue; }
			h1, h2 { color: $white; }
		}
		span.h2 { display: block; @include font(35,40,dis,rg); color: $black; }
	}
	
	&.iframe {
		padding: 2.0rem 2.0rem 4.0rem 2.0rem; margin: 0;
		h1 { @include width(full); }
		.panel {
			.bundle, .bundle.narrow, .bundle.full, .bundle.wide  { @include width(full); }
		}
	}
	&.photos, &.photos_album { background: $darkblue; }
	*/ }
  main.menu {
    background: #78aac8; }
  main h 1, main h2, main h3, main h4 {
    font-style: normal;
    color: #144593; }
  main h1 {
    font-family: 'opensans', sans-serif;
    font-weight: 400;
    font-size: 3rem;
    line-height: 3.25rem;
    padding: 4.0rem 0 2.0rem 0;
    width: calc(92vw - 7.5rem);
    max-width: calc(1320px - 7.5rem);
    margin-left: auto;
    margin-right: auto;
    font-family: 'opensans', sans-serif;
    font-weight: 400;
    font-size: 3rem;
    line-height: 3.25rem;
    padding: 4.0rem 0 2.0rem 0;
    width: calc(92vw - 7.5rem);
    max-width: calc(1320px - 7.5rem);
    margin-left: auto;
    margin-right: auto; }
    main h1 span.subline {
      display: inline-block;
      font-family: 'opensans', sans-serif;
      font-weight: 200;
      font-size: 2.5rem;
      line-height: 2.75rem;
      color: black; }
    main h1.level-1 {
      text-transform: uppercase;
      font-weight: 500;
      color: white; }
    main h1.level-2 {
      color: white; }
  main h2 {
    font-family: 'opensans', sans-serif;
    font-weight: 400;
    font-size: 2.25rem;
    line-height: 2.4375rem;
    padding: 0.8125rem 0 1.0rem 0; }
  main h3 {
    font-family: 'notoserif', serif;
    font-weight: 500;
    font-size: 1.375rem;
    line-height: 1.625rem;
    color: black;
    padding: 1.0rem 0 0.625rem 0; }
  main h1.wide, main h1.full, main h2.wide, main h2.full {
    width: calc(92vw - 7.5rem);
    max-width: calc(1320px - 7.5rem);
    margin-left: auto;
    margin-right: auto; }
  main h1.narrow, main h2.narrow {
    width: 80%;
    max-width: 800px;
    margin-left: auto;
    margin-right: auto; }
  main h2 span.small {
    font-family: 'opensans', sans-serif;
    font-weight: 700;
    font-size: 1.375rem;
    line-height: 1.5rem; }
  main nav.parent {
    font-family: 'opensans', sans-serif;
    font-weight: 400;
    font-size: 0.875rem;
    line-height: 1rem;
    width: calc(92vw - 7.5rem);
    max-width: calc(1320px - 7.5rem);
    margin-left: auto;
    margin-right: auto;
    text-transform: uppercase;
    padding: 4.0rem 0 0.5rem 0; }
    main nav.parent a {
      color: #5493b9; }
    main nav.parent a:hover {
      color: #144593;
      text-decoration: none; }
  main nav.parent + h1 {
    padding-top: 0; }
  main p, main ul, main ol {
    margin: 0;
    padding-bottom: 0.75rem; }
  main ul {
    padding-bottom: 0.5rem; }
  main ul li {
    list-style-type: none;
    position: relative;
    margin: 0;
    padding: 0 0 0.25rem 0; }
  main ul:not(.nobullet) li {
    padding-left: 1.25rem; }
  main ul:not(.nobullet) li::before {
    position: absolute;
    left: 0;
    top: 0;
    content: '\e800';
    width: 1.25rem;
    height: 1.0rem;
    font-family: 'icon';
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    font-weight: 400;
    font-size: 1.125rem;
    line-height: 1.75rem;
    color: #ace3fd; }
  main strong, main b {
    font-weight: 700; }
  main em, main i {
    font-style: italic; }
  main sup, main sub {
    font-size: 75%;
    line-height: 0;
    vertical-align: baseline;
    position: relative; }
  main sup {
    top: -0.5em; }
  main sub {
    bottom: -0.25em; }
  main a {
    color: #5493b9; }
  main a:not(.nohover):hover {
    color: #144593;
    text-decoration: underline; }
  main span.sym {
    display: inline-block;
    position: relative;
    padding-left: 1.5rem; }
  main span.sym::before {
    font-family: 'icon';
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    font-weight: 400;
    font-size: 1.125rem;
    line-height: 1.75rem;
    content: "\e813";
    color: #283750;
    position: absolute;
    left: 0;
    top: 0; }
  main span.sym.phone::before {
    content: "\e830"; }
  main nav.siblings {
    width: 80%;
    max-width: 800px;
    margin-left: auto;
    margin-right: auto;
    margin-top: 4.0rem; }
    main nav.siblings ul li {
      margin-bottom: 0.25rem;
      font-family: 'opensans', sans-serif;
      font-weight: 400;
      font-size: 1rem;
      line-height: 1.5rem; }
      main nav.siblings ul li a {
        display: block;
        height: 100%;
        background: rgba(40, 55, 80, 0.25);
        padding: 0 1.0rem;
        color: #283750; }
        main nav.siblings ul li a:hover {
          text-decoration: none;
          background: rgba(40, 55, 80, 0.75);
          color: white; }
        main nav.siblings ul li a::before {
          font-family: 'icon';
          -webkit-font-smoothing: antialiased;
          -moz-osx-font-smoothing: grayscale;
          font-weight: 400;
          font-size: 1rem;
          line-height: 1.5rem;
          content: '\e824';
          padding-right: 0.5rem; }
      main nav.siblings ul li.next a::before {
        content: '\e821'; }
      main nav.siblings ul li.prev a::before {
        content: '\e822'; }
      main nav.siblings ul li.grandparent a::before {
        content: '\e810'; }
  main.menu nav.parent a {
    color: #283750;
    border-bottom: 1px solid; }
  main.menu nav.parent a:hover {
    color: white; }

footer {
  min-height: 6.0rem; }
  footer strong, footer b {
    font-weight: 900; }
  footer .bundle {
    width: calc(92vw - 7.5rem);
    max-width: calc(1320px - 7.5rem);
    margin-left: auto;
    margin-right: auto;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -webkit-flex-wrap: nowrap;
    -moz-flex-wrap: nowrap;
    -ms-flex-wrap: nowrap;
    flex-wrap: nowrap;
    -webkit-align-items: flex-start;
    align-items: flex-start;
    -webkit-justify-content: space-between;
    justify-content: space-between;
    position: relative;
    padding: 2.0rem 0 3.0rem 0;
    font-family: 'opensans', sans-serif;
    font-weight: 400;
    font-size: 0.9375rem;
    line-height: 1.625rem;
    color: white; }
    footer .bundle div.box {
      width: calc((100% - 1.5rem) / 4); }
      footer .bundle div.box a {
        color: white;
        border-bottom: 1px dotted white; }
        footer .bundle div.box a:hover {
          color: white;
          border-bottom: 1px solid white; }

div.panel {
  height: auto;
  position: relative;
  width: 100%; }
  div.panel.margin-0 {
    margin: 0 0; }
  div.panel.margin-1 {
    margin: 0 0 1.5rem 0; }
  div.panel.margin-2 {
    margin: 0 0 3.0rem 0; }
  div.panel.margin-3 {
    margin: 0 0 4.5rem 0; }
  div.panel div.bundle {
    position: relative;
    margin: 0 auto; }
    div.panel div.bundle.full {
      width: 100%;
      max-width: none;
      margin-left: auto;
      margin-right: auto; }
    div.panel div.bundle.intro {
      width: calc(92vw - 2.0rem);
      max-width: calc(1320px - 2.0rem);
      margin-left: auto;
      margin-right: auto; }
    div.panel div.bundle.wide {
      width: calc(92vw - 7.5rem);
      max-width: calc(1320px - 7.5rem);
      margin-left: auto;
      margin-right: auto; }
      div.panel div.bundle.wide h2 {
        width: 80%;
        max-width: 800px;
        margin-left: auto;
        margin-right: auto; }
    div.panel div.bundle.narrow {
      width: 80%;
      max-width: 800px;
      margin-left: auto;
      margin-right: auto; }
    div.panel div.bundle.album {
      margin-left: auto;
      margin-right: auto; }
    div.panel div.bundle.bgcolor {
      padding: 3.0rem 0; }
  div.panel div.gal {
    width: 100%;
    background: transparent; }
    div.panel div.gal figure {
      display: block;
      width: 100%;
      position: relative; }
      div.panel div.gal figure img {
        width: 100% !important;
        height: auto !important; }
      div.panel div.gal figure figcaption {
        font-family: 'opensans', sans-serif;
        font-weight: 400;
        font-size: 0.9375rem;
        line-height: 1.25rem;
        padding-top: 0.375rem;
        color: rgba(40, 55, 80, 0.75); }
        div.panel div.gal figure figcaption h3 {
          font-family: 'notoserif', serif;
          font-weight: 500;
          font-size: 1.125rem;
          line-height: 1.375rem;
          padding: 0 0 0.375rem 0; }
        div.panel div.gal figure figcaption p {
          padding: 0; }
      div.panel div.gal figure picture {
        display: block;
        position: relative; }
        div.panel div.gal figure picture span.plus {
          display: block;
          position: absolute;
          font-family: 'opensans', sans-serif;
          font-weight: 700;
          font-size: 1.5rem;
          line-height: 1.5rem;
          color: white;
          bottom: 0.75rem;
          right: 0.75rem;
          z-index: 10;
          background: transparent; }
  div.panel div.txt {
    width: 100%;
    background: transparent; }
    div.panel div.txt div.col {
      display: inline-block;
      vertical-align: top;
      width: calc((100% - 1.0rem) / 2);
      margin-right: 1.0rem; }
      div.panel div.txt div.col:last-of-type {
        margin-right: 0; }
    div.panel div.txt span.birth, div.panel div.txt span.death {
      font-weight: 700;
      padding-left: 1.25rem;
      position: relative; }
      div.panel div.txt span.birth::before, div.panel div.txt span.death::before {
        position: absolute;
        left: 0;
        top: 0;
        font-family: 'icon';
        -webkit-font-smoothing: antialiased;
        -moz-osx-font-smoothing: grayscale;
        font-weight: 400;
        font-size: 1.125rem;
        line-height: 1.625rem;
        content: '\e809'; }
    div.panel div.txt span.death::before {
      content: '\e808'; }
  div.panel.text-only.home-intro div.bundle {
    width: calc(92vw - 7.5rem);
    max-width: calc(1320px - 7.5rem);
    margin-left: auto;
    margin-right: auto; }
  div.panel.text-imgs div.bundle.row, div.panel.text-imgs div.bundle.rev {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -webkit-flex-wrap: wrap;
    -moz-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-flex-direction: horizontal;
    -moz-flex-direction: horizontal;
    -ms-flex-direction: row;
    -webkit-flex-direction: row;
    flex-direction: row;
    -webkit-justify-content: space-between;
    justify-content: space-between; }
  div.panel.text-imgs div.bundle.rev {
    -webkit-flex-direction: horizontal-reverse;
    -moz-flex-direction: horizontal-reverse;
    -ms-flex-direction: column-reverse;
    -webkit-flex-direction: row-reverse;
    flex-direction: row-reverse; }
  div.panel.text-imgs div.bundle div.gal, div.panel.text-imgs div.bundle div.txt {
    width: calc((100% - 1.0rem) / 2); }
  div.panel.text-imgs div.bundle div.gal {
    padding-top: 0.25rem; }
    div.panel.text-imgs div.bundle div.gal figure {
      padding-bottom: 1.0rem; }
    div.panel.text-imgs div.bundle div.gal figure:last-child {
      margin-bottom: 0; }
  div.panel.text-imgs div.bundle.row.notch, div.panel.text-imgs div.bundle.rev.notch {
    -webkit-justify-content: flex-start;
    justify-content: flex-start; }
    div.panel.text-imgs div.bundle.row.notch div.txt, div.panel.text-imgs div.bundle.rev.notch div.txt {
      width: calc((83.3333% - 1.0rem) / 2);
      margin: 0 0 0 1.0rem;
      max-width: calc(400px - 0.5rem); }
  div.panel.text-imgs div.bundle.rev.notch div.txt {
    margin: 0 1.0rem 0 0; }
  div.panel.text-imgs div.bundle .noflex {
    flex: 0 0 100%; }
  div.panel.imgs-only {
    /*
			&.col-2 {
				// uneven cols: 2 col -> 3 cols, span takes 2 spaces
				&.span-1, &.span-2, &.span-3 { 
					figure { width: calc((100% - 2.0rem) / 3) !important; }
				}
				&.span-1 figure:nth-child(1),
				&.span-2 figure:nth-child(2) { width: calc((((100% - 2.0rem) / 3) * 2) + 1.0rem) !important; } 
			}
			&.col-3 {
				// uneven cols: 3 col -> 4 cols, span takes 2 spaces
				&.span-1, &.span-2, &.span-3 { 
					figure { width: calc((100% - 3.0rem) / 4) !important; }
				}
				&.span-1 figure:nth-child(1),
				&.span-2 figure:nth-child(2),
				&.span-3 figure:nth-child(3) { width: calc((((100% - 3.0rem) / 4) * 2) + 1.0rem) !important; }
			}
		//}
		*/ }
    div.panel.imgs-only div.bundle div.gal:not(.swiper-wrapper) {
      display: -webkit-box;
      display: -moz-box;
      display: -ms-flexbox;
      display: -webkit-flex;
      display: flex;
      -webkit-flex-wrap: wrap;
      -moz-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
      flex-wrap: wrap;
      -webkit-align-items: flex-start;
      align-items: flex-start;
      -webkit-justify-content: flex-start;
      justify-content: flex-start;
      gap: 1.0rem; }
    div.panel.imgs-only div.bundle figure {
      width: 100% !important; }
    div.panel.imgs-only div.bundle.col-2 figure {
      width: calc((100% - 1.0rem) / 2) !important; }
    div.panel.imgs-only div.bundle.col-3 figure {
      width: calc((100% - 2.0rem) / 3) !important; }
    div.panel.imgs-only div.bundle.col-4 figure {
      width: calc((100% - 3.0rem) / 4) !important; }
    div.panel.imgs-only div.bundle.full.col-1 figure figcaption, div.panel.imgs-only div.bundle.full.seq figure figcaption {
      width: calc(92vw - 7.5rem);
      max-width: calc(1320px - 7.5rem);
      margin-left: auto;
      margin-right: auto; }
    div.panel.imgs-only div.bundle.col-2.span-1 figure, div.panel.imgs-only div.bundle.col-2.span-2 figure, div.panel.imgs-only div.bundle.col-2.span-3 figure {
      width: calc((100% - 2.0rem) / 3) !important; }
    div.panel.imgs-only div.bundle.col-2.span-1 figure:nth-child(1), div.panel.imgs-only div.bundle.col-2.span-2 figure:nth-child(2) {
      width: calc((((100% - 2.0rem) / 3) * 2) + 1.0rem) !important; }
    div.panel.imgs-only div.bundle.col-3.span-1 figure, div.panel.imgs-only div.bundle.col-3.span-2 figure, div.panel.imgs-only div.bundle.col-3.span-3 figure {
      width: calc((100% - 3.0rem) / 4) !important; }
    div.panel.imgs-only div.bundle.col-3.span-1 figure:nth-child(1), div.panel.imgs-only div.bundle.col-3.span-2 figure:nth-child(2), div.panel.imgs-only div.bundle.col-3.span-3 figure:nth-child(3) {
      width: calc((((100% - 3.0rem) / 4) * 2) + 1.0rem) !important; }
  div.panel.imgs-box div.bundle {
    aspect-ratio: 16 / 9;
    overflow: hidden; }
    div.panel.imgs-box div.bundle div.gal:not(.swiper-wrapper) {
      display: -webkit-box;
      display: -moz-box;
      display: -ms-flexbox;
      display: -webkit-flex;
      display: flex;
      -webkit-flex-wrap: wrap;
      -moz-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
      flex-wrap: wrap;
      -webkit-align-items: flex-start;
      align-items: flex-start;
      -webkit-justify-content: flex-start;
      justify-content: flex-start;
      gap: 1.0rem;
      padding-top: 1.0rem; }
    div.panel.imgs-box div.bundle figure {
      width: 100% !important; }
    div.panel.imgs-box div.bundle.col-2 figure {
      width: calc((100% - 1.0rem) / 2) !important; }
    div.panel.imgs-box div.bundle div.textwrapper {
      background: lime;
      height: 100%;
      width: calc(92vw - 7.5rem);
      max-width: calc(1320px - 7.5rem);
      margin-left: auto;
      margin-right: auto; }
    div.panel.imgs-box div.bundle div.txt.introbox {
      display: inline-block;
      max-width: 60%;
      box-sizing: border-box;
      padding: 1.0rem;
      opacity: 0;
      transition: all 0.5s ease-in;
      z-index: 10; }
    div.panel.imgs-box div.bundle div.txt.visible {
      opacity: 1.0; }
    div.panel.imgs-box div.bundle div.fade-check {
      height: 1.0rem; }
    div.panel.imgs-box div.bundle div.txt.lt {
      position: absolute;
      left: 0;
      top: 0;
      -webkit-transform: translate(2.75rem, 0);
      -ms-transform: translate(2.75rem, 0);
      transform: translate(2.75rem, 0); }
    div.panel.imgs-box div.bundle div.txt.ct {
      position: absolute;
      left: 50%;
      top: 0;
      -webkit-transform: translate(-50%, 0);
      -ms-transform: translate(-50%, 0);
      transform: translate(-50%, 0); }
    div.panel.imgs-box div.bundle div.txt.rt {
      position: absolute;
      right: 0;
      top: 0;
      -webkit-transform: translate(-2.75rem, 0);
      -ms-transform: translate(-2.75rem, 0);
      transform: translate(-2.75rem, 0); }
    div.panel.imgs-box div.bundle div.txt.lc {
      position: absolute;
      left: 0;
      top: 50%;
      -webkit-transform: translate(2.75rem, 0);
      -ms-transform: translate(2.75rem, 0);
      transform: translate(2.75rem, 0); }
    div.panel.imgs-box div.bundle div.txt.cc {
      position: absolute;
      left: 50%;
      top: 50%;
      -webkit-transform: translate(-50%, 0);
      -ms-transform: translate(-50%, 0);
      transform: translate(-50%, 0); }
    div.panel.imgs-box div.bundle div.txt.rc {
      position: absolute;
      right: 0;
      top: 50%;
      -webkit-transform: translate(-2.75rem, 0);
      -ms-transform: translate(-2.75rem, 0);
      transform: translate(-2.75rem, 0); }
    div.panel.imgs-box div.bundle div.txt.lb {
      position: absolute;
      left: 0;
      bottom: 0;
      -webkit-transform: translate(2.75rem, 0);
      -ms-transform: translate(2.75rem, 0);
      transform: translate(2.75rem, 0); }
    div.panel.imgs-box div.bundle div.txt.cb {
      position: absolute;
      left: 50%;
      bottom: 0;
      -webkit-transform: translate(-50%, 0);
      -ms-transform: translate(-50%, 0);
      transform: translate(-50%, 0); }
    div.panel.imgs-box div.bundle div.txt.rb {
      position: absolute;
      right: 0;
      bottom: 0;
      -webkit-transform: translate(-2.75rem, 0);
      -ms-transform: translate(-2.75rem, 0);
      transform: translate(-2.75rem, 0); }
    div.panel.imgs-box div.bundle div.txt.lt.visible, div.panel.imgs-box div.bundle div.fade-check.lt {
      position: absolute;
      left: 0;
      top: 0;
      -webkit-transform: translate(2.75rem, 5rem);
      -ms-transform: translate(2.75rem, 5rem);
      transform: translate(2.75rem, 5rem); }
    div.panel.imgs-box div.bundle div.txt.ct.visible, div.panel.imgs-box div.bundle div.fade-check.ct {
      position: absolute;
      left: 50%;
      top: 0;
      -webkit-transform: translate(-50%, 5rem);
      -ms-transform: translate(-50%, 5rem);
      transform: translate(-50%, 5rem); }
    div.panel.imgs-box div.bundle div.txt.rt.visible, div.panel.imgs-box div.bundle div.fade-check.rt {
      position: absolute;
      right: 0;
      top: 0;
      -webkit-transform: translate(-5%, 5rem);
      -ms-transform: translate(-5%, 5rem);
      transform: translate(-5%, 5rem); }
    div.panel.imgs-box div.bundle div.txt.lc.visible, div.panel.imgs-box div.bundle div.fade-check.lc {
      position: absolute;
      left: 0;
      top: 50%;
      -webkit-transform: translate(5%, -50%);
      -ms-transform: translate(5%, -50%);
      transform: translate(5%, -50%); }
    div.panel.imgs-box div.bundle div.txt.cc.visible, div.panel.imgs-box div.bundle div.fade-check.cc {
      position: absolute;
      left: 50%;
      top: 50%;
      -webkit-transform: translate(-50%, -50%);
      -ms-transform: translate(-50%, -50%);
      transform: translate(-50%, -50%); }
    div.panel.imgs-box div.bundle div.txt.rc.visible, div.panel.imgs-box div.bundle div.fade-check.rc {
      position: absolute;
      right: 0;
      top: 50%;
      -webkit-transform: translate(-5%, -50%);
      -ms-transform: translate(-5%, -50%);
      transform: translate(-5%, -50%); }
    div.panel.imgs-box div.bundle div.txt.lb.visible, div.panel.imgs-box div.bundle div.fade-check.lb {
      position: absolute;
      left: 0;
      bottom: 0;
      -webkit-transform: translate(5%, -5rem);
      -ms-transform: translate(5%, -5rem);
      transform: translate(5%, -5rem); }
    div.panel.imgs-box div.bundle div.txt.cb.visible, div.panel.imgs-box div.bundle div.fade-check.cb {
      position: absolute;
      left: 50%;
      bottom: 0;
      -webkit-transform: translate(-50%, -5rem);
      -ms-transform: translate(-50%, -5rem);
      transform: translate(-50%, -5rem); }
    div.panel.imgs-box div.bundle div.txt.rb.visible, div.panel.imgs-box div.bundle div.fade-check.rb {
      position: absolute;
      right: 0;
      bottom: 0;
      -webkit-transform: translate(-2.75rem, -5rem);
      -ms-transform: translate(-2.75rem, -5rem);
      transform: translate(-2.75rem, -5rem); }
  div.panel.sub-descendants {
    /*
		div.bundle { 
			@include flex(); @include flex-wrap(wrap); @include flex-align(flex-start); @include flex-just(stretch); gap: 1.0rem;
			div.descendant { 
				width: 100%; margin-bottom: 1.0rem; background-color: $white; align-self: stretch;
				//@include flex(); @include flex-wrap(nowrap); @include flex-align(flex-start); //@include flex-just(stretch); gap: 1.0rem;
				figure { aspect-ratio: 1 / 1; overflow: hidden; width: 50%; }
				img { width: 100% !important; height: 100% !important; object-fit: cover; display: inline-block; }
				div { width: calc((100% - 1.0rem / 2); border: 1px solid red; display: inline-block; }
				h3 { @include font(18,22,dis,sb); color: $black; padding: 1.0rem 0.5rem 0.25rem 0.5rem; }
				p { @include font(16,20,txt,rg); padding: 0 0.5rem 0.75rem 0.5rem; }
				a { 
					color: $black;
					&:hover { 
						text-decoration: none; 
						h3 { text-decoration: underline;  }
					}
				}
				&.white { background-color: $white; align-self: stretch; }
				&.swiper-slide { height: auto; }
			}
			&.col-2 div.descendant  { width: calc((100% - 1.0rem) / 2) !important; } // 2 cols
			&.col-3 div.descendant  { width: calc((100% - 2.0rem) / 3) !important; } // 3 cols
			&.col-4 div.descendant  { width: calc((100% - 3.0rem) / 4) !important; } // 4 cols

		}
		*/ }
    div.panel.sub-descendants h2 {
      color: white; }
    div.panel.sub-descendants div.bundle {
      display: -webkit-box;
      display: -moz-box;
      display: -ms-flexbox;
      display: -webkit-flex;
      display: flex;
      -webkit-flex-wrap: wrap;
      -moz-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
      flex-wrap: wrap;
      -webkit-align-items: flex-start;
      align-items: flex-start;
      -webkit-justify-content: stretch;
      justify-content: stretch;
      gap: 1.0rem; }
      div.panel.sub-descendants div.bundle div.descendant {
        width: 100%;
        background-color: white;
        align-self: stretch; }
        div.panel.sub-descendants div.bundle div.descendant:hover {
          background-color: #eaf2f6; }
        div.panel.sub-descendants div.bundle div.descendant figure {
          aspect-ratio: 3 / 2;
          overflow: hidden; }
        div.panel.sub-descendants div.bundle div.descendant img {
          width: 100% !important;
          height: 100% !important;
          object-fit: cover; }
        div.panel.sub-descendants div.bundle div.descendant a:hover {
          text-decoration: none; }
        div.panel.sub-descendants div.bundle div.descendant div {
          height: 100%; }
          div.panel.sub-descendants div.bundle div.descendant div a {
            display: block;
            height: 100%; }
            div.panel.sub-descendants div.bundle div.descendant div a h3 {
              font-family: 'opensans', sans-serif;
              font-weight: 500;
              font-size: 1.375rem;
              line-height: 1.625rem;
              color: #144593;
              padding: 1.0rem 0.5rem 0.25rem 0.5rem; }
            div.panel.sub-descendants div.bundle div.descendant div a p {
              font-family: 'notoserif', serif;
              font-weight: 400;
              font-size: 1rem;
              line-height: 1.25rem;
              color: black;
              padding: 0 0.5rem 0.75rem 0.5rem; }
        div.panel.sub-descendants div.bundle div.descendant.swiper-slide {
          height: auto; }
        div.panel.sub-descendants div.bundle div.descendant.thbleft {
          display: -webkit-box;
          display: -moz-box;
          display: -ms-flexbox;
          display: -webkit-flex;
          display: flex;
          -webkit-flex-wrap: nowrap;
          -moz-flex-wrap: nowrap;
          -ms-flex-wrap: nowrap;
          flex-wrap: nowrap;
          -webkit-align-items: flex-start;
          align-items: flex-start;
          -webkit-justify-content: stretch;
          justify-content: stretch;
          gap: 1.0rem; }
          div.panel.sub-descendants div.bundle div.descendant.thbleft figure {
            width: 50%;
            aspect-ratio: 1 / 1;
            overflow: hidden; }
          div.panel.sub-descendants div.bundle div.descendant.thbleft div {
            width: calc((100% - 1.0rem) / 2); }
            div.panel.sub-descendants div.bundle div.descendant.thbleft div h3 {
              padding: 1.0rem 0.5rem 0.25rem 0; }
            div.panel.sub-descendants div.bundle div.descendant.thbleft div p {
              padding: 1.0rem 0.5rem 0.75rem 0; }
      div.panel.sub-descendants div.bundle.col-2 div.descendant:not(.nobullet) {
        width: calc((100% - 1.0rem) / 2) !important; }
      div.panel.sub-descendants div.bundle.col-3 div.descendant {
        width: calc((100% - 2.0rem) / 3) !important; }
      div.panel.sub-descendants div.bundle.col-4 div.descendant {
        width: calc((100% - 3.0rem) / 4) !important; }
  div.panel.files-dl h2 {
    font-family: 'opensans', sans-serif;
    font-weight: 500;
    font-size: 1rem;
    line-height: 1.125rem;
    padding: 0.5 0 1.5rem 0;
    text-transform: uppercase;
    border-top: 2px dotted;
    letter-spacing: 0.2rem; }
  div.panel.files-dl p, div.panel.files-dl ul {
    font-family: 'opensans', sans-serif;
    font-weight: 400;
    font-size: 1rem;
    line-height: 1.25rem; }
  div.panel.files-dl ul li {
    padding: 0 0 1.0rem 1.75rem; }
    div.panel.files-dl ul li::before {
      content: '\e812';
      left: 0;
      font-family: 'icon';
      -webkit-font-smoothing: antialiased;
      -moz-osx-font-smoothing: grayscale;
      font-weight: 400;
      font-size: 1.25rem;
      line-height: 1.25rem;
      color: #283750; }
    div.panel.files-dl ul li span.filesize {
      font-family: 'opensans', sans-serif;
      font-weight: 400;
      font-size: 0.8125rem;
      line-height: 1.25rem;
      text-transform: uppercase;
      letter-spacing: 0.05em;
      white-space: nowrap; }
    div.panel.files-dl ul li span.author {
      font-family: 'opensans', sans-serif;
      font-weight: 400;
      font-size: 1rem;
      line-height: 1.125rem; }
    div.panel.files-dl ul li span.descr {
      font-family: 'opensans', sans-serif;
      font-weight: 400;
      font-size: 1rem;
      line-height: 1.25rem;
      display: inline-block;
      padding-top: 0.25rem; }
  div.panel.files-dl strong {
    font-weight: 500; }
  div.panel.text-appendix h2 {
    font-family: 'opensans', sans-serif;
    font-weight: 500;
    font-size: 1rem;
    line-height: 1.125rem;
    padding: 0.5 0 1.5rem 0;
    text-transform: uppercase;
    border-top: 2px dotted;
    letter-spacing: 0.2rem; }
  div.panel.text-appendix p, div.panel.text-appendix ul {
    font-family: 'opensans', sans-serif;
    font-weight: 400;
    font-size: 1rem;
    line-height: 1.25rem; }
  div.panel.text-appendix ul li {
    list-style-type: none;
    position: relative;
    margin: 0;
    padding: 0 0 0.25rem 0; }
  div.panel.text-appendix ul:not(.nobullet) li {
    padding-left: 1.25rem; }
  div.panel.text-appendix ul:not(.nobullet) li::before {
    position: absolute;
    left: 0;
    top: 0;
    content: '–';
    width: 1.25rem;
    height: 1.0rem;
    font-family: 'opensans', sans-serif;
    font-weight: 400;
    font-size: 1rem;
    line-height: 1.25rem;
    color: black; }
  div.panel.swiper-feature .bundle {
    margin-top: 3.0rem; }
    div.panel.swiper-feature .bundle h2 {
      font-family: 'opensans', sans-serif;
      font-weight: 400;
      font-size: 0.875rem;
      line-height: 1rem;
      text-transform: uppercase;
      letter-spacing: 0.125rem;
      margin-bottom: 1.0rem;
      padding: 0.25rem 1.0rem;
      background: #ace3fd;
      color: white;
      text-align: center; }
    div.panel.swiper-feature .bundle div.swiper-slide {
      background: rgba(40, 55, 80, 0.05);
      padding: 0.5rem;
      height: auto; }
      div.panel.swiper-feature .bundle div.swiper-slide picture, div.panel.swiper-feature .bundle div.swiper-slide div.text {
        display: inline-block;
        vertical-align: top; }
      div.panel.swiper-feature .bundle div.swiper-slide picture {
        width: 40%;
        aspect-ratio: 3/2;
        margin-right: 0.75rem; }
        @supports not (aspect-ratio: 3/2) {
          div.panel.swiper-feature .bundle div.swiper-slide picture::before {
            float: left;
            padding-top: 66.6666666667%;
            content: ''; }
          div.panel.swiper-feature .bundle div.swiper-slide picture::after {
            display: block;
            content: '';
            clear: both; } }
        div.panel.swiper-feature .bundle div.swiper-slide picture img {
          display: block;
          width: 100% !important;
          height: 100% !important;
          object-fit: cover !important; }
      div.panel.swiper-feature .bundle div.swiper-slide div.text {
        width: calc(60% - 0.75rem); }
        div.panel.swiper-feature .bundle div.swiper-slide div.text h3 {
          font-family: 'opensans', sans-serif;
          font-weight: 700;
          font-size: 1.125rem;
          line-height: 1.375rem;
          padding: 0 0 0.25rem 0;
          color: #283750; }
        div.panel.swiper-feature .bundle div.swiper-slide div.text p {
          font-family: 'opensans', sans-serif;
          font-weight: 400;
          font-size: 1rem;
          line-height: 1.375rem; }
          div.panel.swiper-feature .bundle div.swiper-slide div.text p::after {
            content: "";
            font-family: 'icon';
            -webkit-font-smoothing: antialiased;
            -moz-osx-font-smoothing: grayscale;
            font-weight: 400;
            font-size: 1rem;
            line-height: 1.375rem;
            color: #ace3fd;
            padding-left: 0.5rem; }
      div.panel.swiper-feature .bundle div.swiper-slide a {
        color: #283750; }
      div.panel.swiper-feature .bundle div.swiper-slide a:hover div.text h3 {
        color: #ace3fd; }
  div.panel.swiper-feature.products .bundle h2 {
    background: #283750; }
  div.panel.swiper-feature.products .bundle div.swiper-slide {
    background: transparent;
    padding: 0; }
    div.panel.swiper-feature.products .bundle div.swiper-slide picture, div.panel.swiper-feature.products .bundle div.swiper-slide div.text {
      width: calc((100% - 0.75rem) / 2); }
    div.panel.swiper-feature.products .bundle div.swiper-slide div.text h3 {
      color: #ace3fd;
      padding-bottom: 0; }
    div.panel.swiper-feature.products .bundle div.swiper-slide div.text h4 {
      font-family: 'opensans', sans-serif;
      font-weight: 400;
      font-size: 1.0625rem;
      line-height: 1.375rem;
      color: #283750; }
    div.panel.swiper-feature.products .bundle div.swiper-slide div.text p {
      padding-top: 0.5rem; }

main.home .panel.text-only {
  font-family: 'notoserif', serif;
  font-weight: 400;
  font-size: 1.5rem;
  line-height: 2rem; }

main.home div.panel.sub-home {
  margin: 0 0 2.0rem 0; }
  main.home div.panel.sub-home .bundle {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -webkit-flex-wrap: nowrap;
    -moz-flex-wrap: nowrap;
    -ms-flex-wrap: nowrap;
    flex-wrap: nowrap;
    -webkit-align-items: stretch;
    align-items: stretch;
    -webkit-justify-content: space-between;
    justify-content: space-between; }
    main.home div.panel.sub-home .bundle div.teaser {
      width: calc((100% - 2.0rem) / 3);
      min-height: 200px;
      margin-bottom: 2.0rem;
      padding-top: 2.5rem;
      position: relative; }
      main.home div.panel.sub-home .bundle div.teaser h2 {
        font-family: 'opensans', sans-serif;
        font-weight: 400;
        font-size: 0.875rem;
        line-height: 1rem;
        text-transform: uppercase;
        letter-spacing: 0.125rem;
        position: absolute;
        top: 0;
        width: 100%;
        padding: 0.25rem 1.0rem;
        background: #283750;
        color: white;
        text-align: center; }
      main.home div.panel.sub-home .bundle div.teaser picture {
        display: block;
        width: 100%;
        aspect-ratio: 3/2;
        background: rgba(40, 55, 80, 0.5); }
        @supports not (aspect-ratio: 3/2) {
          main.home div.panel.sub-home .bundle div.teaser picture::before {
            float: left;
            padding-top: 66.6666666667%;
            content: ''; }
          main.home div.panel.sub-home .bundle div.teaser picture::after {
            display: block;
            content: '';
            clear: both; } }
        main.home div.panel.sub-home .bundle div.teaser picture img {
          display: block;
          width: 100% !important;
          height: 100% !important;
          object-fit: cover !important; }
      main.home div.panel.sub-home .bundle div.teaser div.text {
        width: 100%; }
        main.home div.panel.sub-home .bundle div.teaser div.text h3 {
          font-family: 'opensans', sans-serif;
          font-weight: 700;
          font-size: 1.125rem;
          line-height: 1.375rem;
          padding: 0.5rem 0 0.25rem 0;
          color: #ace3fd; }
        main.home div.panel.sub-home .bundle div.teaser div.text p {
          font-family: 'opensans', sans-serif;
          font-weight: 400;
          font-size: 1rem;
          line-height: 1.375rem; }
          main.home div.panel.sub-home .bundle div.teaser div.text p::after {
            content: "";
            font-family: 'icon';
            -webkit-font-smoothing: antialiased;
            -moz-osx-font-smoothing: grayscale;
            font-weight: 400;
            font-size: 1rem;
            line-height: 1.375rem;
            color: #ace3fd;
            padding-left: 0.5rem; }
      main.home div.panel.sub-home .bundle div.teaser a {
        color: #283750; }
      main.home div.panel.sub-home .bundle div.teaser a:hover div.text h3 {
        color: #283750; }

main.menu .panel.intro-menu {
  height: calc(100vh - 6.0rem);
  overflow: hidden;
  margin-bottom: 4.0rem; }
  main.menu .panel.intro-menu div.bundle {
    height: 100%; }
    main.menu .panel.intro-menu div.bundle div.message {
      height: calc(40vh - 6.0rem);
      position: relative;
      top: 0;
      width: calc(92vw - 7.5rem);
      max-width: calc(1320px - 7.5rem);
      margin-left: auto;
      margin-right: auto; }
      main.menu .panel.intro-menu div.bundle div.message .headlines {
        width: 100%;
        position: absolute;
        top: 65%;
        left: 50%;
        -webkit-transform: translate(-50%, -50%);
        -ms-transform: translate(-50%, -50%);
        transform: translate(-50%, -50%); }
    main.menu .panel.intro-menu div.bundle div.gal {
      height: 60vh !important;
      position: absolute;
      width: 100%;
      bottom: 0;
      display: -webkit-box;
      display: -moz-box;
      display: -ms-flexbox;
      display: -webkit-flex;
      display: flex;
      -webkit-flex-wrap: wrap;
      -moz-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
      flex-wrap: wrap;
      -webkit-align-items: flex-start;
      align-items: flex-start;
      -webkit-justify-content: space-between;
      justify-content: space-between; }
    main.menu .panel.intro-menu div.bundle figure {
      display: block;
      width: 100% !important;
      height: 100% !important; }
      main.menu .panel.intro-menu div.bundle figure picture {
        display: block;
        width: 100% !important;
        height: 100% !important; }
        main.menu .panel.intro-menu div.bundle figure picture img {
          display: block;
          width: 100% !important;
          height: 100% !important;
          object-fit: cover !important; }
    main.menu .panel.intro-menu div.bundle.col-2 figure {
      width: calc((100% - 1.0rem) / 2) !important; }
    main.menu .panel.intro-menu div.bundle.col-2.span-1 figure, main.menu .panel.intro-menu div.bundle.col-2.span-2 figure, main.menu .panel.intro-menu div.bundle.col-2.span-3 figure {
      width: calc((100% - 2.0rem) / 3) !important; }
    main.menu .panel.intro-menu div.bundle.col-2.span-1 figure:nth-child(1), main.menu .panel.intro-menu div.bundle.col-2.span-2 figure:nth-child(2) {
      width: calc((((100% - 2.0rem) / 3) * 2) + 1.0rem) !important; }
    main.menu .panel.intro-menu div.bundle.col-3 figure {
      width: calc((100% - 2.0rem) / 3) !important; }
    main.menu .panel.intro-menu div.bundle.col-3.span-1 figure, main.menu .panel.intro-menu div.bundle.col-3.span-2 figure, main.menu .panel.intro-menu div.bundle.col-3.span-3 figure {
      width: calc((100% - 3.0rem) / 4) !important; }
    main.menu .panel.intro-menu div.bundle.col-3.span-1 figure:nth-child(1), main.menu .panel.intro-menu div.bundle.col-3.span-2 figure:nth-child(2), main.menu .panel.intro-menu div.bundle.col-3.span-3 figure:nth-child(3) {
      width: calc((((100% - 3.0rem) / 4) * 2) + 1.0rem) !important; }
    main.menu .panel.intro-menu div.bundle.col-4 figure {
      width: calc((100% - 3.0rem) / 4) !important; }

main.menu .panel.sub-menu .bundle {
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: nowrap;
  -moz-flex-wrap: nowrap;
  -ms-flex-wrap: nowrap;
  flex-wrap: nowrap;
  -webkit-align-items: stretch;
  align-items: stretch;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  -webkit-flex-direction: horizontal;
  -moz-flex-direction: horizontal;
  -ms-flex-direction: row;
  -webkit-flex-direction: row;
  flex-direction: row; }
  main.menu .panel.sub-menu .bundle div.teasers, main.menu .panel.sub-menu .bundle div.text {
    width: calc((100% - 1.0rem) / 2); }
  main.menu .panel.sub-menu .bundle div.teasers {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -webkit-flex-wrap: wrap;
    -moz-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-align-items: stretch;
    align-items: stretch;
    -webkit-justify-content: space-between;
    justify-content: space-between; }
    main.menu .panel.sub-menu .bundle div.teasers div.teaser {
      width: calc((100% - 1.0rem) / 2);
      border-top: 0.5rem solid rgba(40, 55, 80, 0.75);
      padding-top: 0.5rem;
      margin-bottom: 1.0rem; }
      main.menu .panel.sub-menu .bundle div.teasers div.teaser figure, main.menu .panel.sub-menu .bundle div.teasers div.teaser picture {
        display: block;
        width: 100%;
        aspect-ratio: 3/2; }
        @supports not (aspect-ratio: 3/2) {
          main.menu .panel.sub-menu .bundle div.teasers div.teaser figure::before, main.menu .panel.sub-menu .bundle div.teasers div.teaser picture::before {
            float: left;
            padding-top: 66.6666666667%;
            content: ''; }
          main.menu .panel.sub-menu .bundle div.teasers div.teaser figure::after, main.menu .panel.sub-menu .bundle div.teasers div.teaser picture::after {
            display: block;
            content: '';
            clear: both; } }
        main.menu .panel.sub-menu .bundle div.teasers div.teaser figure img, main.menu .panel.sub-menu .bundle div.teasers div.teaser picture img {
          display: block;
          width: 100% !important;
          height: 100% !important;
          object-fit: cover !important; }
      main.menu .panel.sub-menu .bundle div.teasers div.teaser div.text {
        width: 100%; }
        main.menu .panel.sub-menu .bundle div.teasers div.teaser div.text h2 {
          font-family: 'opensans', sans-serif;
          font-weight: 700;
          font-size: 1.125rem;
          line-height: 1.375rem;
          padding: 0.5rem 0 0.25rem 0;
          color: #ace3fd; }
        main.menu .panel.sub-menu .bundle div.teasers div.teaser div.text p {
          font-family: 'opensans', sans-serif;
          font-weight: 400;
          font-size: 1rem;
          line-height: 1.375rem; }
          main.menu .panel.sub-menu .bundle div.teasers div.teaser div.text p::after {
            content: "";
            font-family: 'icon';
            -webkit-font-smoothing: antialiased;
            -moz-osx-font-smoothing: grayscale;
            font-weight: 400;
            font-size: 1rem;
            line-height: 1.375rem;
            color: #ace3fd;
            padding-left: 0.5rem; }
      main.menu .panel.sub-menu .bundle div.teasers div.teaser a {
        color: #283750; }
      main.menu .panel.sub-menu .bundle div.teasers div.teaser a:hover div.text h2 {
        color: #283750; }
  main.menu .panel.sub-menu .bundle.textright {
    -webkit-flex-direction: horizontal-reverse;
    -moz-flex-direction: horizontal-reverse;
    -ms-flex-direction: column-reverse;
    -webkit-flex-direction: row-reverse;
    flex-direction: row-reverse; }
  main.menu .panel.sub-menu .bundle.notext div.teasers {
    width: 100%; }
    main.menu .panel.sub-menu .bundle.notext div.teasers div.teaser {
      width: calc((100% - 3.0rem) / 4); }

main.product div.gal {
  height: 40vh !important;
  overflow: hidden; }
  main.product div.gal figure {
    display: block;
    width: 100% !important;
    height: 100% !important; }
    main.product div.gal figure picture {
      display: block;
      width: 100% !important;
      height: 100% !important; }
      main.product div.gal figure picture img {
        display: block;
        width: 100% !important;
        height: 100% !important;
        object-fit: cover !important; }

main.product div.panel.product .bundle {
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: nowrap;
  -moz-flex-wrap: nowrap;
  -ms-flex-wrap: nowrap;
  flex-wrap: nowrap;
  -webkit-flex-direction: horizontal-reverse;
  -moz-flex-direction: horizontal-reverse;
  -ms-flex-direction: column-reverse;
  -webkit-flex-direction: row-reverse;
  flex-direction: row-reverse;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  margin-top: 3.0rem; }
  main.product div.panel.product .bundle div.body {
    width: calc(66.6666% - 1.0rem); }
  main.product div.panel.product .bundle div.data {
    width: calc(33.3333% - 1.0rem);
    font-family: 'opensans', sans-serif;
    font-weight: 400;
    font-size: 0.9375rem;
    line-height: 1.25rem; }
    main.product div.panel.product .bundle div.data figure {
      aspect-ratio: 2/1;
      width: 100%;
      overflow: hidden;
      border: 1px solid rgba(40, 55, 80, 0.35);
      margin-bottom: 0.125rem; }
      @supports not (aspect-ratio: 2/1) {
        main.product div.panel.product .bundle div.data figure::before {
          float: left;
          padding-top: 50%;
          content: ''; }
        main.product div.panel.product .bundle div.data figure::after {
          display: block;
          content: '';
          clear: both; } }
      main.product div.panel.product .bundle div.data figure img {
        display: block;
        width: 100% !important;
        height: 100% !important;
        object-fit: cover !important; }

main.contact div.panel.map {
  margin-bottom: 3.0rem; }
  main.contact div.panel.map .bundle {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -webkit-flex-wrap: wrap;
    -moz-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-align-items: flex-start;
    align-items: flex-start;
    -webkit-justify-content: space-between;
    justify-content: space-between;
    position: relative;
    height: 50vh; }
    main.contact div.panel.map .bundle .osm-map, main.contact div.panel.map .bundle .gal {
      width: calc((100% - 1.0rem) / 2);
      height: 100%; }
    main.contact div.panel.map .bundle .gal figure, main.contact div.panel.map .bundle .gal figure picture {
      height: 100%; }
    main.contact div.panel.map .bundle .gal figure img {
      display: block;
      height: 100% !important;
      width: 100% !important;
      object-fit: cover; }

main.contact div.panel.contact .bundle {
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-align-items: flex-start;
  align-items: flex-start;
  -webkit-justify-content: space-between;
  justify-content: space-between; }
  main.contact div.panel.contact .bundle .text {
    width: calc((100% - 1.0rem) / 2);
    margin: 0;
    padding-top: 3.125rem; }

main.contact_form {
  background-color: rgba(40, 55, 80, 0.25); }
  main.contact_form div.panel.form {
    padding: 0 0 5.0rem 0;
    margin-bottom: 0; }
    main.contact_form div.panel.form .title {
      padding: 5.0rem 0 2.0rem 0; }
      main.contact_form div.panel.form .title h1 {
        padding: 0;
        margin: 0;
        color: #ace3fd; }
    main.contact_form div.panel.form h2 {
      color: #283750; }
    main.contact_form div.panel.form p.error {
      padding: 0.25rem 0.5rem;
      font-family: 'opensans', sans-serif;
      font-weight: 500;
      font-size: 1.125rem;
      line-height: 1.375rem;
      width: 100%;
      background-color: #ffdc64; }
    main.contact_form div.panel.form form {
      display: -webkit-box;
      display: -moz-box;
      display: -ms-flexbox;
      display: -webkit-flex;
      display: flex;
      -webkit-flex-wrap: wrap;
      -moz-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
      flex-wrap: wrap;
      -webkit-justify-content: space-between;
      justify-content: space-between;
      -webkit-align-items: space-between;
      align-items: space-between;
      margin-top: 2.0rem; }
    main.contact_form div.panel.form input[type=text], main.contact_form div.panel.form input[type=password], main.contact_form div.panel.form input[type=email], main.contact_form div.panel.form textarea {
      -webkit-appearance: none;
      -moz-appearance: none;
      appearance: none;
      color: #283750;
      border-radius: 0;
      background: white;
      font-family: 'notoserif', serif;
      font-weight: 400;
      font-size: 1.125rem;
      line-height: 1.5rem;
      padding: 1.75rem 0.5rem 1.125rem 0.5rem;
      border: 1px solid rgba(40, 55, 80, 0.15);
      border-top: 1px solid rgba(40, 55, 80, 0.4);
      border-left: 1px solid rgba(40, 55, 80, 0.4);
      width: 100%;
      transition: all .3s linear; }
      main.contact_form div.panel.form input[type=text]:focus, main.contact_form div.panel.form input[type=password]:focus, main.contact_form div.panel.form input[type=email]:focus, main.contact_form div.panel.form textarea:focus {
        outline: 0; }
      main.contact_form div.panel.form input[type=text].error, main.contact_form div.panel.form input[type=password].error, main.contact_form div.panel.form input[type=email].error, main.contact_form div.panel.form textarea.error {
        background: #ffdc64; }
        main.contact_form div.panel.form input[type=text].error::-webkit-input-placeholder, main.contact_form div.panel.form input[type=password].error::-webkit-input-placeholder, main.contact_form div.panel.form input[type=email].error::-webkit-input-placeholder, main.contact_form div.panel.form textarea.error::-webkit-input-placeholder {
          color: #ffdc64;
          font-weight: 500; }
        main.contact_form div.panel.form input[type=text].error:-moz-placeholder, main.contact_form div.panel.form input[type=password].error:-moz-placeholder, main.contact_form div.panel.form input[type=email].error:-moz-placeholder, main.contact_form div.panel.form textarea.error:-moz-placeholder {
          color: #ffdc64;
          font-weight: 500; }
        main.contact_form div.panel.form input[type=text].error::-moz-placeholder, main.contact_form div.panel.form input[type=password].error::-moz-placeholder, main.contact_form div.panel.form input[type=email].error::-moz-placeholder, main.contact_form div.panel.form textarea.error::-moz-placeholder {
          color: #ffdc64;
          font-weight: 500; }
        main.contact_form div.panel.form input[type=text].error:-ms-input-placeholder, main.contact_form div.panel.form input[type=password].error:-ms-input-placeholder, main.contact_form div.panel.form input[type=email].error:-ms-input-placeholder, main.contact_form div.panel.form textarea.error:-ms-input-placeholder {
          color: #ffdc64;
          font-weight: 500; }
    main.contact_form div.panel.form textarea {
      width: 100%;
      height: 18.0rem; }
    main.contact_form div.panel.form select {
      -webkit-appearance: none;
      -moz-appearance: none;
      appearance: none;
      border-radius: 0;
      width: calc((100% - 1.5rem) / 2);
      cursor: pointer;
      padding: 1.0rem 0.5rem;
      font-family: 'opensans', sans-serif;
      font-weight: 400;
      font-size: 1.125rem;
      line-height: 1.5rem;
      color: rgba(40, 55, 80, 0.7);
      background: white url(../css_gfx/bg_select.svg) 95% center no-repeat;
      background-size: 0.75rem auto;
      border: 1px solid rgba(40, 55, 80, 0.15);
      border-bottom: 1px solid rgba(40, 55, 80, 0.4);
      border-right: 1px solid rgba(40, 55, 80, 0.4); }
      main.contact_form div.panel.form select.error {
        background-color: #ffdc64; }
    main.contact_form div.panel.form div.formrow {
      width: calc((100% - 1.5rem) / 2);
      position: relative;
      margin-bottom: 1.0rem;
      clear: both; }
      main.contact_form div.panel.form div.formrow.span-2 {
        width: 100%; }
      main.contact_form div.panel.form div.formrow.block {
        display: block;
        width: 100%; }
      main.contact_form div.panel.form div.formrow.confirm {
        display: none !important; }
      main.contact_form div.panel.form div.formrow.submit {
        margin-top: 2.0rem; }
      main.contact_form div.panel.form div.formrow.wide {
        margin: 1.5rem 0 4.0rem 0; }
      main.contact_form div.panel.form div.formrow label {
        position: absolute;
        left: 0;
        top: calc(10% - 0.75rem);
        opacity: 0;
        transition: all .25s ease;
        font-family: 'opensans', sans-serif;
        font-weight: 400;
        font-size: 1.5rem;
        line-height: 1.5rem; }
        main.contact_form div.panel.form div.formrow label.error {
          background-color: #ffdc64; }
      main.contact_form div.panel.form div.formrow input[type=text]::-webkit-input-placeholder, main.contact_form div.panel.form div.formrow textarea::-webkit-input-placeholder {
        font-family: 'opensans', sans-serif;
        font-weight: 400;
        font-size: 1.125rem;
        line-height: 1.5rem;
        color: rgba(40, 55, 80, 0.7);
        opacity: 1; }
      main.contact_form div.panel.form div.formrow input[type=text]:-moz-placeholder, main.contact_form div.panel.form div.formrow textarea:-moz-placeholder {
        font-family: 'opensans', sans-serif;
        font-weight: 400;
        font-size: 1.125rem;
        line-height: 1.5rem;
        color: rgba(40, 55, 80, 0.7);
        opacity: 1; }
      main.contact_form div.panel.form div.formrow input[type=text]::-moz-placeholder, main.contact_form div.panel.form div.formrow textarea::-moz-placeholder {
        font-family: 'opensans', sans-serif;
        font-weight: 400;
        font-size: 1.125rem;
        line-height: 1.5rem;
        color: rgba(40, 55, 80, 0.7);
        opacity: 1; }
      main.contact_form div.panel.form div.formrow input[type=text]:-ms-input-placeholder, main.contact_form div.panel.form div.formrow textarea:-ms-input-placeholder {
        font-family: 'opensans', sans-serif;
        font-weight: 400;
        font-size: 1.125rem;
        line-height: 1.5rem;
        color: rgba(40, 55, 80, 0.7);
        opacity: 1; }
      main.contact_form div.panel.form div.formrow input[type=text]:focus::-webkit-input-placeholder, main.contact_form div.panel.form div.formrow textarea:focus::-webkit-input-placeholder {
        color: transparent; }
      main.contact_form div.panel.form div.formrow input[type=text]:focus:-moz-placeholder, main.contact_form div.panel.form div.formrow textarea:focus:-moz-placeholder {
        color: transparent; }
      main.contact_form div.panel.form div.formrow input[type=text]:focus::-moz-placeholder, main.contact_form div.panel.form div.formrow textarea:focus::-moz-placeholder {
        color: transparent; }
      main.contact_form div.panel.form div.formrow input[type=text]:focus:-ms-input-placeholder, main.contact_form div.panel.form div.formrow textarea:focus:-ms-input-placeholder {
        color: transparent; }
      main.contact_form div.panel.form div.formrow input[type=text]:focus + label,
      main.contact_form div.panel.form div.formrow textarea:focus + label,
      main.contact_form div.panel.form div.formrow input[type=text]:not(:placeholder-shown) + label,
      main.contact_form div.panel.form div.formrow textarea:not(:placeholder-shown) + label {
        top: 0.25rem;
        left: 0.5rem;
        opacity: 1.0;
        color: #ace3fd;
        font-family: 'opensans', sans-serif;
        font-weight: 400;
        font-size: 0.875rem;
        line-height: 1.125rem; }
      main.contact_form div.panel.form div.formrow.checkradio {
        position: relative;
        margin: 2.0rem 0 3.0rem 0;
        color: #283750; }
        main.contact_form div.panel.form div.formrow.checkradio label {
          display: block;
          position: static;
          left: auto;
          top: auto;
          opacity: 1.0;
          cursor: pointer;
          font-family: 'notoserif', serif;
          font-weight: 400;
          font-size: 1.125rem;
          line-height: 1.5rem;
          padding-left: 2.25rem; }
    main.contact_form div.panel.form input[type=checkbox], main.contact_form div.panel.form input[type=radio] {
      display: none; }
    main.contact_form div.panel.form input[type=checkbox] + label, main.contact_form div.panel.form input[type=radio] + label {
      position: relative;
      padding: 0 0 0 1.25rem;
      display: block; }
    main.contact_form div.panel.form input[type=checkbox] + label span, main.contact_form div.panel.form input[type=radio] + label span {
      display: block;
      width: 1.0rem;
      height: 1.0rem;
      position: absolute;
      left: 0.5rem;
      top: 0.25rem;
      background-color: transparent;
      background-size: contain;
      cursor: pointer; }
    main.contact_form div.panel.form input[type=checkbox] + label span {
      background-image: url(../css_gfx/bg_check.svg);
      background-color: white; }
    main.contact_form div.panel.form input[type=radio] + label span {
      background-image: url(../css_gfx/bg_radio.svg);
      background-color: white;
      -webkit-border-radius: 50%;
      -moz-border-radius: 50%;
      -ms-border-radius: 50%;
      border-radius: 50%; }
    main.contact_form div.panel.form input[type=checkbox]:checked + label span, main.contact_form div.panel.form input[type=radio]:checked + label span {
      background-color: #ace3fd; }
    main.contact_form div.panel.form button:not(.linkbutton) {
      font-family: 'opensans', sans-serif;
      font-weight: 700;
      font-size: 1rem;
      line-height: 1.125rem;
      text-transform: uppercase;
      letter-spacing: 0.05rem;
      padding: 0.75rem 2.0rem;
      background: #283750;
      color: white;
      cursor: pointer; }
      main.contact_form div.panel.form button:not(.linkbutton).inactive {
        background: rgba(40, 55, 80, 0.1) !important;
        cursor: default; }
      main.contact_form div.panel.form button:not(.linkbutton):hover {
        background: #ace3fd; }
      main.contact_form div.panel.form button:not(.linkbutton)::after {
        font-family: 'icon';
        -webkit-font-smoothing: antialiased;
        -moz-osx-font-smoothing: grayscale;
        font-weight: 400;
        font-size: 1.0625rem;
        line-height: 1.125rem;
        content: "\e813";
        padding: 0 0.75rem;
        position: relative;
        top: 2px; }
      main.contact_form div.panel.form button:not(.linkbutton) span {
        display: block;
        width: 0;
        height: 0;
        overflow: hidden; }

main.searchresult h1 {
  color: #283750; }
  main.searchresult h1 span {
    color: #ace3fd; }

main.searchresult div.result {
  margin-bottom: 2.0rem;
  padding-bottom: 2.0rem;
  border-bottom: 1px solid #283750; }
  main.searchresult div.result a {
    color: #283750; }
    main.searchresult div.result a:hover {
      text-decoration: none; }
  main.searchresult div.result mark {
    background: rgba(172, 227, 253, 0.1); }
  main.searchresult div.result p.parent {
    color: #ace3fd;
    font-family: 'opensans', sans-serif;
    font-weight: 500;
    font-size: 0.75rem;
    line-height: 0.875rem;
    text-transform: uppercase;
    letter-spacing: 0.125rem; }
  main.searchresult div.result h2 {
    font-family: 'opensans', sans-serif;
    font-weight: 700;
    font-size: 1.5rem;
    line-height: 1.75rem;
    padding: 0 0 0.5rem 0; }

main.photos .panel.sub-photos .bundle div.teasers, main.photos_album .panel.sub-photos .bundle div.teasers {
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-align-items: stretch;
  align-items: stretch;
  -webkit-justify-content: flex-start;
  justify-content: flex-start;
  gap: 1.0rem; }
  main.photos .panel.sub-photos .bundle div.teasers div.teaser, main.photos_album .panel.sub-photos .bundle div.teasers div.teaser {
    width: calc((100% - 2.0rem) / 3); }
    main.photos .panel.sub-photos .bundle div.teasers div.teaser figure, main.photos_album .panel.sub-photos .bundle div.teasers div.teaser figure {
      display: block;
      width: 100%;
      aspect-ratio: 3/2; }
      @supports not (aspect-ratio: 3/2) {
        main.photos .panel.sub-photos .bundle div.teasers div.teaser figure::before, main.photos_album .panel.sub-photos .bundle div.teasers div.teaser figure::before {
          float: left;
          padding-top: 66.6666666667%;
          content: ''; }
        main.photos .panel.sub-photos .bundle div.teasers div.teaser figure::after, main.photos_album .panel.sub-photos .bundle div.teasers div.teaser figure::after {
          display: block;
          content: '';
          clear: both; } }
      main.photos .panel.sub-photos .bundle div.teasers div.teaser figure img, main.photos_album .panel.sub-photos .bundle div.teasers div.teaser figure img {
        display: block;
        width: 100% !important;
        height: 100% !important;
        object-fit: cover !important;
        border: 1px solid white; }
    main.photos .panel.sub-photos .bundle div.teasers div.teaser h2, main.photos_album .panel.sub-photos .bundle div.teasers div.teaser h2 {
      font-family: 'opensans', sans-serif;
      font-weight: 700;
      font-size: 1.25rem;
      line-height: 1.375rem;
      padding: 0.75rem 0 0.25rem 0;
      color: white; }
    main.photos .panel.sub-photos .bundle div.teasers div.teaser h3, main.photos_album .panel.sub-photos .bundle div.teasers div.teaser h3 {
      font-family: 'opensans', sans-serif;
      font-weight: 400;
      font-size: 1rem;
      line-height: 1.375rem;
      padding: 0 0 0.5rem 0;
      color: white; }
    main.photos .panel.sub-photos .bundle div.teasers div.teaser p, main.photos_album .panel.sub-photos .bundle div.teasers div.teaser p {
      font-family: 'opensans', sans-serif;
      font-weight: 400;
      font-size: 0.9375rem;
      line-height: 1.375rem; }
    main.photos .panel.sub-photos .bundle div.teasers div.teaser a, main.photos_album .panel.sub-photos .bundle div.teasers div.teaser a {
      color: white; }

main.photos .panel.photos-album .bundle #lightgallery, main.photos_album .panel.photos-album .bundle #lightgallery {
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-align-items: flex-start;
  align-items: flex-start;
  -webkit-justify-content: flex-start;
  justify-content: flex-start;
  gap: 0.75rem; }
  main.photos .panel.photos-album .bundle #lightgallery figure, main.photos_album .panel.photos-album .bundle #lightgallery figure {
    width: calc((100% - 5.25rem) / 8);
    border: 1px solid rgba(255, 255, 255, 0.5);
    position: relative;
    aspect-ratio: 1/1; }
    @supports not (aspect-ratio: 1/1) {
      main.photos .panel.photos-album .bundle #lightgallery figure::before, main.photos_album .panel.photos-album .bundle #lightgallery figure::before {
        float: left;
        padding-top: 100%;
        content: ''; }
      main.photos .panel.photos-album .bundle #lightgallery figure::after, main.photos_album .panel.photos-album .bundle #lightgallery figure::after {
        display: block;
        content: '';
        clear: both; } }
    main.photos .panel.photos-album .bundle #lightgallery figure img, main.photos_album .panel.photos-album .bundle #lightgallery figure img {
      max-width: 75% !important;
      max-height: 75% !important;
      position: absolute;
      top: 50%;
      left: 50%;
      -webkit-transform: translate(-50%, -50%);
      -ms-transform: translate(-50%, -50%);
      transform: translate(-50%, -50%); }
    main.photos .panel.photos-album .bundle #lightgallery figure figcaption, main.photos_album .panel.photos-album .bundle #lightgallery figure figcaption {
      display: inline-block;
      position: absolute;
      bottom: 0.25rem;
      font-family: 'opensans', sans-serif;
      font-weight: 400;
      font-size: 0.9375rem;
      line-height: 1.25rem;
      position: absolute;
      top: auto;
      left: 50%;
      -webkit-transform: translate(-50%, 0);
      -ms-transform: translate(-50%, 0);
      transform: translate(-50%, 0);
      color: rgba(255, 255, 255, 0.5); }
    main.photos .panel.photos-album .bundle #lightgallery figure:hover, main.photos_album .panel.photos-album .bundle #lightgallery figure:hover {
      border: 1px solid white;
      cursor: pointer; }
      main.photos .panel.photos-album .bundle #lightgallery figure:hover figcaption, main.photos_album .panel.photos-album .bundle #lightgallery figure:hover figcaption {
        color: white; }

@media screen and (max-width: 1800px) {
  main.photos .panel.photos-album .bundle #lightgallery figure, main.photos_album .panel.photos-album .bundle #lightgallery figure {
    width: calc((100% - 4.5rem) / 7); } }

@media screen and (max-width: 1600px) {
  main.photos .panel.photos-album .bundle #lightgallery figure, main.photos_album .panel.photos-album .bundle #lightgallery figure {
    width: calc((100% - 3.75rem) / 6); } }

@media screen and (max-width: 1200px) {
  main.photos .panel.photos-album .bundle #lightgallery figure, main.photos_album .panel.photos-album .bundle #lightgallery figure {
    width: calc((100% - 3.0rem) / 5); } }

@media screen and (max-width: 1024px) {
  main.photos .panel.sub-photos .bundle div.teasers div.teaser, main.photos_album .panel.sub-photos .bundle div.teasers div.teaser {
    width: calc((100% - 1.0rem) / 2); }
  main.photos .panel.photos-album .bundle #lightgallery figure, main.photos_album .panel.photos-album .bundle #lightgallery figure {
    width: calc((100% - 2.25rem) / 4); } }

@media screen and (max-width: 840px) {
  main.photos .panel.photos-album .bundle #lightgallery figure, main.photos_album .panel.photos-album .bundle #lightgallery figure {
    width: calc((100% - 1.5rem) / 3); } }

@media screen and (max-width: 680px) {
  main.photos .panel.sub-photos .bundle div.teasers div.teaser, main.photos_album .panel.sub-photos .bundle div.teasers div.teaser {
    width: 100%; }
  main.photos .panel.photos-album .bundle #lightgallery figure, main.photos_album .panel.photos-album .bundle #lightgallery figure {
    width: calc((100% - 0.75rem) / 2); } }

@media screen and (max-width: 420px) {
  main.photos .panel.photos-album .bundle #lightgallery figure, main.photos_album .panel.photos-album .bundle #lightgallery figure {
    width: 100%; } }

.PageProtectorForm, .page-protector-container {
  width: 20vw;
  max-width: 400px;
  height: 10.0rem;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%); }
  .PageProtectorForm p, .PageProtectorForm legend, .page-protector-container p, .page-protector-container legend {
    font-family: 'opensans', sans-serif;
    font-weight: 400;
    font-size: 1.0625rem;
    line-height: 1.5rem;
    display: block;
    width: 100%;
    margin-bottom: 1rem;
    color: white; }
  .PageProtectorForm input[type='text'], .PageProtectorForm input[type='password'], .page-protector-container input[type='text'], .page-protector-container input[type='password'] {
    width: 100%;
    font-family: 'opensans', sans-serif;
    font-weight: 400;
    font-size: 1.0625rem;
    line-height: 1.5rem;
    background: white;
    color: #283750;
    padding: 0.5rem 1.0rem;
    margin: 0.5rem 0; }
  .PageProtectorForm button, .page-protector-container button {
    font-family: 'opensans', sans-serif;
    font-weight: 700;
    font-size: 1rem;
    line-height: 1.125rem;
    text-transform: uppercase;
    letter-spacing: 0.05rem;
    padding: 0.75rem 2.0rem;
    margin: 0.5rem 0;
    background: #ace3fd;
    color: white;
    cursor: pointer; }
    .PageProtectorForm button:hover, .page-protector-container button:hover {
      background: #f7fcff; }

div.modalwrap {
  width: 100vw;
  height: 100vh;
  top: 0;
  position: fixed;
  z-index: 40;
  background: rgba(40, 55, 80, 0.9);
  opacity: 0;
  left: -10000px; }
  div.modalwrap div.modal {
    width: 60%;
    height: 80%;
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    background: white;
    max-width: 800px; }
    div.modalwrap div.modal iframe {
      width: 100% !important;
      height: 100% !important;
      overflow: scroll; }
  div.modalwrap.visible {
    opacity: 1.0;
    left: 0; }

a.special {
  display: block;
  position: fixed;
  width: 2.0rem;
  height: 2.0rem;
  cursor: pointer;
  z-index: 100;
  background: rgba(0, 0, 0, 0.5) center center no-repeat;
  background-size: contain;
  -webkit-border-radius: 0.125rem;
  -moz-border-radius: 0.125rem;
  -ms-border-radius: 0.125rem;
  border-radius: 0.125rem;
  color: white;
  transition: all 0.5s; }
  a.special::before, a.special::after {
    font-family: 'icon';
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    font-weight: 400;
    font-size: 1.5rem;
    line-height: 1.5rem;
    color: white;
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%); }
  a.special:hover {
    background-color: black; }
  a.special.burger {
    right: 2%;
    top: 2.0rem;
    display: none; }
    a.special.burger::before {
      content: "\e801"; }
  a.special.shut {
    right: 2%;
    top: 2.0rem;
    background: transparent; }
    a.special.shut::before {
      content: "\e802"; }
  a.special.shut.modal {
    right: 14%;
    top: 10%;
    background: transparent; }
    a.special.shut.modal::before {
      content: "\e802"; }
    a.special.shut.modal:hover {
      background-color: transparent; }
  a.special.scroll {
    right: 2%;
    bottom: 2.0rem;
    opacity: 0;
    transition: opacity 0.5s; }
    a.special.scroll::before {
      content: "\e810"; }
    a.special.scroll.temp {
      opacity: 1.0;
      transition: opacity 0.5s; }
    a.special.scroll.temp.footer {
      background-color: rgba(255, 255, 255, 0.5); }
  a.special.edit {
    right: 0;
    top: 0;
    opacity: 0.7; }
    a.special.edit::before {
      content: "\e825"; }
    a.special.edit:hover {
      opacity: 1 !important; }
  a.special.albumburger {
    top: 2%;
    right: 2%;
    background: transparent; }
    a.special.albumburger::before {
      content: "\e801"; }

/**
 * Swiper 4.5.0
 * Most modern mobile touch slider and framework with hardware accelerated transitions
 * http://www.idangero.us/swiper/
 *
 * Copyright 2014-2019 Vladimir Kharlampidi
 *
 * Released under the MIT License
 *
 * Released on: February 22, 2019
 */
.swiper-container {
  margin: 0 auto;
  position: relative;
  overflow: hidden;
  list-style: none;
  padding: 0;
  /* Fix of Webkit flickering */
  z-index: 1; }

.swiper-container-no-flexbox .swiper-slide {
  float: left; }

.swiper-container-vertical > .swiper-wrapper {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
  -ms-flex-direction: column;
  flex-direction: column; }

.swiper-wrapper {
  position: relative;
  width: 100%;
  height: 100%;
  z-index: 1;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-transition-property: -webkit-transform;
  transition-property: -webkit-transform;
  -o-transition-property: transform;
  transition-property: transform;
  transition-property: transform, -webkit-transform;
  -webkit-box-sizing: content-box;
  box-sizing: content-box; }

.swiper-container-android .swiper-slide,
.swiper-wrapper {
  -webkit-transform: translate3d(0px, 0, 0);
  transform: translate3d(0px, 0, 0); }

.swiper-container-multirow > .swiper-wrapper {
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap; }

.swiper-container-free-mode > .swiper-wrapper {
  -webkit-transition-timing-function: ease-out;
  -o-transition-timing-function: ease-out;
  transition-timing-function: ease-out;
  margin: 0 auto; }

.swiper-slide {
  -webkit-flex-shrink: 0;
  -ms-flex-negative: 0;
  flex-shrink: 0;
  width: 100%;
  height: 100%;
  position: relative;
  -webkit-transition-property: -webkit-transform;
  transition-property: -webkit-transform;
  -o-transition-property: transform;
  transition-property: transform;
  transition-property: transform, -webkit-transform; }

.swiper-slide-invisible-blank {
  visibility: hidden; }

/* Auto Height */
.swiper-container-autoheight,
.swiper-container-autoheight .swiper-slide {
  height: auto; }

.swiper-container-autoheight .swiper-wrapper {
  -webkit-box-align: start;
  -webkit-align-items: flex-start;
  -ms-flex-align: start;
  align-items: flex-start;
  -webkit-transition-property: height, -webkit-transform;
  transition-property: height, -webkit-transform;
  -o-transition-property: transform, height;
  transition-property: transform, height;
  transition-property: transform, height, -webkit-transform; }

/* 3D Effects */
.swiper-container-3d {
  -webkit-perspective: 1200px;
  perspective: 1200px; }

.swiper-container-3d .swiper-wrapper,
.swiper-container-3d .swiper-slide,
.swiper-container-3d .swiper-slide-shadow-left,
.swiper-container-3d .swiper-slide-shadow-right,
.swiper-container-3d .swiper-slide-shadow-top,
.swiper-container-3d .swiper-slide-shadow-bottom,
.swiper-container-3d .swiper-cube-shadow {
  -webkit-transform-style: preserve-3d;
  transform-style: preserve-3d; }

.swiper-container-3d .swiper-slide-shadow-left,
.swiper-container-3d .swiper-slide-shadow-right,
.swiper-container-3d .swiper-slide-shadow-top,
.swiper-container-3d .swiper-slide-shadow-bottom {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 10; }

.swiper-container-3d .swiper-slide-shadow-left {
  background-image: -webkit-gradient(linear, right top, left top, from(rgba(0, 0, 0, 0.5)), to(rgba(0, 0, 0, 0)));
  background-image: -webkit-linear-gradient(right, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
  background-image: -o-linear-gradient(right, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
  background-image: linear-gradient(to left, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0)); }

.swiper-container-3d .swiper-slide-shadow-right {
  background-image: -webkit-gradient(linear, left top, right top, from(rgba(0, 0, 0, 0.5)), to(rgba(0, 0, 0, 0)));
  background-image: -webkit-linear-gradient(left, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
  background-image: -o-linear-gradient(left, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
  background-image: linear-gradient(to right, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0)); }

.swiper-container-3d .swiper-slide-shadow-top {
  background-image: -webkit-gradient(linear, left bottom, left top, from(rgba(0, 0, 0, 0.5)), to(rgba(0, 0, 0, 0)));
  background-image: -webkit-linear-gradient(bottom, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
  background-image: -o-linear-gradient(bottom, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
  background-image: linear-gradient(to top, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0)); }

.swiper-container-3d .swiper-slide-shadow-bottom {
  background-image: -webkit-gradient(linear, left top, left bottom, from(rgba(0, 0, 0, 0.5)), to(rgba(0, 0, 0, 0)));
  background-image: -webkit-linear-gradient(top, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
  background-image: -o-linear-gradient(top, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
  background-image: linear-gradient(to bottom, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0)); }

/* IE10 Windows Phone 8 Fixes */
.swiper-container-wp8-horizontal,
.swiper-container-wp8-horizontal > .swiper-wrapper {
  -ms-touch-action: pan-y;
  touch-action: pan-y; }

.swiper-container-wp8-vertical,
.swiper-container-wp8-vertical > .swiper-wrapper {
  -ms-touch-action: pan-x;
  touch-action: pan-x; }

.swiper-button-prev,
.swiper-button-next {
  position: absolute;
  top: 50%;
  width: 27px;
  height: 44px;
  margin-top: -22px;
  z-index: 10;
  cursor: pointer;
  background-size: 27px 44px;
  background-position: center;
  background-repeat: no-repeat; }

.swiper-button-prev.swiper-button-disabled,
.swiper-button-next.swiper-button-disabled {
  opacity: 0.35;
  cursor: auto;
  pointer-events: none; }

.swiper-button-prev,
.swiper-container-rtl .swiper-button-next {
  background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%2027%2044'%3E%3Cpath%20d%3D'M0%2C22L22%2C0l2.1%2C2.1L4.2%2C22l19.9%2C19.9L22%2C44L0%2C22L0%2C22L0%2C22z'%20fill%3D'%23007aff'%2F%3E%3C%2Fsvg%3E");
  left: 10px;
  right: auto; }

.swiper-button-next,
.swiper-container-rtl .swiper-button-prev {
  background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%2027%2044'%3E%3Cpath%20d%3D'M27%2C22L27%2C22L5%2C44l-2.1-2.1L22.8%2C22L2.9%2C2.1L5%2C0L27%2C22L27%2C22z'%20fill%3D'%23007aff'%2F%3E%3C%2Fsvg%3E");
  right: 10px;
  left: auto; }

.swiper-button-prev.swiper-button-white,
.swiper-container-rtl .swiper-button-next.swiper-button-white {
  background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%2027%2044'%3E%3Cpath%20d%3D'M0%2C22L22%2C0l2.1%2C2.1L4.2%2C22l19.9%2C19.9L22%2C44L0%2C22L0%2C22L0%2C22z'%20fill%3D'%23ffffff'%2F%3E%3C%2Fsvg%3E"); }

.swiper-button-next.swiper-button-white,
.swiper-container-rtl .swiper-button-prev.swiper-button-white {
  background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%2027%2044'%3E%3Cpath%20d%3D'M27%2C22L27%2C22L5%2C44l-2.1-2.1L22.8%2C22L2.9%2C2.1L5%2C0L27%2C22L27%2C22z'%20fill%3D'%23ffffff'%2F%3E%3C%2Fsvg%3E"); }

.swiper-button-prev.swiper-button-black,
.swiper-container-rtl .swiper-button-next.swiper-button-black {
  background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%2027%2044'%3E%3Cpath%20d%3D'M0%2C22L22%2C0l2.1%2C2.1L4.2%2C22l19.9%2C19.9L22%2C44L0%2C22L0%2C22L0%2C22z'%20fill%3D'%23000000'%2F%3E%3C%2Fsvg%3E"); }

.swiper-button-next.swiper-button-black,
.swiper-container-rtl .swiper-button-prev.swiper-button-black {
  background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%2027%2044'%3E%3Cpath%20d%3D'M27%2C22L27%2C22L5%2C44l-2.1-2.1L22.8%2C22L2.9%2C2.1L5%2C0L27%2C22L27%2C22z'%20fill%3D'%23000000'%2F%3E%3C%2Fsvg%3E"); }

.swiper-button-lock {
  display: none; }

.swiper-pagination {
  position: absolute;
  text-align: center;
  -webkit-transition: 300ms opacity;
  -o-transition: 300ms opacity;
  transition: 300ms opacity;
  -webkit-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
  z-index: 10; }

.swiper-pagination.swiper-pagination-hidden {
  opacity: 0; }

/* Common Styles */
.swiper-pagination-fraction,
.swiper-pagination-custom,
.swiper-container-horizontal > .swiper-pagination-bullets {
  bottom: 10px;
  left: 0;
  width: 100%; }

/* Bullets */
.swiper-pagination-bullets-dynamic {
  overflow: hidden;
  font-size: 0; }

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  -webkit-transform: scale(0.33);
  -ms-transform: scale(0.33);
  transform: scale(0.33);
  position: relative; }

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active {
  -webkit-transform: scale(1);
  -ms-transform: scale(1);
  transform: scale(1); }

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-main {
  -webkit-transform: scale(1);
  -ms-transform: scale(1);
  transform: scale(1); }

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev {
  -webkit-transform: scale(0.66);
  -ms-transform: scale(0.66);
  transform: scale(0.66); }

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev-prev {
  -webkit-transform: scale(0.33);
  -ms-transform: scale(0.33);
  transform: scale(0.33); }

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next {
  -webkit-transform: scale(0.66);
  -ms-transform: scale(0.66);
  transform: scale(0.66); }

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next-next {
  -webkit-transform: scale(0.33);
  -ms-transform: scale(0.33);
  transform: scale(0.33); }

.swiper-pagination-bullet {
  width: 0.625rem;
  height: 0.625rem;
  display: inline-block;
  border-radius: none;
  background: #000;
  opacity: 0.2; }

button.swiper-pagination-bullet {
  border: none;
  margin: 0;
  padding: 0;
  -webkit-box-shadow: none;
  box-shadow: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none; }

.swiper-pagination-clickable .swiper-pagination-bullet {
  cursor: pointer; }

.swiper-pagination-bullet-active {
  opacity: 1;
  background: #007aff; }

.swiper-container-vertical > .swiper-pagination-bullets {
  right: 10px;
  top: 50%;
  -webkit-transform: translate3d(0px, -50%, 0);
  transform: translate3d(0px, -50%, 0); }

.swiper-container-vertical > .swiper-pagination-bullets .swiper-pagination-bullet {
  margin: 6px 0;
  display: block; }

.swiper-container-vertical > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic {
  top: 50%;
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  transform: translateY(-50%);
  width: 8px; }

.swiper-container-vertical > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  display: inline-block;
  -webkit-transition: 200ms top, 200ms -webkit-transform;
  transition: 200ms top, 200ms -webkit-transform;
  -o-transition: 200ms transform, 200ms top;
  transition: 200ms transform, 200ms top;
  transition: 200ms transform, 200ms top, 200ms -webkit-transform; }

.swiper-container-horizontal > .swiper-pagination-bullets .swiper-pagination-bullet {
  margin: 0 0.25rem; }

.swiper-container-horizontal > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic {
  left: 50%;
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  transform: translateX(-50%);
  white-space: nowrap; }

.swiper-container-horizontal > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  -webkit-transition: 200ms left, 200ms -webkit-transform;
  transition: 200ms left, 200ms -webkit-transform;
  -o-transition: 200ms transform, 200ms left;
  transition: 200ms transform, 200ms left;
  transition: 200ms transform, 200ms left, 200ms -webkit-transform; }

.swiper-container-horizontal.swiper-container-rtl > .swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  -webkit-transition: 200ms right, 200ms -webkit-transform;
  transition: 200ms right, 200ms -webkit-transform;
  -o-transition: 200ms transform, 200ms right;
  transition: 200ms transform, 200ms right;
  transition: 200ms transform, 200ms right, 200ms -webkit-transform; }

/* Progress */
.swiper-pagination-progressbar {
  background: rgba(0, 0, 0, 0.25);
  position: absolute; }

.swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
  background: #007aff;
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  -webkit-transform: scale(0);
  -ms-transform: scale(0);
  transform: scale(0);
  -webkit-transform-origin: left top;
  -ms-transform-origin: left top;
  transform-origin: left top; }

.swiper-container-rtl .swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
  -webkit-transform-origin: right top;
  -ms-transform-origin: right top;
  transform-origin: right top; }

.swiper-container-horizontal > .swiper-pagination-progressbar,
.swiper-container-vertical > .swiper-pagination-progressbar.swiper-pagination-progressbar-opposite {
  width: 100%;
  height: 4px;
  left: 0;
  top: 0; }

.swiper-container-vertical > .swiper-pagination-progressbar,
.swiper-container-horizontal > .swiper-pagination-progressbar.swiper-pagination-progressbar-opposite {
  width: 4px;
  height: 100%;
  left: 0;
  top: 0; }

.swiper-pagination-white .swiper-pagination-bullet-active {
  background: #ffffff; }

.swiper-pagination-progressbar.swiper-pagination-white {
  background: rgba(255, 255, 255, 0.25); }

.swiper-pagination-progressbar.swiper-pagination-white .swiper-pagination-progressbar-fill {
  background: #ffffff; }

.swiper-pagination-black .swiper-pagination-bullet-active {
  background: #000000; }

.swiper-pagination-progressbar.swiper-pagination-black {
  background: rgba(0, 0, 0, 0.25); }

.swiper-pagination-progressbar.swiper-pagination-black .swiper-pagination-progressbar-fill {
  background: #000000; }

.swiper-pagination-lock {
  display: none; }

/* Scrollbar */
.swiper-scrollbar {
  border-radius: 10px;
  position: relative;
  -ms-touch-action: none;
  background: rgba(0, 0, 0, 0.1); }

.swiper-container-horizontal > .swiper-scrollbar {
  position: absolute;
  left: 1%;
  bottom: 3px;
  z-index: 50;
  height: 5px;
  width: 98%; }

.swiper-container-vertical > .swiper-scrollbar {
  position: absolute;
  right: 3px;
  top: 1%;
  z-index: 50;
  width: 5px;
  height: 98%; }

.swiper-scrollbar-drag {
  height: 100%;
  width: 100%;
  position: relative;
  background: rgba(0, 0, 0, 0.5);
  border-radius: 10px;
  left: 0;
  top: 0; }

.swiper-scrollbar-cursor-drag {
  cursor: move; }

.swiper-scrollbar-lock {
  display: none; }

.swiper-zoom-container {
  width: 100%;
  height: 100%;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  text-align: center; }

.swiper-zoom-container > img,
.swiper-zoom-container > svg,
.swiper-zoom-container > canvas {
  max-width: 100%;
  max-height: 100%;
  -o-object-fit: contain;
  object-fit: contain; }

.swiper-slide-zoomed {
  cursor: move; }

/* Preloader */
.swiper-lazy-preloader {
  width: 42px;
  height: 42px;
  position: absolute;
  left: 50%;
  top: 50%;
  margin-left: -21px;
  margin-top: -21px;
  z-index: 10;
  -webkit-transform-origin: 50%;
  -ms-transform-origin: 50%;
  transform-origin: 50%;
  -webkit-animation: swiper-preloader-spin 1s steps(12, end) infinite;
  animation: swiper-preloader-spin 1s steps(12, end) infinite; }

.swiper-lazy-preloader:after {
  display: block;
  content: '';
  width: 100%;
  height: 100%;
  background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg%20viewBox%3D'0%200%20120%20120'%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20xmlns%3Axlink%3D'http%3A%2F%2Fwww.w3.org%2F1999%2Fxlink'%3E%3Cdefs%3E%3Cline%20id%3D'l'%20x1%3D'60'%20x2%3D'60'%20y1%3D'7'%20y2%3D'27'%20stroke%3D'%236c6c6c'%20stroke-width%3D'11'%20stroke-linecap%3D'round'%2F%3E%3C%2Fdefs%3E%3Cg%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.27'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.27'%20transform%3D'rotate(30%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.27'%20transform%3D'rotate(60%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.27'%20transform%3D'rotate(90%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.27'%20transform%3D'rotate(120%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.27'%20transform%3D'rotate(150%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.37'%20transform%3D'rotate(180%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.46'%20transform%3D'rotate(210%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.56'%20transform%3D'rotate(240%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.66'%20transform%3D'rotate(270%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.75'%20transform%3D'rotate(300%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.85'%20transform%3D'rotate(330%2060%2C60)'%2F%3E%3C%2Fg%3E%3C%2Fsvg%3E");
  background-position: 50%;
  background-size: 100%;
  background-repeat: no-repeat; }

.swiper-lazy-preloader-white:after {
  background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg%20viewBox%3D'0%200%20120%20120'%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20xmlns%3Axlink%3D'http%3A%2F%2Fwww.w3.org%2F1999%2Fxlink'%3E%3Cdefs%3E%3Cline%20id%3D'l'%20x1%3D'60'%20x2%3D'60'%20y1%3D'7'%20y2%3D'27'%20stroke%3D'%23fff'%20stroke-width%3D'11'%20stroke-linecap%3D'round'%2F%3E%3C%2Fdefs%3E%3Cg%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.27'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.27'%20transform%3D'rotate(30%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.27'%20transform%3D'rotate(60%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.27'%20transform%3D'rotate(90%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.27'%20transform%3D'rotate(120%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.27'%20transform%3D'rotate(150%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.37'%20transform%3D'rotate(180%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.46'%20transform%3D'rotate(210%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.56'%20transform%3D'rotate(240%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.66'%20transform%3D'rotate(270%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.75'%20transform%3D'rotate(300%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.85'%20transform%3D'rotate(330%2060%2C60)'%2F%3E%3C%2Fg%3E%3C%2Fsvg%3E"); }

@-webkit-keyframes swiper-preloader-spin {
  100% {
    -webkit-transform: rotate(360deg);
    transform: rotate(360deg); } }

@keyframes swiper-preloader-spin {
  100% {
    -webkit-transform: rotate(360deg);
    transform: rotate(360deg); } }

/* a11y */
.swiper-container .swiper-notification {
  position: absolute;
  left: 0;
  top: 0;
  pointer-events: none;
  opacity: 0;
  z-index: -1000; }

.swiper-container-fade.swiper-container-free-mode .swiper-slide {
  -webkit-transition-timing-function: ease-out;
  -o-transition-timing-function: ease-out;
  transition-timing-function: ease-out; }

.swiper-container-fade .swiper-slide {
  pointer-events: none;
  -webkit-transition-property: opacity;
  -o-transition-property: opacity;
  transition-property: opacity; }

.swiper-container-fade .swiper-slide .swiper-slide {
  pointer-events: none; }

.swiper-container-fade .swiper-slide-active,
.swiper-container-fade .swiper-slide-active .swiper-slide-active {
  pointer-events: auto; }

.swiper-container-cube {
  overflow: visible; }

.swiper-container-cube .swiper-slide {
  pointer-events: none;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  z-index: 1;
  visibility: hidden;
  -webkit-transform-origin: 0 0;
  -ms-transform-origin: 0 0;
  transform-origin: 0 0;
  width: 100%;
  height: 100%; }

.swiper-container-cube .swiper-slide .swiper-slide {
  pointer-events: none; }

.swiper-container-cube.swiper-container-rtl .swiper-slide {
  -webkit-transform-origin: 100% 0;
  -ms-transform-origin: 100% 0;
  transform-origin: 100% 0; }

.swiper-container-cube .swiper-slide-active,
.swiper-container-cube .swiper-slide-active .swiper-slide-active {
  pointer-events: auto; }

.swiper-container-cube .swiper-slide-active,
.swiper-container-cube .swiper-slide-next,
.swiper-container-cube .swiper-slide-prev,
.swiper-container-cube .swiper-slide-next + .swiper-slide {
  pointer-events: auto;
  visibility: visible; }

.swiper-container-cube .swiper-slide-shadow-top,
.swiper-container-cube .swiper-slide-shadow-bottom,
.swiper-container-cube .swiper-slide-shadow-left,
.swiper-container-cube .swiper-slide-shadow-right {
  z-index: 0;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden; }

.swiper-container-cube .swiper-cube-shadow {
  position: absolute;
  left: 0;
  bottom: 0px;
  width: 100%;
  height: 100%;
  background: #000;
  opacity: 0.6;
  -webkit-filter: blur(50px);
  filter: blur(50px);
  z-index: 0; }

.swiper-container-flip {
  overflow: visible; }

.swiper-container-flip .swiper-slide {
  pointer-events: none;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  z-index: 1; }

.swiper-container-flip .swiper-slide .swiper-slide {
  pointer-events: none; }

.swiper-container-flip .swiper-slide-active,
.swiper-container-flip .swiper-slide-active .swiper-slide-active {
  pointer-events: auto; }

.swiper-container-flip .swiper-slide-shadow-top,
.swiper-container-flip .swiper-slide-shadow-bottom,
.swiper-container-flip .swiper-slide-shadow-left,
.swiper-container-flip .swiper-slide-shadow-right {
  z-index: 0;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden; }

.swiper-container-coverflow .swiper-wrapper {
  /* Windows 8 IE 10 fix */
  -ms-perspective: 1200px; }

.swiper-pagination-bullet:only-child {
  visibility: hidden; }

.lg-icon {
  /* use !important to prevent issues with browser extensions that change fonts */
  font-family: 'icon';
  speak: never;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  /* Better Font Rendering =========== */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale; }

.lg-container {
  font-family: 'notoserif';
  font-style: italic; }

.lg-next,
.lg-prev {
  background-color: rgba(0, 0, 0, 0.45);
  background-color: transparent;
  border-radius: 2px;
  color: #999;
  cursor: pointer;
  display: block;
  font-size: 22px;
  margin-top: -10px;
  padding: 8px 10px 9px;
  position: absolute;
  top: 50%;
  z-index: 1084;
  outline: none;
  border: none; }

.lg-next.disabled,
.lg-prev.disabled {
  opacity: 0 !important;
  cursor: default; }

.lg-next:hover:not(.disabled),
.lg-prev:hover:not(.disabled) {
  color: #fff; }

.lg-single-item .lg-next, .lg-single-item
.lg-prev {
  display: none; }

.lg-next {
  right: 20px; }

.lg-next:before {
  content: '\e806'; }

.lg-prev {
  left: 20px; }

.lg-prev:after {
  content: '\e805'; }

@-webkit-keyframes lg-right-end {
  0% {
    left: 0; }
  50% {
    left: -30px; }
  100% {
    left: 0; } }

@-moz-keyframes lg-right-end {
  0% {
    left: 0; }
  50% {
    left: -30px; }
  100% {
    left: 0; } }

@-ms-keyframes lg-right-end {
  0% {
    left: 0; }
  50% {
    left: -30px; }
  100% {
    left: 0; } }

@keyframes lg-right-end {
  0% {
    left: 0; }
  50% {
    left: -30px; }
  100% {
    left: 0; } }

@-webkit-keyframes lg-left-end {
  0% {
    left: 0; }
  50% {
    left: 30px; }
  100% {
    left: 0; } }

@-moz-keyframes lg-left-end {
  0% {
    left: 0; }
  50% {
    left: 30px; }
  100% {
    left: 0; } }

@-ms-keyframes lg-left-end {
  0% {
    left: 0; }
  50% {
    left: 30px; }
  100% {
    left: 0; } }

@keyframes lg-left-end {
  0% {
    left: 0; }
  50% {
    left: 30px; }
  100% {
    left: 0; } }

.lg-outer.lg-right-end .lg-object {
  -webkit-animation: lg-right-end 0.3s;
  -o-animation: lg-right-end 0.3s;
  animation: lg-right-end 0.3s;
  position: relative; }

.lg-outer.lg-left-end .lg-object {
  -webkit-animation: lg-left-end 0.3s;
  -o-animation: lg-left-end 0.3s;
  animation: lg-left-end 0.3s;
  position: relative; }

.lg-toolbar {
  z-index: 1082;
  left: 0;
  position: absolute;
  top: 0;
  width: 100%; }

.lg-media-overlap .lg-toolbar {
  background-image: linear-gradient(0deg, rgba(0, 0, 0, 0), rgba(0, 0, 0, 0.4)); }

.lg-toolbar .lg-icon {
  color: #999;
  cursor: pointer;
  float: right;
  font-size: 24px;
  height: 47px;
  line-height: 27px;
  padding: 10px 0;
  text-align: center;
  width: 50px;
  text-decoration: none !important;
  outline: medium none;
  will-change: color;
  -webkit-transition: color 0.2s linear;
  -o-transition: color 0.2s linear;
  transition: color 0.2s linear;
  background: none;
  border: none;
  box-shadow: none; }

.lg-toolbar .lg-icon.lg-icon-18 {
  font-size: 18px; }

.lg-toolbar .lg-icon:hover {
  color: #fff; }

.lg-toolbar .lg-close:after {
  content: '\e802'; }

.lg-toolbar .lg-maximize {
  font-size: 22px; }

.lg-toolbar .lg-maximize:after {
  content: '\e826'; }

.lg-sub-html {
  color: #eee;
  font-size: 16px;
  padding: 10px 40px;
  text-align: center;
  z-index: 1080;
  opacity: 0;
  -webkit-transition: opacity 0.2s ease-out 0s;
  -o-transition: opacity 0.2s ease-out 0s;
  transition: opacity 0.2s ease-out 0s; }

.lg-sub-html h4 {
  margin: 0;
  font-size: 13px;
  font-weight: bold; }

.lg-sub-html p {
  font-size: 12px;
  margin: 5px 0 0; }

.lg-sub-html a {
  color: inherit; }

.lg-sub-html a:hover {
  text-decoration: underline; }

.lg-media-overlap .lg-sub-html {
  background-image: linear-gradient(180deg, rgba(0, 0, 0, 0), rgba(0, 0, 0, 0.6)); }

.lg-item .lg-sub-html {
  position: absolute;
  bottom: 0;
  right: 0;
  left: 0; }

.lg-error-msg {
  font-size: 14px;
  color: #999; }

.lg-counter {
  color: #999;
  display: inline-block;
  font-size: 16px;
  padding-left: 20px;
  padding-top: 12px;
  height: 47px;
  vertical-align: middle; }

.lg-closing .lg-toolbar,
.lg-closing .lg-prev,
.lg-closing .lg-next,
.lg-closing .lg-sub-html {
  opacity: 0;
  -webkit-transition: -webkit-transform 0.08 cubic-bezier(0, 0, 0.25, 1) 0s, opacity 0.08 cubic-bezier(0, 0, 0.25, 1) 0s, color 0.08 linear;
  -moz-transition: -moz-transform 0.08 cubic-bezier(0, 0, 0.25, 1) 0s, opacity 0.08 cubic-bezier(0, 0, 0.25, 1) 0s, color 0.08 linear;
  -o-transition: -o-transform 0.08 cubic-bezier(0, 0, 0.25, 1) 0s, opacity 0.08 cubic-bezier(0, 0, 0.25, 1) 0s, color 0.08 linear;
  transition: transform 0.08 cubic-bezier(0, 0, 0.25, 1) 0s, opacity 0.08 cubic-bezier(0, 0, 0.25, 1) 0s, color 0.08 linear; }

body:not(.lg-from-hash) .lg-outer.lg-start-zoom .lg-item:not(.lg-zoomable) .lg-img-wrap,
body:not(.lg-from-hash) .lg-outer.lg-start-zoom .lg-item:not(.lg-zoomable) .lg-video-cont {
  opacity: 0;
  -moz-transform: scale3d(0.5, 0.5, 0.5);
  -o-transform: scale3d(0.5, 0.5, 0.5);
  -ms-transform: scale3d(0.5, 0.5, 0.5);
  -webkit-transform: scale3d(0.5, 0.5, 0.5);
  transform: scale3d(0.5, 0.5, 0.5);
  will-change: transform, opacity;
  -webkit-transition: -webkit-transform 250ms cubic-bezier(0, 0, 0.25, 1) 0s, opacity 250ms cubic-bezier(0, 0, 0.25, 1) !important;
  -moz-transition: -moz-transform 250ms cubic-bezier(0, 0, 0.25, 1) 0s, opacity 250ms cubic-bezier(0, 0, 0.25, 1) !important;
  -o-transition: -o-transform 250ms cubic-bezier(0, 0, 0.25, 1) 0s, opacity 250ms cubic-bezier(0, 0, 0.25, 1) !important;
  transition: transform 250ms cubic-bezier(0, 0, 0.25, 1) 0s, opacity 250ms cubic-bezier(0, 0, 0.25, 1) !important; }

body:not(.lg-from-hash) .lg-outer.lg-start-zoom .lg-item:not(.lg-zoomable).lg-complete .lg-img-wrap,
body:not(.lg-from-hash) .lg-outer.lg-start-zoom .lg-item:not(.lg-zoomable).lg-complete .lg-video-cont {
  opacity: 1;
  -moz-transform: scale3d(1, 1, 1);
  -o-transform: scale3d(1, 1, 1);
  -ms-transform: scale3d(1, 1, 1);
  -webkit-transform: scale3d(1, 1, 1);
  transform: scale3d(1, 1, 1); }

.lg-icon:focus-visible {
  color: #fff;
  border-radius: 3px;
  outline: 1px dashed rgba(255, 255, 255, 0.6); }

.lg-toolbar .lg-icon:focus-visible {
  border-radius: 8px;
  outline-offset: -5px; }

.lg-group:after {
  content: '';
  display: table;
  clear: both; }

.lg-container {
  display: none;
  outline: none; }

.lg-container.lg-show {
  display: block; }

.lg-on {
  scroll-behavior: unset; }

.lg-overlay-open {
  overflow: hidden; }

.lg-toolbar,
.lg-prev,
.lg-next,
.lg-pager-outer,
.lg-hide-sub-html .lg-sub-html {
  opacity: 0;
  will-change: transform, opacity;
  -webkit-transition: -webkit-transform 0.25s cubic-bezier(0, 0, 0.25, 1) 0s, opacity 0.25s cubic-bezier(0, 0, 0.25, 1) 0s;
  -moz-transition: -moz-transform 0.25s cubic-bezier(0, 0, 0.25, 1) 0s, opacity 0.25s cubic-bezier(0, 0, 0.25, 1) 0s;
  -o-transition: -o-transform 0.25s cubic-bezier(0, 0, 0.25, 1) 0s, opacity 0.25s cubic-bezier(0, 0, 0.25, 1) 0s;
  transition: transform 0.25s cubic-bezier(0, 0, 0.25, 1) 0s, opacity 0.25s cubic-bezier(0, 0, 0.25, 1) 0s; }

.lg-show-in .lg-toolbar,
.lg-show-in .lg-prev,
.lg-show-in .lg-next,
.lg-show-in .lg-pager-outer {
  opacity: 1; }

.lg-show-in.lg-hide-sub-html .lg-sub-html {
  opacity: 1; }

.lg-show-in .lg-hide-items .lg-prev {
  opacity: 0;
  -webkit-transform: translate3d(-10px, 0, 0);
  transform: translate3d(-10px, 0, 0); }

.lg-show-in .lg-hide-items .lg-next {
  opacity: 0;
  -webkit-transform: translate3d(10px, 0, 0);
  transform: translate3d(10px, 0, 0); }

.lg-show-in .lg-hide-items .lg-toolbar {
  opacity: 0;
  -webkit-transform: translate3d(0, -10px, 0);
  transform: translate3d(0, -10px, 0); }

.lg-show-in .lg-hide-items.lg-hide-sub-html .lg-sub-html {
  opacity: 0;
  -webkit-transform: translate3d(0, 20px, 0);
  transform: translate3d(0, 20px, 0); }

.lg-outer {
  width: 100%;
  height: 100%;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 1050;
  text-align: left;
  opacity: 0.001;
  outline: none;
  will-change: auto;
  overflow: hidden;
  -webkit-transition: opacity 0.15s ease 0s;
  -o-transition: opacity 0.15s ease 0s;
  transition: opacity 0.15s ease 0s; }

.lg-outer * {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box; }

.lg-outer.lg-zoom-from-image {
  opacity: 1; }

.lg-outer.lg-visible {
  opacity: 1; }

.lg-outer.lg-css3 .lg-item:not(.lg-start-end-progress).lg-prev-slide, .lg-outer.lg-css3 .lg-item:not(.lg-start-end-progress).lg-next-slide, .lg-outer.lg-css3 .lg-item:not(.lg-start-end-progress).lg-current {
  -webkit-transition-duration: inherit !important;
  transition-duration: inherit !important;
  -webkit-transition-timing-function: inherit !important;
  transition-timing-function: inherit !important; }

.lg-outer.lg-css3.lg-dragging .lg-item.lg-prev-slide, .lg-outer.lg-css3.lg-dragging .lg-item.lg-next-slide, .lg-outer.lg-css3.lg-dragging .lg-item.lg-current {
  -webkit-transition-duration: 0s !important;
  transition-duration: 0s !important;
  opacity: 1; }

.lg-outer.lg-grab img.lg-object {
  cursor: -webkit-grab;
  cursor: -moz-grab;
  cursor: -o-grab;
  cursor: -ms-grab;
  cursor: grab; }

.lg-outer.lg-grabbing img.lg-object {
  cursor: move;
  cursor: -webkit-grabbing;
  cursor: -moz-grabbing;
  cursor: -o-grabbing;
  cursor: -ms-grabbing;
  cursor: grabbing; }

.lg-outer .lg-content {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0; }

.lg-outer .lg-inner {
  width: 100%;
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  -webkit-transition: opacity 0s;
  -o-transition: opacity 0s;
  transition: opacity 0s;
  white-space: nowrap; }

.lg-outer .lg-item {
  display: none !important; }

.lg-outer .lg-item:not(.lg-start-end-progress) {
  background: url("../images/loading.gif") no-repeat scroll center center transparent; }

.lg-outer.lg-css3 .lg-prev-slide,
.lg-outer.lg-css3 .lg-current,
.lg-outer.lg-css3 .lg-next-slide {
  display: inline-block !important; }

.lg-outer.lg-css .lg-current {
  display: inline-block !important; }

.lg-outer .lg-item,
.lg-outer .lg-img-wrap {
  display: inline-block;
  text-align: center;
  position: absolute;
  width: 100%;
  height: 100%; }

.lg-outer .lg-item:before,
.lg-outer .lg-img-wrap:before {
  content: '';
  display: inline-block;
  height: 100%;
  vertical-align: middle; }

.lg-outer .lg-img-wrap {
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
  white-space: nowrap;
  font-size: 0; }

.lg-outer .lg-item.lg-complete {
  background-image: none; }

.lg-outer .lg-item.lg-current {
  z-index: 1060; }

.lg-outer .lg-object {
  display: inline-block;
  vertical-align: middle;
  max-width: 100%;
  max-height: 100%;
  width: auto;
  height: auto;
  position: relative; }

.lg-outer .lg-empty-html.lg-sub-html,
.lg-outer .lg-empty-html .lg-sub-html {
  display: none; }

.lg-outer.lg-hide-download .lg-download {
  opacity: 0.75;
  pointer-events: none; }

.lg-outer .lg-first-slide .lg-dummy-img {
  position: absolute;
  top: 50%;
  left: 50%; }

.lg-outer.lg-components-open:not(.lg-zoomed) .lg-components {
  -webkit-transform: translate3d(0, 0%, 0);
  transform: translate3d(0, 0%, 0);
  opacity: 1; }

.lg-outer.lg-components-open:not(.lg-zoomed) .lg-sub-html {
  opacity: 1;
  transition: opacity 0.2s ease-out 0.15s; }

.lg-backdrop {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 1040;
  background-color: #283750;
  opacity: 0;
  will-change: auto;
  -webkit-transition: opacity 333ms ease-in 0s;
  -o-transition: opacity 333ms ease-in 0s;
  transition: opacity 333ms ease-in 0s; }

.lg-backdrop.in {
  opacity: 1; }

.lg-css3.lg-no-trans .lg-prev-slide,
.lg-css3.lg-no-trans .lg-next-slide,
.lg-css3.lg-no-trans .lg-current {
  -webkit-transition: none 0s ease 0s !important;
  -moz-transition: none 0s ease 0s !important;
  -o-transition: none 0s ease 0s !important;
  transition: none 0s ease 0s !important; }

.lg-css3.lg-use-css3 .lg-item {
  -webkit-backface-visibility: hidden;
  -moz-backface-visibility: hidden;
  backface-visibility: hidden; }

.lg-css3.lg-fade .lg-item {
  opacity: 0; }

.lg-css3.lg-fade .lg-item.lg-current {
  opacity: 1; }

.lg-css3.lg-fade .lg-item.lg-prev-slide, .lg-css3.lg-fade .lg-item.lg-next-slide, .lg-css3.lg-fade .lg-item.lg-current {
  -webkit-transition: opacity 0.1s ease 0s;
  -moz-transition: opacity 0.1s ease 0s;
  -o-transition: opacity 0.1s ease 0s;
  transition: opacity 0.1s ease 0s; }

.lg-css3.lg-use-css3 .lg-item.lg-start-progress {
  -webkit-transition: -webkit-transform 1s cubic-bezier(0.175, 0.885, 0.32, 1.275) 0s;
  -moz-transition: -moz-transform 1s cubic-bezier(0.175, 0.885, 0.32, 1.275) 0s;
  -o-transition: -o-transform 1s cubic-bezier(0.175, 0.885, 0.32, 1.275) 0s;
  transition: transform 1s cubic-bezier(0.175, 0.885, 0.32, 1.275) 0s; }

.lg-css3.lg-use-css3 .lg-item.lg-start-end-progress {
  -webkit-transition: -webkit-transform 1s cubic-bezier(0, 0, 0.25, 1) 0s;
  -moz-transition: -moz-transform 1s cubic-bezier(0, 0, 0.25, 1) 0s;
  -o-transition: -o-transform 1s cubic-bezier(0, 0, 0.25, 1) 0s;
  transition: transform 1s cubic-bezier(0, 0, 0.25, 1) 0s; }

.lg-css3.lg-slide.lg-use-css3 .lg-item {
  opacity: 0; }

.lg-css3.lg-slide.lg-use-css3 .lg-item.lg-prev-slide {
  -webkit-transform: translate3d(-100%, 0, 0);
  transform: translate3d(-100%, 0, 0); }

.lg-css3.lg-slide.lg-use-css3 .lg-item.lg-next-slide {
  -webkit-transform: translate3d(100%, 0, 0);
  transform: translate3d(100%, 0, 0); }

.lg-css3.lg-slide.lg-use-css3 .lg-item.lg-current {
  -webkit-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
  opacity: 1; }

.lg-css3.lg-slide.lg-use-css3 .lg-item.lg-prev-slide, .lg-css3.lg-slide.lg-use-css3 .lg-item.lg-next-slide, .lg-css3.lg-slide.lg-use-css3 .lg-item.lg-current {
  -webkit-transition: -webkit-transform 1s cubic-bezier(0, 0, 0.25, 1) 0s, opacity 0.1s ease 0s;
  -moz-transition: -moz-transform 1s cubic-bezier(0, 0, 0.25, 1) 0s, opacity 0.1s ease 0s;
  -o-transition: -o-transform 1s cubic-bezier(0, 0, 0.25, 1) 0s, opacity 0.1s ease 0s;
  transition: transform 1s cubic-bezier(0, 0, 0.25, 1) 0s, opacity 0.1s ease 0s; }

.lg-container {
  display: none; }

.lg-container.lg-show {
  display: block; }

.lg-container.lg-dragging-vertical .lg-backdrop {
  -webkit-transition-duration: 0s !important;
  transition-duration: 0s !important; }

.lg-container.lg-dragging-vertical .lg-css3 .lg-item.lg-current {
  -webkit-transition-duration: 0s !important;
  transition-duration: 0s !important;
  opacity: 1; }

.lg-inline .lg-backdrop,
.lg-inline .lg-outer {
  position: absolute; }

.lg-inline .lg-backdrop {
  z-index: 1; }

.lg-inline .lg-outer {
  z-index: 2; }

.lg-inline .lg-maximize:after {
  content: '\e909'; }

.lg-components {
  -webkit-transform: translate3d(0, 100%, 0);
  transform: translate3d(0, 100%, 0);
  will-change: transform;
  -webkit-transition: -webkit-transform 0.35s ease-out 0s;
  -moz-transition: -moz-transform 0.35s ease-out 0s;
  -o-transition: -o-transform 0.35s ease-out 0s;
  transition: transform 0.35s ease-out 0s;
  z-index: 1080;
  position: absolute;
  bottom: 0;
  right: 0;
  left: 0; }

.lg-fullscreen::after {
  content: "\e826"; }

.lg-fullscreen-on .lg-fullscreen::after {
  content: "\e827"; }

@media screen and (max-width: 1440px) {
  main.home div.panel.intro-home div.bundle .messagewrapper {
    font-family: 'opensans', sans-serif;
    font-weight: 700;
    font-size: 4.6875rem;
    line-height: 5rem; } }

@media screen and (max-width: 1140px) {
  main.menu .panel.intro-menu {
    margin-bottom: 2.0rem; }
  main.menu .panel.sub-menu .bundle {
    display: block;
    width: 80%;
    max-width: 800px;
    margin-left: auto;
    margin-right: auto; }
    main.menu .panel.sub-menu .bundle div.teasers, main.menu .panel.sub-menu .bundle div.text {
      width: 100%; }
    main.menu .panel.sub-menu .bundle div.teasers {
      margin-top: 1.5rem; } }

@media screen and (max-width: 1024px) {
  html {
    font-size: 97%; }
  header {
    z-index: 30;
    background-color: white;
    height: auto;
    min-height: 5.0rem; }
    header nav.main {
      height: 100%;
      top: 0;
      bottom: auto; }
      header nav.main img.full, header nav.main img.sticky {
        position: absolute;
        left: 0;
        top: 0;
        width: 16.0rem !important;
        z-index: 20; }
      header nav.main div.mobilewrap {
        height: auto;
        max-height: 0;
        overflow: hidden;
        transition: all 0.25s ease-out;
        opacity: 0; }
        header nav.main div.mobilewrap.visible {
          max-height: 500px;
          display: block;
          transition: all 0.25s ease-out;
          opacity: 1.0; }
      header nav.main ul.menu.visible, header nav.main ul.menu.hidden, header nav.main div.search.visible, header nav.main div.search.hidden {
        top: auto;
        opacity: 1; }
      header nav.main ul.menu {
        width: 100%;
        height: auto;
        position: relative;
        right: auto;
        bottom: auto;
        text-align: left;
        padding: 8.0rem 0 3.0rem 0; }
        header nav.main ul.menu li {
          display: block;
          margin: 0;
          padding: 0;
          height: auto;
          border-top: 1px solid rgba(40, 55, 80, 0.5) !important; }
          header nav.main ul.menu li:last-child {
            border-bottom: 1px solid rgba(40, 55, 80, 0.5) !important; }
        header nav.main ul.menu a {
          padding: 0.5rem 0;
          border: none !important;
          color: #283750;
          display: block;
          height: 100%; }
          header nav.main ul.menu a.active {
            color: #ace3fd; }
      header nav.main div.search {
        width: 100%;
        position: relative;
        right: auto;
        top: auto;
        text-align: left;
        height: auto;
        padding: 0 0 3.0rem 0; }
        header nav.main div.search input {
          position: relative;
          left: auto;
          top: auto;
          border-bottom: 1px solid rgba(40, 55, 80, 0.7);
          background: rgba(40, 55, 80, 0.5);
          border-radius: 0;
          border: 1px solid rgba(40, 55, 80, 0.075);
          border-top: 1px solid rgba(40, 55, 80, 0.2);
          border-left: 1px solid rgba(40, 55, 80, 0.2); }
        header nav.main div.search button {
          color: rgba(40, 55, 80, 0.5); }
      header nav.main ul.navswitch {
        width: 2.0rem;
        height: 2.0rem;
        color: #283750;
        position: absolute;
        top: 1.5rem;
        right: 1.5rem; }
        header nav.main ul.navswitch li.mobile {
          display: block;
          width: auto;
          height: auto;
          overflow: auto;
          width: 100%;
          height: 100%; }
        header nav.main ul.navswitch li.hidden {
          display: block;
          width: auto;
          height: auto;
          overflow: auto; }
        header nav.main ul.navswitch li.menu, header nav.main ul.navswitch li.search, header nav.main ul.navswitch li.menu.visible, header nav.main ul.navswitch li.search.visible {
          display: block;
          width: 0;
          height: 0;
          overflow: hidden; }
        header nav.main ul.navswitch li a {
          padding: 0; }
      header nav.main.sticky {
        position: relative;
        top: 0;
        bottom: auto; }
  footer {
    position: relative;
    bottom: auto;
    height: auto;
    z-index: 20; }
  main {
    margin: 0 0 0 0; }
    main .headlines .label {
      padding: 0.125rem 1.0rem;
      margin-bottom: 0.375rem;
      font-family: 'opensans', sans-serif;
      font-weight: 400;
      font-size: 0.8125rem;
      line-height: 0.9375rem; }
    main .headlines h1 {
      font-family: 'opensans', sans-serif;
      font-weight: 700;
      font-size: 2.1875rem;
      line-height: 2.5rem; }
    main .headlines h2 {
      font-family: 'opensans', sans-serif;
      font-weight: 400;
      font-size: 2rem;
      line-height: 2.25rem; }
  main.home div.panel.intro-home {
    height: calc(100vh - 5.0rem); }
    main.home div.panel.intro-home div.bundle .videowrapper {
      height: calc(100vh - 5.0rem); }
    main.home div.panel.intro-home div.bundle .messagewrapper {
      left: 5%;
      bottom: 25vh;
      width: 90%;
      font-family: 'opensans', sans-serif;
      font-weight: 700;
      font-size: 3.75rem;
      line-height: 4.25rem; }
  main.menu .panel.intro-menu {
    height: calc(100vh - 5.0rem); }
    main.menu .panel.intro-menu div.bundle div.message {
      height: calc(40vh - 5.0rem); }
      main.menu .panel.intro-menu div.bundle div.message .headlines {
        position: absolute;
        top: 60%;
        left: 50%;
        -webkit-transform: translate(-50%, -50%);
        -ms-transform: translate(-50%, -50%);
        transform: translate(-50%, -50%); }
    main.menu .panel.intro-menu div.bundle.col-2.span-1 figure, main.menu .panel.intro-menu div.bundle.col-2.span-2 figure, main.menu .panel.intro-menu div.bundle.col-2.span-3 figure {
      width: calc((100% - 1.0rem) / 2) !important; }
    main.menu .panel.intro-menu div.bundle.col-2.span-1 figure:nth-child(1) figure:nth-child(2), main.menu .panel.intro-menu div.bundle.col-2.span-2 figure:nth-child(2) {
      width: calc((100% - 1.0rem) / 2) !important; }
    main.menu .panel.intro-menu div.bundle.col-3 figure, main.menu .panel.intro-menu div.bundle.col-4 figure {
      width: calc((100% - 1.0rem) / 2) !important; }
    main.menu .panel.intro-menu div.bundle.col-3.span-1 figure, main.menu .panel.intro-menu div.bundle.col-3.span-2 figure, main.menu .panel.intro-menu div.bundle.col-3.span-3 figure, main.menu .panel.intro-menu div.bundle.col-4.span-1 figure, main.menu .panel.intro-menu div.bundle.col-4.span-2 figure, main.menu .panel.intro-menu div.bundle.col-4.span-3 figure {
      width: calc((100% - 1.0rem) / 2) !important; }
    main.menu .panel.intro-menu div.bundle.col-3.span-1 figure:nth-child(1), main.menu .panel.intro-menu div.bundle.col-3.span-2 figure:nth-child(2), main.menu .panel.intro-menu div.bundle.col-3.span-3 figure:nth-child(3), main.menu .panel.intro-menu div.bundle.col-4.span-1 figure:nth-child(1), main.menu .panel.intro-menu div.bundle.col-4.span-2 figure:nth-child(2), main.menu .panel.intro-menu div.bundle.col-4.span-3 figure:nth-child(3) {
      width: calc((100% - 1.0rem) / 2) !important; }
    main.menu .panel.intro-menu div.bundle.col-3 figure:nth-child(3), main.menu .panel.intro-menu div.bundle.col-3.span-3 figure:nth-child(3), main.menu .panel.intro-menu div.bundle.col-3 figure:nth-child(4), main.menu .panel.intro-menu div.bundle.col-4 figure:nth-child(3), main.menu .panel.intro-menu div.bundle.col-4.span-3 figure:nth-child(3), main.menu .panel.intro-menu div.bundle.col-4 figure:nth-child(4) {
      display: none !important; }
  main.product .panel.imgs-only.product div.bundle.col-2.span-1 figure, main.product .panel.imgs-only.product div.bundle.col-2.span-2 figure, main.product .panel.imgs-only.product div.bundle.col-2.span-3 figure {
    width: calc((100% - 1.0rem) / 2) !important; }
  main.product .panel.imgs-only.product div.bundle.col-2.span-1 figure:nth-child(1) figure:nth-child(2), main.product .panel.imgs-only.product div.bundle.col-2.span-2 figure:nth-child(2) {
    width: calc((100% - 1.0rem) / 2) !important; }
  main.product .panel.imgs-only.product div.bundle.col-3 figure, main.product .panel.imgs-only.product div.bundle.col-4 figure {
    width: calc((100% - 1.0rem) / 2) !important; }
  main.product .panel.imgs-only.product div.bundle.col-3.span-1 figure, main.product .panel.imgs-only.product div.bundle.col-3.span-2 figure, main.product .panel.imgs-only.product div.bundle.col-3.span-3 figure, main.product .panel.imgs-only.product div.bundle.col-4.span-1 figure, main.product .panel.imgs-only.product div.bundle.col-4.span-2 figure, main.product .panel.imgs-only.product div.bundle.col-4.span-3 figure {
    width: calc((100% - 1.0rem) / 2) !important; }
  main.product .panel.imgs-only.product div.bundle.col-3.span-1 figure:nth-child(1), main.product .panel.imgs-only.product div.bundle.col-3.span-2 figure:nth-child(2), main.product .panel.imgs-only.product div.bundle.col-3.span-3 figure:nth-child(3), main.product .panel.imgs-only.product div.bundle.col-4.span-1 figure:nth-child(1), main.product .panel.imgs-only.product div.bundle.col-4.span-2 figure:nth-child(2), main.product .panel.imgs-only.product div.bundle.col-4.span-3 figure:nth-child(3) {
    width: calc((100% - 1.0rem) / 2) !important; }
  main.product .panel.imgs-only.product div.bundle.col-3 figure:nth-child(3), main.product .panel.imgs-only.product div.bundle.col-3.span-3 figure:nth-child(3), main.product .panel.imgs-only.product div.bundle.col-3 figure:nth-child(4), main.product .panel.imgs-only.product div.bundle.col-4 figure:nth-child(3), main.product .panel.imgs-only.product div.bundle.col-4.span-3 figure:nth-child(3), main.product .panel.imgs-only.product div.bundle.col-4 figure:nth-child(4) {
    display: none !important; } }

@media screen and (max-width: 1024px) and (max-height: 800px) {
  main.contact div.panel.map .bundle {
    height: 35vh; } }

@media screen and (max-width: 960px) {
  html {
    font-size: 95%; }
  footer .bundle {
    font-family: 'opensans', sans-serif;
    font-weight: 400;
    font-size: 0.9375rem;
    line-height: 1.75rem; }
    footer .bundle div.box, footer .bundle div.box.dekra {
      width: calc(33.3% - 0.5rem); } }

@media screen and (max-width: 900px) {
  div.panel div.bundle.narrow {
    width: calc(92vw - 7.5rem);
    max-width: calc(1320px - 7.5rem);
    margin-left: auto;
    margin-right: auto; }
  main nav.siblings {
    width: calc(92vw - 7.5rem);
    max-width: calc(1320px - 7.5rem);
    margin-left: auto;
    margin-right: auto; }
  main.menu .panel.sub-menu .bundle {
    width: calc(92vw - 7.5rem);
    max-width: calc(1320px - 7.5rem);
    margin-left: auto;
    margin-right: auto; }
  main .headlines.product {
    width: calc(92vw - 7.5rem);
    max-width: calc(1320px - 7.5rem);
    margin-left: auto;
    margin-right: auto; }
  div.modalwrap div.modal {
    width: 92%;
    max-width: none; } }

@media screen and (max-width: 840px) {
  html {
    font-size: 92%; } }

@media screen and (max-width: 800px) {
  html {
    font-size: 92%; }
  main.home .panel.intro-home {
    margin-bottom: 2.0rem !important; }
  main.home .panel.text-only {
    font-family: 'notoserif', serif;
    font-weight: 400;
    font-size: 1.5rem;
    line-height: 2rem;
    margin: 0; }
  main.home div.panel.sub-home .bundle {
    display: block; }
    main.home div.panel.sub-home .bundle div.teaser {
      width: 100%;
      min-height: 0;
      margin: 0 0 1.0rem 0 !important;
      padding: 0; }
      main.home div.panel.sub-home .bundle div.teaser h2 {
        position: static;
        display: inline-block;
        width: auto;
        padding: 0.125rem 1.0rem; }
      main.home div.panel.sub-home .bundle div.teaser picture, main.home div.panel.sub-home .bundle div.teaser div.text {
        display: inline-block;
        vertical-align: top; }
      main.home div.panel.sub-home .bundle div.teaser picture {
        width: 40%;
        margin-top: 0.375rem; }
      main.home div.panel.sub-home .bundle div.teaser div.text {
        width: calc(60% - 1.0rem);
        margin-left: 1.0rem; }
        main.home div.panel.sub-home .bundle div.teaser div.text h3 {
          font-family: 'opensans', sans-serif;
          font-weight: 700;
          font-size: 1.25rem;
          line-height: 1.5rem; }
  div.panel.swiper-feature .bundle div.swiper-slide {
    padding: 1.0rem; }
    div.panel.swiper-feature .bundle div.swiper-slide picture, div.panel.swiper-feature .bundle div.swiper-slide div.text {
      display: block;
      width: 100%; }
    div.panel.swiper-feature .bundle div.swiper-slide picture {
      aspect-ratio: 2/1;
      margin: 0 0 1.0rem 0; }
      @supports not (aspect-ratio: 2/1) {
        div.panel.swiper-feature .bundle div.swiper-slide picture::before {
          float: left;
          padding-top: 50%;
          content: ''; }
        div.panel.swiper-feature .bundle div.swiper-slide picture::after {
          display: block;
          content: '';
          clear: both; } }
  div.panel.swiper-feature.products .bundle div.swiper-slide picture, div.panel.swiper-feature.products .bundle div.swiper-slide div.text {
    display: block;
    width: 100%; } }

@media screen and (max-width: 768px) {
  div.panel.text-imgs div.bundle.row, div.panel.text-imgs div.bundle.rev, div.panel.text-imgs div.bundle.row.notch, div.panel.text-imgs div.bundle.rev.notch {
    display: block !important; }
  div.panel.text-imgs div.bundle div.gal, div.panel.text-imgs div.bundle div.txt {
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    max-width: none !important; }
  main.home div.panel.intro-home div.bundle .messagewrapper {
    left: 4%;
    bottom: 25vh;
    width: 92%;
    font-family: 'notoserif', serif;
    font-weight: 700;
    font-size: 3.4375rem;
    line-height: 3.75rem; }
  main.contact div.panel.contact .bundle {
    display: block; }
    main.contact div.panel.contact .bundle .headlines.contact, main.contact div.panel.contact .bundle .text {
      width: 100%; }
  main.contact_form div.panel.form form {
    display: block; }
  main.contact_form div.panel.form div.formrow {
    width: 100% !important; } }

@media screen and (max-width: 680px) {
  html {
    font-size: 90%; }
  footer .bundle div.box {
    width: calc(40% - 0.5rem); }
    footer .bundle div.box.dekra {
      width: calc(20% - 0.5rem); }
  main.menu .panel.intro-menu {
    height: calc(100vh - 5.0rem); }
    main.menu .panel.intro-menu div.bundle.col-2 figure:nth-child(1), main.menu .panel.intro-menu div.bundle.col-2.span-1 figure:nth-child(1), main.menu .panel.intro-menu div.bundle.col-2.span-2 figure:nth-child(2), main.menu .panel.intro-menu div.bundle.col-2.span-3 figure:nth-child(3), main.menu .panel.intro-menu div.bundle.col-3 figure:nth-child(1), main.menu .panel.intro-menu div.bundle.col-3.span-1 figure:nth-child(1), main.menu .panel.intro-menu div.bundle.col-3.span-2 figure:nth-child(2), main.menu .panel.intro-menu div.bundle.col-3.span-3 figure:nth-child(3), main.menu .panel.intro-menu div.bundle.col-4 figure:nth-child(1), main.menu .panel.intro-menu div.bundle.col-4.span-1 figure:nth-child(1), main.menu .panel.intro-menu div.bundle.col-4.span-2 figure:nth-child(2), main.menu .panel.intro-menu div.bundle.col-4.span-3 figure:nth-child(3) {
      width: 100% !important; }
    main.menu .panel.intro-menu div.bundle.col-2 figure:nth-child(2), main.menu .panel.intro-menu div.bundle.col-2 figure:nth-child(3), main.menu .panel.intro-menu div.bundle.col-2 figure:nth-child(4), main.menu .panel.intro-menu div.bundle.col-3 figure:nth-child(2), main.menu .panel.intro-menu div.bundle.col-3 figure:nth-child(3), main.menu .panel.intro-menu div.bundle.col-3 figure:nth-child(4), main.menu .panel.intro-menu div.bundle.col-4 figure:nth-child(2), main.menu .panel.intro-menu div.bundle.col-4 figure:nth-child(3), main.menu .panel.intro-menu div.bundle.col-4 figure:nth-child(4) {
      display: none !important; }
  main.product .headlines.product {
    margin-bottom: 1.0rem !important; }
  main.product .panel.imgs-only.product div.bundle.col-2 figure:nth-child(1), main.product .panel.imgs-only.product div.bundle.col-2.span-1 figure:nth-child(1), main.product .panel.imgs-only.product div.bundle.col-2.span-2 figure:nth-child(2), main.product .panel.imgs-only.product div.bundle.col-2.span-3 figure:nth-child(3), main.product .panel.imgs-only.product div.bundle.col-3 figure:nth-child(1), main.product .panel.imgs-only.product div.bundle.col-3.span-1 figure:nth-child(1), main.product .panel.imgs-only.product div.bundle.col-3.span-2 figure:nth-child(2), main.product .panel.imgs-only.product div.bundle.col-3.span-3 figure:nth-child(3), main.product .panel.imgs-only.product div.bundle.col-4 figure:nth-child(1), main.product .panel.imgs-only.product div.bundle.col-4.span-1 figure:nth-child(1), main.product .panel.imgs-only.product div.bundle.col-4.span-2 figure:nth-child(2), main.product .panel.imgs-only.product div.bundle.col-4.span-3 figure:nth-child(3) {
    width: 100% !important; }
  main.product .panel.imgs-only.product div.bundle.col-2 figure:nth-child(2), main.product .panel.imgs-only.product div.bundle.col-2 figure:nth-child(3), main.product .panel.imgs-only.product div.bundle.col-2 figure:nth-child(4), main.product .panel.imgs-only.product div.bundle.col-3 figure:nth-child(2), main.product .panel.imgs-only.product div.bundle.col-3 figure:nth-child(3), main.product .panel.imgs-only.product div.bundle.col-3 figure:nth-child(4), main.product .panel.imgs-only.product div.bundle.col-4 figure:nth-child(2), main.product .panel.imgs-only.product div.bundle.col-4 figure:nth-child(3), main.product .panel.imgs-only.product div.bundle.col-4 figure:nth-child(4) {
    display: none !important; }
  main.product div.panel.product .bundle {
    margin-top: 0 !important;
    display: block; }
    main.product div.panel.product .bundle div.body, main.product div.panel.product .bundle div.data {
      width: 100%; }
      main.product div.panel.product .bundle div.body figure, main.product div.panel.product .bundle div.data figure {
        margin-top: 1.0rem; }
  main.contact div.panel.map {
    margin-bottom: 1.5rem; }
    main.contact div.panel.map .bundle {
      display: block; }
      main.contact div.panel.map .bundle .osm-map {
        width: 100%; }
      main.contact div.panel.map .bundle .gal {
        display: none; }
  main.contact div.panel.contact .bundle .text {
    padding-top: 1.0rem; } }

@media screen and (max-width: 640px) {
  main h2 {
    font-family: 'opensans', sans-serif;
    font-weight: 700;
    font-size: 1.375rem;
    line-height: 1.5rem; }
  main h3 {
    font-family: 'opensans', sans-serif;
    font-weight: 700;
    font-size: 1.1875rem;
    line-height: 1.375rem; }
  main .headlines .label {
    margin-bottom: 0.25rem;
    font-family: 'opensans', sans-serif;
    font-weight: 400;
    font-size: 0.75rem;
    line-height: 0.875rem; }
  main .headlines h1 {
    font-family: 'opensans', sans-serif;
    font-weight: 700;
    font-size: 1.75rem;
    line-height: 1.875rem; }
  main .headlines h2 {
    font-family: 'opensans', sans-serif;
    font-weight: 400;
    font-size: 1.5625rem;
    line-height: 1.6875rem; }
  main.home div.panel.intro-home div.bundle .messagewrapper {
    font-family: 'notoserif', serif;
    font-weight: 700;
    font-size: 3.125rem;
    line-height: 3.375rem; }
  main.menu .panel.intro-menu div.bundle div.message .headlines {
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%); }
  main.menu .panel.sub-menu .bundle div.teasers {
    display: block; }
    main.menu .panel.sub-menu .bundle div.teasers div.teaser {
      width: 100%; } }

@media screen and (max-width: 560px) {
  main {
    margin-bottom: 0; }
  footer {
    position: relative;
    bottom: auto;
    height: auto; }
    footer .bundle {
      -webkit-flex-wrap: wrap;
      -moz-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
      flex-wrap: wrap; }
      footer .bundle div.box {
        width: calc(50% - 0.5rem); }
        footer .bundle div.box.dekra {
          width: 100%;
          padding: 2.0rem 0 2.0rem 0; }
          footer .bundle div.box.dekra img {
            position: static;
            right: auto; }
  main.home div.panel.sub-home .bundle {
    display: block; }
    main.home div.panel.sub-home .bundle div.teaser {
      padding-top: 2.5rem;
      margin-bottom: 1.0rem !important; }
      main.home div.panel.sub-home .bundle div.teaser h2 {
        position: absolute;
        top: 0;
        display: block;
        width: 100%;
        padding: 0.25rem 1.0rem; }
      main.home div.panel.sub-home .bundle div.teaser picture, main.home div.panel.sub-home .bundle div.teaser div.text {
        display: block;
        width: 100%; }
      main.home div.panel.sub-home .bundle div.teaser div.text {
        margin: 0; }
      main.home div.panel.sub-home .bundle div.teaser picture {
        margin-top: 0; }
  div.panel.imgs-only div.bundle.col-2 figure, div.panel.imgs-only div.bundle.col-3 figure {
    width: 100% !important; }
  div.panel.imgs-only div.bundle.col-4 figure {
    width: calc((100% - 1.0rem) / 2) !important; } }

@media screen and (max-width: 480px) {
  footer .bundle {
    display: block; }
    footer .bundle div.box, footer .bundle div.box.dekra {
      width: 100%; }
    footer .bundle div.box.menu {
      padding-top: 1.0rem; }
    footer .bundle div.box.dekra {
      padding-top: 3.0rem; }
  main.home div.panel.intro-home div.bundle .messagewrapper {
    font-family: 'notoserif', serif;
    font-weight: 700;
    font-size: 2.8125rem;
    line-height: 3rem; }
  div.panel.imgs-only div.bundle.mat.col-4 figure {
    width: 100% !important; } }

@media screen and (max-width: 420px) {
  main.home div.panel.intro-home div.bundle .messagewrapper {
    font-family: 'notoserif', serif;
    font-weight: 700;
    font-size: 2.5rem;
    line-height: 2.625rem; } }

.swiper-container {
  padding-bottom: 4.0rem !important;
  margin-bottom: 1.0rem !important; }
  .swiper-container.seq figure {
    padding-bottom: 0;
    display: block; }
  .swiper-container.news {
    padding-bottom: 4.0rem !important; }
  .swiper-container .swiper-button-next, .swiper-container .swiper-button-prev {
    top: auto !important;
    bottom: 0 !important;
    background-image: none !important;
    cursor: pointer; }
    .swiper-container .swiper-button-next::before, .swiper-container .swiper-button-prev::before {
      width: 2.5rem !important;
      font-family: 'icon';
      -webkit-font-smoothing: antialiased;
      -moz-osx-font-smoothing: grayscale;
      font-weight: 400;
      font-size: 2.25rem;
      line-height: 2.25rem;
      content: '\e821' !important;
      color: #283750;
      right: 0; }
    .swiper-container .swiper-button-next.swiper-button-disabled, .swiper-container .swiper-button-prev.swiper-button-disabled {
      opacity: 0; }
  .swiper-container .swiper-button-prev {
    left: 0; }
    .swiper-container .swiper-button-prev::before {
      content: '\e822' !important; }
  .swiper-container .swiper-pagination span {
    background: #283750;
    cursor: pointer; }

div #matomo-opt-out {
  background: rgba(172, 227, 253, 0.15);
  padding: 0.5rem 0.5rem 0.5rem 2.0rem;
  position: relative; }
  div #matomo-opt-out input {
    position: absolute;
    left: 0.5rem;
    top: 1.0rem; }
