@font-face {
  font-family: "IBMPlexMono";
  font-style: normal;
  font-weight: normal;
  src: url(/site/fonts/IBMPlexMono-Regular.woff2) format("woff2"), url(/site/fonts/IBMPlexMono-Regular.woff) format("woff");
}
@font-face {
  font-family: "IBMPlexMono";
  font-style: bold;
  font-weight: bold;
  src: url(/site/fonts/IBMPlexMono-Bold.woff2) format("woff2"), url(/site/fonts/IBMPlexMono-Bold.woff) format("woff");
}
@font-face {
  font-family: "IBMPlexSans";
  font-style: normal;
  font-weight: normal;
  src: url(/site/fonts/IBMPlexSans-Regular.woff2) format("woff2"), url(/site/fonts/IBMPlexSans-Regular.woff) format("woff");
}
@font-face {
  font-family: "IBMPlexSans";
  font-style: bold;
  font-weight: bold;
  src: url(/site/fonts/IBMPlexSans-SemiBold.woff2) format("woff2"), url(/site/fonts/IBMPlexSans-SemiBold.woff) format("woff");
}
@font-face {
  font-family: "IBMPlexSans";
  font-style: italic;
  font-weight: normal;
  src: url(/site/fonts/IBMPlexSans-Italic.woff2) format("woff2"), url(/site/fonts/IBMPlexSans-Italic.woff) format("woff");
}
html {
  --light-blue: #b7e0fd;
  --light-blue2: #99c2df;
  --box-blue: #96bae2;
  --mid-blue: #5a73b4;
  --button-blue: #313368;
  --menu-blue: rgba(49, 51, 104, 0.8);
  --apple-blue: rgb(5, 111, 227);
  --dark-blue: #454795;
  --mid-gray: #a7a7a7;
  --box-gray: #ddd;
  --border-gray: #eee;
  --error-text: #f00;
  --font-mini: 14px;
  --font-listing: 15px;
  --font-long: 16px;
  --font-normal: 18px;
  --font-bigger1: 20px;
  --font-button: 22px;
  --font-bigger2: 24px;
  --font-title: 26px;
  --font-top-h2: 40px;
  --font-top-h3: 30px;
  --color-navy-900: #0D3B66; /* Master Captain */
  --color-navy-800: #081F2D; /* Deep Navy (Brand) */
  --color-blue-700: #0F4C75; /* Primary actions */
  --color-blue-600: #1F5E99; /* Captain */
  --color-blue-500: #4C7FB3; /* Skipper */
  --tier_3: #000050; /* Master Captain */
  --tier_2: #294795; /* Captain */
  --tier_1: #6092cd; /* Skipper */
  --tier_0: #a3c6e9; /* Test */
}

html {
  overflow-x: hidden;
  max-width: 100%;
}

body {
  background-color: white;
  color: #000;
  font-family: "IBMPlexSans", sans-serif;
  line-height: 1.7em;
  margin-left: auto;
  margin-right: auto;
  margin-top: 0;
  margin-bottom: 0;
  overflow-x: hidden;
  max-width: 100%;
}

h2 {
  margin-top: 40px;
  margin-bottom: 2em;
  line-height: 1.4em;
}

h3 {
  margin-top: 2em;
}

h4 {
  margin-top: 2em;
}

p {
  font-size: var(--font-normal);
  line-height: 1.7em;
}

a {
  color: var(--mid-blue);
  text-decoration: none;
  overflow-wrap: break-word;
  word-wrap: break-word;
  word-break: break-word;
}
a:visited {
  color: var(--mid-blue);
  text-decoration: none;
}

nav a {
  margin-right: 2ex;
  color: white;
}
nav a:visited {
  color: white;
  text-decoration: none;
}

.logbook, .logbook-bold {
  text-transform: uppercase;
}

.logbook-bold {
  font-weight: bold;
}

.font-normal {
  font-size: var(--font-normal);
  line-height: 1.7em;
}

.text-blue {
  color: var(--mid-blue) !important;
}

.text-center {
  text-align: center !important;
  justify-content: center;
  align-items: center;
}

.caption {
  font-style: italic;
  margin-bottom: 2em;
  margin-top: 1em;
  display: block;
}

.distance-top-section {
  padding-top: 4em;
}

.distance-bottom-section {
  margin-bottom: 6em;
}

.button,
.button-small,
.button-big {
  align-content: center;
  background-color: var(--mid-blue);
  border-radius: 0px;
  color: white;
  display: inline-block;
  font-size: var(--font-button);
  font-weight: normal;
  margin-top: 40px;
  margin-top: 40px;
  height: 30px;
  padding: 5px;
  text-align: center;
  text-decoration: none;
  width: fit-content;
}
.button[disabled],
.button-small[disabled],
.button-big[disabled] {
  background-color: var(--box-gray);
  box-shadow: none;
}
.button:hover,
.button-small:hover,
.button-big:hover {
  background-color: var(--dark-blue);
  box-shadow: 0px 0px 40px rgba(37, 62, 85, 0.7);
}
.button:focus,
.button-small:focus,
.button-big:focus {
  outline: 2px solid white;
  outline-offset: 2px;
}
.button:active,
.button-small:active,
.button-big:active {
  background-color: var(--mid-blue);
  box-shadow: 0px 0px 20px rgba(37, 62, 85, 0.3);
  transform: translateY(1px);
}
.button a,
.button-small a,
.button-big a {
  color: white;
  line-height: 32px;
  text-decoration: none;
  width: 300px;
}
.button a:visited,
.button-small a:visited,
.button-big a:visited {
  color: white;
  text-decoration: none;
}

.button-new {
  align-content: center;
  border-top: solid 1px var(--apple-blue);
  color: var(--apple-blue);
  display: inline-block;
  font-size: var(--font-normal);
  height: 30px;
  letter-spacing: 0.03em;
  margin-left: auto;
  margin-right: auto;
  margin-top: 30px;
  padding: 3px 5px 0px 5px;
  text-align: center;
  text-decoration: none;
  width: fit-content;
}
.button-new:hover {
  font-weight: bold;
}
.button-new:focus {
  font-weight: bold;
}
.button-new a {
  color: var(--apple-blue);
  line-height: 32px;
  text-decoration: none;
}
.button-new a:visited {
  text-decoration: none;
}

.colored-button-new {
  background-color: var(--apple-blue);
  margin-left: 20px !important;
  margin-right: 20px !important;
  margin-top: 0px;
  margin-bottom: 20px;
  border-radius: 30px !important;
  padding: 9px 21px !important;
  border-top: none !important;
  font-size: var(--font-long);
  transition: all 0.3s ease;
  font-weight: 500;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.colored-button-new:hover {
  color: white !important;
  background-color: var(--box-blue);
  box-shadow: 0 6px 20px rgba(37, 62, 85, 0.3);
  transform: translateY(-2px) scale(1.02);
}
.colored-button-new:active {
  transform: translateY(0) scale(1);
  box-shadow: 0 2px 10px rgba(37, 62, 85, 0.3);
}
.colored-button-new a {
  color: white !important;
  text-decoration: none;
  font-weight: 500;
}
.colored-button-new a:visited {
  text-decoration: none;
}
.colored-button-new a:hover {
  color: white !important;
}

.back-to-top {
  position: fixed;
  bottom: 30px;
  right: 30px;
  width: 40px;
  height: 40px;
  background-color: var(--border-gray);
  color: white;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 35px;
  text-decoration: none;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
  transition: all 0.3s ease, opacity 0.3s ease;
  z-index: 9999;
}
.back-to-top:visited {
  color: white;
}
.back-to-top:hover {
  background-color: var(--button-blue-hover);
  transform: translateY(-3px);
  box-shadow: 0 6px 16px rgba(0, 0, 0, 0.4);
}

.impressum, .impressum p {
  font-size: 16px;
  max-width: 500px;
  margin-left: auto;
  margin-right: auto;
}
.impressum a, .impressum p a {
  color: black;
  text-decoration: none;
}
.impressum a:visited, .impressum p a:visited {
  color: black;
  text-decoration: none;
}

.privacy, .privacy p {
  font-size: var(--font-mini);
  margin-left: auto;
  margin-right: auto;
  line-height: 1.4em;
}
.privacy h2, .privacy p h2 {
  font-size: var(--font-normal);
}
.privacy h3, .privacy p h3 {
  margin-top: 16px;
  margin-bottom: 0;
  font-size: var(--font-long) !important;
  padding-bottom: 0;
}
.privacy h4, .privacy p h4 {
  font-size: var(--font-mini);
}
.privacy a, .privacy p a {
  color: black;
  text-decoration: none;
}
.privacy a:visited, .privacy p a:visited {
  color: black;
  text-decoration: none;
}

.tablet-frame {
  position: relative;
  border-radius: 23px;
  box-shadow: 0 0 20px rgba(0, 0, 0, 0.5);
  padding: 23px;
  padding-top: 30px;
  margin-top: 1em;
  background: linear-gradient(to bottom right, white, rgb(221, 221, 221));
}

.zigzag-border {
  width: 100%;
  padding-top: 10px;
  padding-bottom: 10px;
  background-color: black;
  display: block;
  clip-path: polygon(0% 3px, 3% 0px, 6% 3px, 9% 0px, 12% 3px, 15% 0px, 18% 3px, 21% 0px, 24% 3px, 27% 0px, 30% 3px, 33% 0px, 36% 3px, 39% 0px, 42% 3px, 45% 0px, 48% 3px, 51% 0px, 54% 3px, 57% 0px, 60% 3px, 63% 0px, 66% 3px, 69% 0px, 72% 3px, 75% 0px, 78% 3px, 81% 0px, 84% 3px, 87% 0px, 90% 3px, 93% 0px, 96% 3px, 99% 0px, 100% 3px, 100% calc(100% - 3px), 99% 100%, 96% calc(100% - 3px), 93% 100%, 90% calc(100% - 3px), 87% 100%, 84% calc(100% - 3px), 81% 100%, 78% calc(100% - 3px), 75% 100%, 72% calc(100% - 3px), 69% 100%, 66% calc(100% - 3px), 63% 100%, 60% calc(100% - 3px), 57% 100%, 54% calc(100% - 3px), 51% 100%, 48% calc(100% - 3px), 45% 100%, 42% calc(100% - 3px), 39% 100%, 36% calc(100% - 3px), 33% 100%, 30% calc(100% - 3px), 27% 100%, 24% calc(100% - 3px), 21% 100%, 18% calc(100% - 3px), 15% 100%, 12% calc(100% - 3px), 9% 100%, 6% calc(100% - 3px), 3% 100%, 0% calc(100% - 3px));
}

.popover-overlay {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: rgba(0, 0, 0, 0);
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: background-color 0.4s ease, opacity 0.4s ease;
  padding: 20px;
}
@media (max-width: 767px) {
  .popover-overlay {
    align-items: flex-end;
    padding: 0;
  }
}
.popover-overlay.active {
  background-color: rgba(0, 0, 0, 0.5);
  opacity: 1;
  pointer-events: auto;
}
.popover-overlay.active .popover-content {
  transform: translateY(0);
}

.popover-content {
  background: white;
  width: 100%;
  max-width: 600px;
  max-height: 85vh;
  border-radius: 20px;
  box-shadow: 0 10px 40px rgba(0, 0, 0, 0.3);
  transform: translateY(100vh);
  transition: transform 0.9s cubic-bezier(0.32, 0.72, 0, 1);
  overflow: hidden;
  position: relative;
  padding-bottom: 30px;
}
.popover-content details-container,
.popover-content USP-image {
  flex-direction: row;
  margin-left: auto;
  margin-right: auto;
  max-width: 90%;
  margin-bottom: 1em;
  text-align: left;
}
.popover-content details-container details-box,
.popover-content USP-image details-box {
  max-width: 100%;
  min-width: 100%;
  padding-left: 0px;
  padding-bottom: 10px;
  font-size: var(--font-long);
  line-height: 1.6em;
  text-align: left;
}
@media (max-width: 767px) {
  .popover-content {
    max-width: 100%;
    border-radius: 20px 20px 0 0;
    max-height: 90vh;
  }
}

.popover-close {
  position: absolute;
  top: 15px;
  right: 15px;
  background: rgba(0, 0, 0, 0.1);
  border: none;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  font-size: 28px;
  line-height: 1;
  color: #333;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background-color 0.2s ease;
  z-index: 10;
}
.popover-close:hover {
  background: rgba(0, 0, 0, 0.2);
}

.popover-inner {
  padding: 10px 30px 20px 20px;
  overflow-y: auto;
  max-height: 85vh;
}
.popover-inner details summary {
  display: none;
}
.popover-inner details > div {
  display: block !important;
  margin-top: 1em;
}
.popover-inner USP-image {
  display: block;
  text-align: center;
  margin-bottom: 1.5em;
}
.popover-inner USP-image img {
  max-width: 100%;
  height: auto;
}
.popover-inner details-container {
  display: block;
  width: 100%;
}
.popover-inner h3 {
  margin-top: 0;
  margin-bottom: 20px;
  text-align: center;
}
.popover-inner h3 img {
  height: 40px;
  margin-right: 15px;
  vertical-align: bottom;
}
.popover-inner p {
  margin-bottom: 15px;
  line-height: 1.6;
  color: #333;
}
.popover-inner ol {
  margin-left: 20px;
  margin-bottom: 20px;
}
.popover-inner ol li {
  margin-bottom: 12px;
  line-height: 1.6;
  color: #333;
}
.popover-inner a {
  color: white !important;
  text-decoration: none;
}
.popover-inner a:hover {
  text-decoration: underline;
}

@media screen and (max-width: 1024px) {
  .distance-top-section {
    padding-top: 0;
  }
}
@media screen and (max-width: 700px) {
  .tablet-pc {
    display: none;
  }
  .button {
    font-size: var(--font-bigger1);
    padding: 5px;
  }
}
@media screen and (min-width: 501px) {
  .small-size {
    display: none;
  }
}
@media screen and (min-width: 701px) {
  .smartphone {
    display: none;
  }
}
nav {
  top: 30px;
  font-size: 20px;
  font-weight: 400;
}

body {
  margin: 0;
}

.sidebar {
  position: fixed;
  z-index: 3000;
}
.sidebar details summary {
  color: white;
  list-style-type: none;
  padding: 10px;
  padding-bottom: 2px;
  text-align: center;
  cursor: pointer;
}
.sidebar details summary::marker, .sidebar details summary::-webkit-details-marker {
  display: none;
  content: "";
}
.sidebar details > summary {
  list-style: none;
}
.sidebar .hamburger-icon {
  font-size: 80px;
  vertical-align: -30%;
  color: rgb(230, 230, 230);
}
.sidebar .content {
  color: rgb(230, 230, 230);
  padding-left: 20px;
  padding-top: 5px;
  padding-bottom: 40px;
  display: inline-block;
  text-align: right;
  line-height: 40px;
}
.sidebar .content a {
  color: white;
  text-decoration: none;
}
.sidebar .content a:hover {
  text-decoration: none;
  color: var(--button-blue);
}

@media screen and (min-width: 901px) {
  .sidebar {
    position: fixed;
    top: 0;
    right: 0;
    width: auto;
    background-color: transparent;
    box-shadow: none;
    transition: background-color 0.3s ease, box-shadow 0.3s ease, width 0.3s ease;
  }
  .sidebar.scrolled {
    background-color: white !important;
    box-shadow: 0px 2px 10px rgba(0, 0, 0, 0.1);
    width: 100%;
  }
  .sidebar.scrolled .content {
    justify-content: flex-end;
  }
  .sidebar nav {
    margin: 0;
    padding: 0;
  }
  .sidebar details {
    margin: 0;
  }
  .sidebar details summary {
    display: none;
  }
  .sidebar details[open] .content {
    display: flex;
  }
  .sidebar .hamburger-icon {
    display: none;
  }
  .sidebar .content {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    gap: 10px;
    align-items: center;
    justify-content: center;
    background-color: transparent;
    padding: 5px 30px;
    box-shadow: none;
    text-align: center;
    line-height: normal;
    white-space: nowrap;
  }
  .sidebar .content br {
    display: none;
  }
  .sidebar .content a {
    font-size: 14px;
    font-weight: 400;
    display: inline-block;
    color: black;
    text-decoration: none;
    white-space: nowrap;
  }
  .sidebar .content a:hover {
    text-decoration: none;
    color: var(--mid-gray);
  }
}
@media screen and (max-width: 900px) {
  .sidebar {
    float: right;
    right: 0;
    top: 0;
  }
  .sidebar details {
    margin: 8px;
    text-align: right;
  }
  .sidebar details summary {
    float: right;
    margin-left: 10px;
  }
  .sidebar .content {
    background: linear-gradient(rgba(150, 186, 226, 0.7) 0%, rgba(150, 186, 226, 0.9) 80%, rgba(150, 186, 226, 0) 100%);
  }
}
@media screen and (max-width: 700px) {
  details summary .hamburger-icon {
    font-size: 30px;
    vertical-align: -30%;
  }
}
banner-top {
  background: url("/site/media/Sunna-Meri-Cockpit-Speed.jpg") center center no-repeat;
  background-size: cover;
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  margin-left: auto;
  margin-right: auto;
  padding-left: 20px;
  padding-right: 20px;
  min-height: 500px;
  flex-direction: row;
  justify-content: left;
  position: relative;
  border-bottom: solid 5px white;
}
banner-top banner-top-content {
  margin-left: 30px;
  background: linear-gradient(rgba(150, 186, 226, 0.7), rgba(150, 186, 226, 0.7)) 0 0/100% calc(var(--gap-position, 120px)), linear-gradient(rgba(150, 186, 226, 0.7) 0%, rgba(150, 186, 226, 0.7) 80%, rgba(150, 186, 226, 0) 100%) 0 calc(var(--gap-position, 120px) + 5px)/100% calc(100% - var(--gap-position, 120px) - 5px);
  background-repeat: no-repeat;
  padding: 10px;
  padding-bottom: 60px;
  max-width: 500px;
  display: block;
  animation: flyInFromTop 1.5s ease-out;
}
banner-top banner-top-content .transparent-gap {
  height: 5px;
  margin: 0 -10px;
}
@keyframes flyInFromTop {
  from {
    opacity: 0;
    transform: translateY(-100px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
banner-top h1, banner-top h2, banner-top h3 {
  color: white;
  font-weight: bold;
  padding-left: 1vw;
}
banner-top h1 {
  font-size: 4em;
  font-variant: small-caps;
  font-weight: bold;
}
banner-top h2 {
  font-size: var(--font-top-h2);
  line-height: 1.2em;
  text-align: left;
  margin-bottom: 0px;
}
banner-top h3 {
  font-size: var(--font-top-h3);
  line-height: 1.2em;
  text-align: left;
  margin-top: 1em;
}
banner-top h4 {
  font-size: var(--font-bigger1);
  color: white;
  line-height: 5rem;
  text-align: center;
  margin-left: auto;
  margin-right: auto;
}
banner-top img {
  width: 100px;
  margin-left: auto;
  margin-right: auto;
}
banner-top top-button {
  margin-right: 15px;
}
banner-top top-button a {
  width: 280px;
}
@media screen and (max-width: 700px) {
  banner-top banner-top {
    max-width: 100% !important;
  }
  banner-top banner-top img {
    max-width: 100% !important;
  }
  banner-top banner-top-content {
    max-width: 80% !important;
    margin-left: 5px;
  }
  banner-top h1, banner-top h2, banner-top h3 {
    margin-right: 0px;
    padding-left: 10px;
  }
  banner-top h1 {
    font-size: 55px;
  }
  banner-top h2 {
    font-size: 36px;
  }
  banner-top h3 {
    font-size: var(--font-bigger2);
  }
  banner-top top-button {
    margin-right: 0px;
  }
  banner-top top-button a {
    padding-left: 10px;
  }
  banner-top top-button.button {
    font-size: var(--font-bigger1);
  }
  banner-top top-button.button a {
    padding: 10px 10px;
  }
}

banner-top-trimutic {
  align-items: left;
  background: url("/media/TRIMUTIC-SKY-blau-big.jpg") center center no-repeat;
  background-size: cover;
  flex-wrap: wrap;
  flex-direction: column;
  justify-content: center;
  margin-left: auto;
  margin-right: auto;
  min-height: 30vh;
  padding-top: 80px;
  padding-left: 20px;
  padding-right: 20px;
  padding-bottom: 30px;
  display: flex;
}

USP-container {
  background-color: var(--light-blue);
  display: block;
  padding: 30px 0;
  position: relative;
}

USP {
  gap: 20px;
  margin: 0 auto;
  max-width: 1100px;
  padding-left: 20px;
  padding-right: 20px;
}
USP USP-content {
  margin: 0 auto;
  display: block;
  max-width: 500px;
  padding-left: 20px;
  padding-right: 20px;
  padding-bottom: 30px;
}
USP USP-image a {
  display: block;
  margin: 0 auto;
  text-align: center;
}
USP USP-image a img {
  max-width: 90%;
  margin: 0 auto;
  max-height: 500px;
}
USP USP-image {
  display: block;
  margin: 0 auto;
  text-align: center;
}
USP USP-image img {
  max-width: 90%;
  margin: 0 auto;
  max-height: 500px;
}
USP h3 {
  font-size: var(--font-bigger2);
  text-align: left;
  font-weight: bold;
  line-height: 1.4em;
  margin-top: 0;
}
USP h3 img {
  display: block;
  height: 60px;
}

USP + USP {
  margin-top: 60px;
}

@media screen and (min-width: 900px) {
  USP {
    display: flex;
    flex-direction: row;
    padding-left: 20px;
    padding-right: 20px;
  }
  USP USP-content {
    width: 50%;
  }
  USP USP-image {
    width: 50%;
  }
  USP USP-image img {
    max-height: 500px;
    margin: 0 auto;
    max-width: 100%;
  }
  USP USP-image img a {
    padding-left: 0px;
    padding-right: 0px;
  }
  USP.odd USP-image {
    order: 1;
  }
  USP h3 {
    margin-top: 2em;
  }
}
.USP-summary {
  color: var(--button-blue);
  cursor: pointer;
  font-size: var(--font-normal);
  font-weight: bold;
  line-height: 2em;
}

banner-container {
  margin-top: 10ex;
  display: flex;
  flex-wrap: wrap;
  flex-direction: row;
  justify-content: center;
  margin-left: auto;
  margin-right: auto;
  padding-right: 30px;
  padding-left: 30px;
  max-width: 1500px;
}
banner-container banner-title {
  font-size: var(--font-bigger2);
  font-weight: bold;
  margin-bottom: 0px;
}
banner-container banner-box, banner-container banner-box-video, banner-container banner-box-testimonial, banner-container banner-box-abo, banner-container banner-box-button {
  background-color: var(--light-blue);
  max-width: 350px;
  margin: 1em;
  padding: 1.3em;
  border-radius: 28px;
}
banner-container banner-box img, banner-container banner-box-video img, banner-container banner-box-testimonial img, banner-container banner-box-abo img, banner-container banner-box-button img {
  margin-left: auto;
  margin-right: auto;
  width: 100%;
}
banner-container banner-box banner-more, banner-container banner-box-video banner-more, banner-container banner-box-testimonial banner-more, banner-container banner-box-abo banner-more, banner-container banner-box-button banner-more {
  text-align: center;
  color: var(--button-blue);
  font-size: var(--font-button);
  line-height: 3em;
}
banner-container banner-box banner-more a:link, banner-container banner-box a:visited, banner-container banner-box-video banner-more a:link, banner-container banner-box-video a:visited, banner-container banner-box-testimonial banner-more a:link, banner-container banner-box-testimonial a:visited, banner-container banner-box-abo banner-more a:link, banner-container banner-box-abo a:visited, banner-container banner-box-button banner-more a:link, banner-container banner-box-button a:visited {
  color: var(--button-blue);
  line-height: 300%;
  font-weight: bold;
}
banner-container banner-box {
  background-color: var(--light-blue);
  max-width: 350px;
}
banner-container banner-box-video {
  background-color: var(--box-gray);
  border: 1px solid var(--border-gray);
  max-width: 200px;
}
banner-container banner-box-video a, banner-container banner-box-video img {
  display: block;
}
banner-container banner-box-testimonial {
  background-color: var(--mid-blue);
  max-width: 200px;
  padding: 1.2em;
  font-size: var(--font-normal);
  line-height: 1.4em;
  color: white;
}
banner-container banner-box-testimonial .testimonial-name {
  line-height: 2em;
  font-style: italic;
}

@media screen and (max-width: 700px) {
  banner-container, container-USP, banner-top {
    max-width: 100%;
    padding-right: 15px;
    padding-left: 20px;
  }
  banner-container USP-text, banner-container USP-image, banner-container banner-title, container-USP USP-text, container-USP USP-image, container-USP banner-title, banner-top USP-text, banner-top USP-image, banner-top banner-title {
    min-width: 80vw !important;
    max-width: 80vw !important;
    margin-left: auto;
    margin-right: auto;
  }
}
container-background {
  background-color: var(--box-gray);
  display: block;
  padding-bottom: 30px;
  margin-bottom: 30px !important;
}

details-container,
details-container-wide,
details-container-2col {
  display: flex;
  flex-wrap: wrap;
  flex-direction: row;
  margin-left: auto;
  margin-right: auto;
  max-width: 1000px;
  margin-bottom: 1em;
  text-align: left;
}
details-container details-box,
details-container-wide details-box,
details-container-2col details-box {
  max-width: 650px;
  min-width: 650px;
  margin-left: auto;
  margin-right: auto;
  padding-left: 0px;
  padding-bottom: 10px;
  font-size: var(--font-long);
  line-height: 1.6em;
  text-align: left;
}
details-container details-box img,
details-container-wide details-box img,
details-container-2col details-box img {
  margin-left: 0px;
  margin-right: 30px;
  max-width: 100%;
  width: 420px;
}
details-container details-box .img-inline,
details-container-wide details-box .img-inline,
details-container-2col details-box .img-inline {
  width: 100% !important;
  margin-right: 0px;
  margin-top: -30px;
}
details-container details-box h2,
details-container-wide details-box h2,
details-container-2col details-box h2 {
  margin-bottom: 0px;
}
details-container details-box h2 img,
details-container-wide details-box h2 img,
details-container-2col details-box h2 img {
  margin-right: 10px;
}
details-container details-box li,
details-container-wide details-box li,
details-container-2col details-box li {
  margin-left: 18px;
}
details-container details-box .title-icon,
details-container-wide details-box .title-icon,
details-container-2col details-box .title-icon {
  margin-top: 20px;
  margin-left: 0px;
  margin-right: 10px;
  height: 30px !important;
  width: auto !important;
  max-width: 40px !important;
  text-align: left;
  vertical-align: baseline;
  display: inline-block;
}
details-container .font18,
details-container-wide .font18,
details-container-2col .font18 {
  font-size: var(--font-normal);
  line-height: 1.7em;
}
details-container .no-margin-bottom,
details-container-wide .no-margin-bottom,
details-container-2col .no-margin-bottom {
  margin-bottom: 0px !important;
}

details-container-2col {
  gap: 50px !important;
}
details-container-2col details-box-2col {
  max-width: 450px;
  min-width: 450px;
  margin-left: 0px;
  padding-left: 0px;
  padding-bottom: 10px;
  font-size: var(--font-long);
  line-height: 1.6em;
  text-align: left;
  gap: 50px !important;
}
details-container-2col details-box-2col img {
  margin-left: 0px;
  margin-right: 30px;
  max-width: 100%;
  width: 420px;
}
details-container-2col details-box-2col h2 {
  margin-bottom: 0px;
}

details-box-full {
  max-width: 100%;
  min-width: 100%;
  margin-right: 30px;
  margin-left: 0px;
  padding-left: 0px;
  padding-bottom: 10px;
  font-size: var(--font-long);
  line-height: 1.6em;
  text-align: left;
  margin-block-start: 0em;
}

.p16 {
  font-size: var(--font-long) !important;
  margin-block-start: 0em;
}

.h3-section-title {
  display: flex;
  align-items: flex-start;
  font-size: var(--font-bigger1) !important;
  font-weight: bold;
  text-align: left;
  margin-top: 0px;
  margin-bottom: 0px;
  width: 100% !important;
  margin-left: 0 !important;
  padding-left: 0 !important;
}

.portrait {
  background-color: white;
  min-width: 300px;
  max-width: 350px;
  row-gap: 15px;
  font-size: var(--font-long);
}
.portrait img {
  max-width: 200px;
}
.portrait .statement {
  font-style: italic;
}

details-container-wide {
  background-color: var(--light-blue);
  background-image: linear-gradient(to bottom right, var(--light-blue), var(--light-blue2));
  width: 100%;
  max-width: 100%;
  margin-top: 4em;
  padding-top: 2em;
  gap: 20px !important;
}
details-container-wide details-container {
  gap: 20px !important;
}
details-container-wide details-box-title {
  max-width: 1000px;
  margin-top: 40px;
  margin-bottom: 0px;
  justify-content: start !important;
  text-align: left;
  justify-self: start !important;
}
details-container-wide h2 {
  margin-top: 40px;
  margin-bottom: 0em;
  line-height: 1.4em;
  justify-self: start;
}
details-container-wide details-box-USP {
  padding-left: 0px;
  margin-bottom: 30px;
  justify-content: center;
  max-width: 1000px;
  gap: 20px;
  text-align: center;
}
details-container-wide details-box-USP a, details-container-wide details-box-USP a:visited {
  color: #000;
}
details-container-wide details-box-USP h2 {
  max-width: 1000px;
  min-width: 320px;
  margin-top: 0px;
  margin-bottom: 0px;
  font-size: var(--font-title);
  font-weight: bold;
  text-align: left;
}
details-container-wide details-box-USP h4 {
  max-width: 320px;
  min-width: 320px;
  margin-top: 0px;
  margin-bottom: 0px;
  font-size: var(--font-normal);
  font-weight: bold;
  text-align: center;
}
details-container-wide details-box-USP h4.wider-image img {
  width: 90px;
  height: 50px;
}
details-container-wide details-box-USP img {
  width: 50px;
  height: 50px;
}

details-usp-container {
  display: flex;
  flex-wrap: wrap;
  flex-direction: row;
  gap: 25px;
  justify-content: center;
  margin: 30px auto 1em auto;
  padding: 0 30px;
  max-width: 1500px;
  margin-left: auto;
  margin-right: auto;
}
details-usp-container details-usp-box {
  display: flex;
  flex-wrap: wrap;
  justify-content: top;
  align-content: flex-start;
  flex-direction: column;
  text-align: center;
  padding: 30px;
  font-size: var(--font-normal);
  border-radius: 28px;
  background-color: white;
  width: 300px;
  box-shadow: 0 0 20px rgba(0, 0, 0, 0.1);
}
details-usp-container details-usp-box h4 {
  font-size: var(--font-bigger1);
  font-weight: bold;
  margin-top: 0px;
  margin-bottom: 1em;
  color: var(--button-blue);
}
details-usp-container details-usp-box .title-icon {
  margin-top: 0px;
  margin-bottom: 1em;
  margin-left: auto;
  margin-right: auto;
  height: 40px !important;
  width: auto !important;
  max-width: 50px !important;
  text-align: center;
  display: block;
  filter: invert(21%) sepia(30%) saturate(1500%) hue-rotate(212deg) brightness(102%) contrast(90%);
}
details-usp-container details-usp-box .button-new {
  margin-top: auto;
}

details-content-box {
  display: flex;
  flex-wrap: wrap;
  justify-content: top;
  align-content: flex-start;
  flex-direction: column;
  margin-left: auto;
  margin-right: auto;
  padding: 30px;
  font-size: var(--font-long);
  border-radius: 28px;
  background-color: white;
  width: 450px;
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.2);
  line-height: 2em !important;
}
details-content-box p {
  display: block;
}
details-content-box a {
  display: block;
  line-height: 1.1em;
  margin-bottom: 0.7em;
}

.width-500 {
  max-width: 500px !important;
  width: 90% !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding-left: 15px;
  padding-right: 15px;
}

@media screen and (max-width: 1050px) {
  details-container {
    gap: 0px !important;
    max-width: 900px !important;
  }
  details-container h2 {
    max-width: 650px;
    min-width: 300px;
    margin-left: auto;
    margin-right: auto;
  }
  details-container details-box-2col,
  details-container details-box section,
  details-container details-box-title {
    max-width: 650px !important;
    min-width: 300px;
    display: block !important;
    margin: 0 auto !important;
    gap: 50px !important;
  }
  details-container details-box-2col,
  details-container details-container details-box-full {
    padding-left: 15px;
    padding-right: 15px;
  }
  details-container details-box-2col img,
  details-container details-container details-box-full img {
    margin-left: 0px;
    margin-right: 0px;
    margin-top: 30px;
    max-width: 100vw;
    min-width: 300px;
  }
  details-container details-box-2col h2 img,
  details-container details-container details-box-full h2 img {
    max-width: 40px;
    min-width: 40px;
  }
  details-container details-container details-box-title {
    display: block;
    max-width: 450px !important;
    min-width: 300px;
    text-align: left;
    margin: 0 auto !important;
  }
  details-container-wide,
  details-container-wide details-container {
    margin-left: auto;
    margin-right: auto;
    align-items: center;
    text-emphasis: center;
    justify-content: center;
  }
  .very-small-text {
    max-width: 450px !important;
  }
  details-box-full {
    max-width: 450px !important;
    display: block;
    margin: 0 auto !important;
    gap: 0px !important;
  }
  details-container details-box + details-box {
    margin-top: 0px !important;
    margin-bottom: 0px !important;
    gap: 0px !important;
  }
  .title-icon, .title-icon img {
    max-width: 40px !important;
    min-width: 30px !important;
  }
}
details-container-wide,
details-container-wide details-container {
  margin-left: auto;
  margin-right: auto;
  align-items: center;
  text-emphasis: center;
  justify-content: center;
}

.very-small-text {
  max-width: 450px !important;
}

details-box-full {
  max-width: 450px !important;
  display: block;
  margin: 0 auto !important;
  gap: 0px !important;
}

details-container details-box + details-box {
  margin-top: 0px !important;
  margin-bottom: 0px !important;
  gap: 0px !important;
}
details-container details-box + details-box .width-500 {
  max-width: 90% !important;
  width: 300px;
  margin-left: auto !important;
  margin-right: auto !important;
}
details-container .title-icon, details-container .title-icon img {
  max-width: 40px !important;
  min-width: 30px !important;
}

@media screen and (max-width: 700px) {
  details-container,
  details-container-2col {
    gap: 0px !important;
    max-width: 90% !important;
    padding-left: 15px !important;
    padding-right: 15px !important;
  }
  details-container h2,
  details-container-2col h2 {
    max-width: 90% !important;
    min-width: 90% !important;
    margin-left: auto;
    margin-right: auto;
    display: block !important;
  }
  details-container details-box-2col,
  details-container details-box,
  details-container details-box section,
  details-container details-box-title,
  details-container details-content-box,
  details-container-2col details-box-2col,
  details-container-2col details-box,
  details-container-2col details-box section,
  details-container-2col details-box-title,
  details-container-2col details-content-box {
    max-width: 90% !important;
    min-width: 90% !important;
    display: block !important;
    margin: 0 auto !important;
    gap: 50px !important;
  }
  details-container details-box-2col h2,
  details-container details-box h2,
  details-container details-box section h2,
  details-container details-box-title h2,
  details-container details-content-box h2,
  details-container-2col details-box-2col h2,
  details-container-2col details-box h2,
  details-container-2col details-box section h2,
  details-container-2col details-box-title h2,
  details-container-2col details-content-box h2 {
    max-width: 100% !important;
    min-width: 100% !important;
  }
  details-container details-box-2col img,
  details-container details-box img,
  details-container details-box section img,
  details-container details-box-title img,
  details-container details-content-box img,
  details-container-2col details-box-2col img,
  details-container-2col details-box img,
  details-container-2col details-box section img,
  details-container-2col details-box-title img,
  details-container-2col details-content-box img {
    margin-left: 0px;
    margin-right: 0px;
    margin-top: 30px;
    max-width: 90%;
    width: 90%;
  }
  details-container details-box-2col h2 img,
  details-container details-box h2 img,
  details-container details-box section h2 img,
  details-container details-box-title h2 img,
  details-container details-content-box h2 img,
  details-container-2col details-box-2col h2 img,
  details-container-2col details-box h2 img,
  details-container-2col details-box section h2 img,
  details-container-2col details-box-title h2 img,
  details-container-2col details-content-box h2 img {
    max-width: 40px;
    width: auto;
  }
  details-container details-box-2col li,
  details-container details-box li,
  details-container details-box section li,
  details-container details-box-title li,
  details-container details-content-box li,
  details-container-2col details-box-2col li,
  details-container-2col details-box li,
  details-container-2col details-box section li,
  details-container-2col details-box-title li,
  details-container-2col details-content-box li {
    margin-left: 10px !important;
  }
  details-container details-box-2col ul, details-container details-box-2col ol,
  details-container details-box ul,
  details-container details-box ol,
  details-container details-box section ul,
  details-container details-box section ol,
  details-container details-box-title ul,
  details-container details-box-title ol,
  details-container details-content-box ul,
  details-container details-content-box ol,
  details-container-2col details-box-2col ul,
  details-container-2col details-box-2col ol,
  details-container-2col details-box ul,
  details-container-2col details-box ol,
  details-container-2col details-box section ul,
  details-container-2col details-box section ol,
  details-container-2col details-box-title ul,
  details-container-2col details-box-title ol,
  details-container-2col details-content-box ul,
  details-container-2col details-content-box ol {
    padding-left: 10px !important;
    margin-left: 10px !important;
  }
  details-container details-content-box,
  details-container-2col details-content-box {
    width: 80% !important;
    max-width: 80% !important;
    min-width: 50% !important;
    line-height: 2em !important;
  }
}
.blockquote-boxes {
  display: flex;
  flex-wrap: wrap;
  gap: 32px;
  justify-content: center;
  margin: 2em auto;
}
.blockquote-boxes h3 {
  flex-basis: 100%;
  font-size: var(--font-bigger2);
  font-weight: bold;
  text-align: center;
}
.blockquote-boxes blockquote {
  background-color: var(--mid-blue);
  border-radius: 20px;
  max-width: 200px;
  margin: 0;
  padding: 1.2em;
  font-size: var(--font-normal);
  line-height: 1.4em;
}
.blockquote-boxes blockquote em {
  display: block;
  margin-top: 0.5em;
}
.blockquote-boxes blockquote img {
  max-width: 100%;
}
.blockquote-boxes blockquote a, .blockquote-boxes blockquote img {
  display: block;
  margin-bottom: 0.5em;
}
.blockquote-boxes.video-boxes blockquote {
  background-color: var(--box-gray);
}
.blockquote-boxes.testimonial-boxes blockquote {
  color: white;
}

container-footer {
  align-items: center;
  background-color: var(--mid-gray);
  color: white;
  display: flex;
  flex-wrap: wrap;
  flex-direction: row;
  margin-left: 0;
  margin-right: 0;
  min-height: 80px;
  padding-top: 5px;
  padding-bottom: 10px;
  width: 100vw;
  position: relative;
  left: 50%;
  right: 50%;
  margin-left: -50vw;
  margin-right: -50vw;
}
container-footer footer-content {
  align-items: center;
  display: flex;
  flex: 1 1 0;
  flex-wrap: wrap;
  justify-content: space-between;
  justify-items: stretch;
  margin-left: auto;
  margin-right: auto;
  padding-left: 20px;
  padding-right: 20px;
  max-width: 1200px;
}
container-footer footer-content trimutic-logo {
  margin-right: 100px;
  float: left;
  padding-top: 15px;
  text-align: left;
}
container-footer footer-content trimutic-logo img {
  width: 150px;
}
container-footer footer-content footer-middle {
  float: left;
  text-align: center;
}
container-footer footer-content footer-menu {
  float: left;
  margin-left: 30px;
  text-align: right;
}
container-footer footer-content footer-menu nav-f {
  color: white;
}
container-footer footer-content footer-menu nav-f a, container-footer footer-content footer-menu nav-f a:visited {
  color: white;
  line-height: 1.6em;
  margin-left: 20px;
}
container-footer .small-size {
  display: none;
}
container-footer .normal-size {
  display: flex;
}

@media screen and (max-width: 1024px) {
  container-footer footer-content {
    margin-top: 10px;
    max-width: 984px;
    min-width: 729px;
    padding-left: 20px;
    padding-right: 20px;
  }
  container-footer footer-content trimutic-logo {
    float: left;
    margin-right: 0px;
    margin: 0;
    text-align: left;
  }
  container-footer footer-content trimutic-logo img {
    width: 150px;
  }
  container-footer footer-content footer-middle {
    float: center;
    margin: 0;
    text-align: center;
    width: max-content;
  }
  container-footer footer-content footer-menu {
    float: right;
    float: right;
    flex-wrap: wrap;
    margin: 0;
    margin-bottom: 10px;
    width: max-content;
    text-align: right;
  }
  container-footer footer-content footer-menu nav-f a, container-footer footer-content footer-menu nav-f a:visited {
    margin-left: 50px;
    display: block;
    margin-bottom: 0.2em;
  }
}
@media screen and (min-width: 769px) {
  .normal-size {
    display: flex;
  }
  .small-size {
    display: none;
  }
}
@media screen and (max-width: 768px) {
  container-footer footer-content {
    margin-top: 10px;
    max-width: 728px;
    min-width: 90vw;
    padding-left: 20px;
    padding-right: 20px;
  }
  container-footer footer-content trimutic-logo {
    float: left;
    line-height: 40px;
    margin-right: 0px;
    margin: 0;
    padding-top: 5px;
    padding-bottom: 10px;
    text-align: center;
  }
  container-footer footer-content trimutic-logo img {
    width: 150px;
  }
  container-footer footer-content footer-menu {
    flex-wrap: wrap;
    float: right;
    margin: 0;
    margin-bottom: 10px;
    text-align: right;
    width: max-content;
  }
  .normal-size {
    display: none;
  }
  .small-size {
    display: flex;
  }
}
#overlay {
  border: none;
  overflow: clip;
  padding: 8px;
  z-index: 100;
  max-width: 1000px;
  text-align: center;
  border-radius: 10px;
}
#overlay #overlay-close {
  display: block;
  cursor: pointer;
  padding: 8px;
  position: absolute;
  right: 8px;
  top: 8px;
  font-size: 26px;
}
#overlay #overlay-img {
  box-sizing: border-box;
  margin: 0 auto;
  max-width: 100%;
  max-height: 100%;
}
#overlay #overlay-content {
  padding-top: 38px;
  padding-bottom: 20px;
  padding-left: 20px;
  padding-right: 20px;
  overflow-y: auto;
}
#overlay #overlay-content iframe {
  margin: 0 auto;
}
#overlay #more-content {
  margin: 0 auto;
  max-width: 495px;
  text-align: left;
  font-size: var(--font-normal);
}
#overlay #more-content h3 {
  margin-top: 0;
  font-size: var(--font-button);
}

#overlay-background {
  background: rgba(0, 0, 0, 0.4);
  display: none;
  inset: 0;
  position: fixed;
  z-index: 10;
}

price-container {
  display: flex;
  flex-wrap: wrap;
  flex-direction: row;
  gap: 20px;
  justify-content: center;
  margin: 30px auto 1em auto;
  padding: 0 30px;
  max-width: 1500px;
  margin-left: auto;
  margin-right: auto;
}
price-container price-box {
  display: flex;
  flex-wrap: wrap;
  justify-content: top;
  align-content: flex-start;
  flex-direction: column;
  padding: 10px;
  font-size: var(--font-normal);
  color: white;
  border-radius: 28px;
  background-color: var(--tier_1);
  width: 250px;
  padding-bottom: 15px;
}
price-container price-box.plan-test {
  background-color: var(--tier_0);
}
price-container price-box.tier_2 {
  background-color: var(--tier_2);
}
price-container price-box.tier_3 {
  background-color: var(--tier_3);
}
price-container price-box section {
  flex-grow: 1;
}
price-container price-box h2, price-container price-box h3, price-container price-box h4, price-container price-box p, price-container price-box ul {
  display: block;
  margin: 0;
}
price-container price-box h2, price-container price-box h3, price-container price-box h4, price-container price-box p {
  text-align: center;
}
price-container price-box h2 {
  font-family: "IBMPlexSans";
  font-size: var(--font-title);
  font-weight: bold;
  line-height: 1.1em;
  margin-top: 0.25em;
  margin-bottom: 0.5em;
}
price-container price-box h3 {
  font-size: var(--font-normal);
  font-weight: bold;
  margin-bottom: 0.5em;
}
price-container price-box h4 {
  margin: 1em 0 0.5em 0;
  font-size: var(--font-button);
  font-weight: bold;
}
price-container price-box ul {
  font-size: var(--font-listing);
  text-align: left;
  padding-left: 1.2em;
  line-height: 1.3em;
}
price-container price-box ul:first-child {
  margin-top: 0.5em;
}
price-container price-box li {
  margin-top: 0.4em;
  padding-top: 0em;
}
price-container price-box ul + ul {
  margin-top: 1em;
}
price-container price-box p {
  font-size: var(--font-mini);
  line-height: initial;
}
price-container price-box p:last-child {
  margin-bottom: 1em;
}
price-container price-box a.button-register {
  bottom: 0px;
  background-color: var(--light-blue);
  color: black;
  width: 100%;
  text-align: center;
  text-decoration: none;
  font-size: var(--font-normal);
  font-weight: bold;
  line-height: 2.5em;
  border-radius: 20px;
  box-shadow: 0px 0px 30px rgba(37, 62, 85, 0.5);
  color: white;
  text-decoration: none;
  margin-top: auto;
}
price-container price-box a.button-register:visited {
  color: black;
  text-decoration: none;
}

pricing-details {
  display: flex;
  flex-wrap: wrap;
  flex-direction: row;
  margin: 0 auto 1em auto;
  max-width: 1000px;
}
pricing-details h2 {
  margin: 2em 0 1em 0;
  line-height: 1.4em;
  text-align: left;
  flex-basis: 100%;
}
pricing-details h3 {
  font-size: var(--font-bigger1);
  text-align: left;
  max-width: 90vw;
  margin-bottom: 0px;
}
pricing-details h4 {
  font-size: var(--font-normal);
  font-weight: bold;
}
pricing-details ul li {
  font-size: var(--font-normal);
}
pricing-details p + h2, pricing-details p + h3, pricing-details p + h4 {
  margin-top: 1em !important;
}
pricing-details .section-title {
  width: 900px !important;
  min-width: 700px;
  display: flex;
  margin-right: 30px;
  margin-left: 0px;
  padding-left: 0px;
  text-align: left;
}
pricing-details section {
  margin-right: 30px;
  margin-left: 0px;
  padding-left: 0px;
  font-size: var(--font-long);
  line-height: 1.7em;
  text-align: left;
  row-gap: 40px;
  max-width: 450px;
}
pricing-details section img {
  margin-left: 0px;
  margin-right: 30px;
  width: 420px;
}
pricing-details section h2 {
  margin-bottom: 0px;
}
pricing-details section h3 {
  font-size: var(--font-bigger1) !important;
}
pricing-details section h4 {
  font-size: var(--font-normal);
  font-style: bold;
  margin-bottom: 0px;
}
pricing-details section h3, pricing-details section h4 {
  margin-top: 0px;
}
pricing-details section p + p {
  margin-top: 0em;
}

.discount-box {
  background-color: #e2e2e2;
  border-radius: 20px;
  color: black;
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  font-size: var(--font-normal);
  justify-content: top;
  padding: 20px;
  width: 650px;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 2em;
  text-align: left;
}
.discount-box h4 {
  color: black;
}

@media screen and (max-width: 1024px) {
  pricing-details, pricing-details section {
    max-width: 450px;
    display: block;
    margin: 0 auto;
    gap: 30px !important;
    row-gap: 30px !important;
  }
  pricing-details {
    padding-left: 15px;
    padding-right: 15px;
  }
}
@media screen and (max-width: 700px) {
  price-container price-box {
    max-width: 320px !important;
    margin-left: auto;
    margin-right: auto;
  }
  price-container price-box h2 {
    margin-left: auto;
    margin-right: auto;
  }
}
#contact-form,
#beta-form {
  max-width: 500px;
}

form {
  border: 1px solid var(--mid-gray);
  border-radius: 10px;
  max-width: 500px;
  background-color: var(--box-gray);
  margin-left: auto;
  margin-right: auto;
  margin-top: 20px;
  padding: 20px;
}
form h3 {
  margin-bottom: 0px;
  margin-top: 0px;
}
form h4 {
  margin-bottom: 5px;
  margin-top: 5px;
}
form p {
  margin-bottom: 0px;
  margin-top: 0px;
  font-size: var(--font-long);
}
form label {
  display: block;
  font-size: var(--font-long);
  padding-left: 3px;
  padding-top: 15px;
  padding-bottom: 2px;
}
form #contact-form-message {
  display: none;
}
form #contact-form-error {
  display: none;
  color: var(--error-text);
}

input, textarea, select {
  width: 95%;
  font-size: var(--font-normal) !important;
  padding: 4px;
  font-family: inherit;
  font-weight: lighter;
  border-radius: 8px;
  margin-left: auto;
  margin-right: auto;
  border: 1px solid gray;
  outline: none;
}

input:focus, textarea:focus, select:focus {
  border: 2px solid #555;
}

input[type=checkbox] {
  width: auto;
  margin-right: 10px;
  transform: scale(1.5);
}

option {
  font-size: var(--font-normal) !important;
}

input[type=submit] {
  cursor: pointer;
  color: white;
  background-color: var(--apple-blue);
  margin-left: 20px !important;
  margin-right: 20px !important;
  padding: 9px 21px !important;
  width: fit-content;
}

@media screen and (max-width: 700px) {
  form {
    margin-top: 0px;
    padding: 15px;
    font-size: var(--font-long);
  }
  form label {
    padding-top: 2px;
    padding-bottom: 0;
    font-size: var(--font-long);
  }
  form input, form textarea, form datalist {
    width: 95%;
    font-size: var(--font-normal);
    padding: 2px;
    margin-top: 0;
  }
}
.newsletter-form {
  border: none;
  font-family: "IBMPlexSans", sans-serif;
  height: 690px;
  text-align: left;
  width: 350px;
}
.newsletter-form .input_X2qHP {
  font-size: 14px !important;
}

iframe {
  height: 690px;
}

.form_15iP5 {
  height: 690px;
}

.downloads-table th, .downloads-table td {
  width: 150px;
  text-align: left;
  border-bottom: 1px solid white;
}
.downloads-table td {
  height: 60px !important;
}
.downloads-table .version-column {
  width: 80px;
  text-align: center !important;
}
.downloads-table .date-column {
  width: 150px;
  text-align: center !important;
}
.downloads-table .download-column {
  width: auto;
  text-align: left !important;
  margin: 0px;
  padding: 0px;
  align-items: start;
  justify-content: left;
}
.downloads-table .download-column a {
  margin-left: 0px;
  padding-left: 0px;
}

@media screen and (max-width: 600px) {
  .downloads-table th, .downloads-table td {
    width: auto;
    font-size: 13px !important;
    padding-right: 15px !important;
  }
  .downloads-table .version-column,
  .downloads-table .date-column,
  .downloads-table .download-column {
    width: auto;
    margin-left: 0px;
    padding-left: 0px;
  }
}
details-container h2,
pricing-details h2,
details-box h2 {
  margin-bottom: 0px;
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 1.5s ease-out, transform 1.5s ease-out;
}
details-container h2.animate-in,
pricing-details h2.animate-in,
details-box h2.animate-in {
  opacity: 1;
  transform: translateY(0);
}

.no_animation details-container h2,
.no_animation pricing-details h2,
.no_animation details-box h2,
.no_animation,
h2.no_animation,
details-container h2.no_animation,
pricing-details h2.no_animation,
details-box h2.no_animation {
  opacity: 1 !important;
  transform: translateY(0) !important;
  transition: none !important;
}
.no_animation details-container h2.animate-in,
.no_animation pricing-details h2.animate-in,
.no_animation details-box h2.animate-in,
.no_animation.animate-in,
h2.no_animation.animate-in,
details-container h2.no_animation.animate-in,
pricing-details h2.no_animation.animate-in,
details-box h2.no_animation.animate-in {
  opacity: 1;
  transform: translateY(0);
}

@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(50px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.grow-in-view {
  opacity: 0;
  transform: scale(0.9);
  transition: opacity 0.8s ease-out, transform 0.8s ease-out;
}
.grow-in-view.animate-in {
  opacity: 1;
  transform: scale(1);
}

@keyframes scaleInView {
  from {
    opacity: 0;
    transform: scale(0.8);
  }
  to {
    opacity: 1;
    transform: scale(1);
  }
}
.image-carousel {
  position: relative;
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
}

.image-carousel .carousel-image {
  position: absolute;
  opacity: 0;
  transition: opacity 0.01s ease-in-out;
}

.image-carousel .carousel-image.active {
  position: relative;
  opacity: 1;
}

.carousel-caption {
  text-align: center;
  margin-top: 15px;
  color: #666;
  font-style: italic;
}

.carousel-caption-in-shadow {
  margin-top: -20px !important;
  z-index: 100;
}

@media screen and (max-width: 600px) {
  .carousel-caption-in-shadow {
    margin-top: -10px !important;
    z-index: 100;
  }
}
.coming-soon-button,
.coming-soon-button2,
.coming-soon-button3 {
  position: absolute !important;
  left: 80%;
  top: 20px;
  width: 120px;
  height: 120px;
  transform: translateX(-50%);
  background-color: red;
  color: white;
  font-size: 24px;
  font-weight: bold;
  padding: 0;
  border-radius: 100px;
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.3);
  z-index: 2000;
  display: flex;
  text-align: center;
  align-items: center;
  justify-content: center;
  opacity: 0;
  animation: fadeIn 1s ease-out 2s forwards;
}

.coming-soon-button2 {
  left: 70%;
  top: 250px;
}
.coming-soon-button2 a {
  color: white;
  text-decoration: none;
}

.coming-soon-button3 {
  left: 80%;
  top: 100px;
}

@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateX(-50%) scale(0.8);
  }
  to {
    opacity: 1;
    transform: translateX(-50%) scale(1);
  }
}