.navbar-toggle {
  position: absolute;
  right: 8px;
  top: 20px;
  width: 43px;
  height: 43px;
  border-width: 0;
  border-radius: 4px;
  background: transparent;
  z-index: 12;
  outline: 0;
  outline-color: transparent;
  outline-style: none;
  box-shadow: none !important;
  -webkit-tap-highlight-color: rgba(0,0,0,0);
  -webkit-tap-highlight-color: transparent;
  transition: 0.5s ease-in-out;
  cursor: pointer;
}
.navbar-toggle:focus {
  outline: 0;
  outline-color: transparent;
  outline-style: none;
  box-shadow: none !important;
  -webkit-tap-highlight-color: rgba(0,0,0,0);
  -webkit-tap-highlight-color: transparent;
}
@media screen and (min-width: 1024px) {
  .navbar-toggle {
    display: none !important;
  }
}
@media screen and (max-width: 1023px) {
  .navbar-toggle {
    display: block !important;
  }
}
.navbar-toggle span {
  display: block;
  position: absolute;
  height: 2px;
  width: 21px;
  background: #0e5c79;
  border-radius: 6px;
  opacity: 1;
  left: 11px;
  transform: rotate(0deg);
  transition: 0.25s ease-in-out;
}
@media (prefers-color-scheme: dark) {
  .navbar-toggle span {
    background: #fff !important;
  }
}
.navbar-toggle span:nth-child(1) {
  top: 14px;
}
.navbar-toggle span:nth-child(2),
.navbar-toggle span:nth-child(3) {
  top: 21px;
}
.navbar-toggle span:nth-child(4) {
  top: 29px;
}
.navbar-toggle.open span:nth-child(1) {
  top: 21px;
  width: 0%;
  left: 50%;
}
.navbar-toggle.open span:nth-child(2) {
  transform: rotate(45deg);
}
.navbar-toggle.open span:nth-child(3) {
  transform: rotate(-45deg);
}
.navbar-toggle.open span:nth-child(4) {
  top: 21px;
  width: 0%;
  left: 50%;
}
.navigation-mobile {
  display: none;
}
.navigation-mobile .container {
  padding: 0 16px;
}
.navigation-mobile .contact-data {
  display: block;
  float: left;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  width: 100%;
  font-size: 14px;
  padding-bottom: 40px;
}
.navigation-mobile .contact-data p {
  margin-top: 24px;
}
.navigation-mobile .language-selector {
  display: block;
  float: left;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  width: 100%;
  padding-top: 24px;
  text-align: center;
  margin-bottom: 24px;
  margin-top: 0;
}
.navigation-mobile .language-selector li {
  margin: 0;
  float: none;
}
.navigation-mobile .language-selector li a {
  margin: 0 15px;
}
@media screen and (max-width: 1024px) {
  .navigation-mobile {
    background: #fff;
    display: block;
    position: fixed;
    float: left;
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    z-index: 10;
    width: 300px;
    top: 0;
    bottom: -100px;
    right: -300px;
    margin: 0;
    box-shadow: 0 0 5px rgba(0,0,0,0.25);
    -moz-transition: 0.3s;
    -webkit-transition: 0.3s;
    transition: 0.3s;
    padding: 80px 0 100px;
    overflow-y: auto;
    overflow-x: hidden;
  }
  .navigation-mobile.visible {
    right: 0;
  }
  .navigation-mobile .navigation {
    display: block;
    float: left;
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    width: 100%;
  }
  .navigation-mobile .navigation .nav.menu {
    display: block;
    float: left;
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    list-style: none;
    margin: 0;
    padding: 0;
    width: 100%;
  }
  .navigation-mobile .navigation .nav.menu li {
    display: block;
    float: left;
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    width: 100%;
  }
  .navigation-mobile .navigation .nav.menu li.current a,
  .navigation-mobile .navigation .nav.menu li.current .nav-header,
  .navigation-mobile .navigation .nav.menu li.active a,
  .navigation-mobile .navigation .nav.menu li.active .nav-header {
    color: #0e5c79;
    font-weight: 600;
  }
  .navigation-mobile .navigation .nav.menu li .nav-child,
  .navigation-mobile .navigation .nav.menu li:hover .nav-child {
    display: none;
  }
  .navigation-mobile .navigation .nav.menu li a,
  .navigation-mobile .navigation .nav.menu li .nav-header {
    display: block;
    float: left;
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    width: 100%;
    border-radius: 0;
    padding: 13.333333333333px 0;
    line-height: 1.3;
    text-decoration: none;
    color: #000;
  }
  .navigation-mobile .navigation .nav.menu li .nav-header {
    position: relative;
  }
  .navigation-mobile .navigation .nav.menu li .nav-header:before {
    border: 2px solid #0e5c79;
    border-right-width: 0;
    border-bottom-width: 0;
    content: " ";
    width: 8px;
    height: 8px;
    display: block;
    position: absolute;
    right: 5px;
    top: 50%;
    -moz-transition: 0.3s;
    -webkit-transition: 0.3s;
    transition: 0.3s;
    transform: translateY(-50%) rotate(135deg);
  }
  .navigation-mobile .navigation .nav.menu li.expanded > .nav-header:before {
    transform: translateY(-50%) rotate(45deg);
  }
  .navigation-mobile .navigation .nav.menu .nav-child {
    display: block;
    float: left;
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    width: 100%;
    list-style: none;
    padding: 0;
    border: 1px solid #0e5c79;
    box-shadow: none;
    display: none;
    position: relative;
    padding: 5px 0;
    margin: 10px 0;
    border-radius: 2px;
  }
  .navigation-mobile .navigation .nav.menu .nav-child li {
    display: block;
    float: left;
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    margin: 0;
    padding: 0;
    clear: both;
    width: 100%;
  }
  .navigation-mobile .navigation .nav.menu .nav-child li.current a,
  .navigation-mobile .navigation .nav.menu .nav-child li.active a {
    font-weight: bold;
  }
  .navigation-mobile .navigation .nav.menu .nav-child li a {
    display: block;
    float: left;
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    width: 100%;
    font-size: 14px;
    line-height: 32px;
    font-weight: normal;
    color: #888;
    padding: 5px 15px;
    text-decoration: none;
    white-space: nowrap;
    border-radius: 0;
  }
  .navigation-mobile .navigation .nav.menu .nav-child li a:hover {
    background: #eee;
    color: #000;
    text-shadow: 1px 1px 1px rgba(255,255,255,0.4);
  }
}
@media screen and (max-width: 1024px) and (prefers-color-scheme: dark) {
  .navigation-mobile {
    background: #000;
  }
}
@media screen and (max-width: 1024px) and (prefers-color-scheme: dark) {
  .navigation-mobile .navigation .nav.menu li.current a,
  .navigation-mobile .navigation .nav.menu li.current .nav-header,
  .navigation-mobile .navigation .nav.menu li.active a,
  .navigation-mobile .navigation .nav.menu li.active .nav-header {
    color: #87aebc;
  }
}
@media screen and (max-width: 1024px) and (prefers-color-scheme: dark) {
  .navigation-mobile .navigation .nav.menu li a,
  .navigation-mobile .navigation .nav.menu li .nav-header {
    color: #fff;
  }
}
@media screen and (max-width: 1024px) and (prefers-color-scheme: dark) {
  .navigation-mobile .navigation .nav.menu li .nav-header:before {
    border-color: #87aebc;
  }
}
@media screen and (max-width: 1024px) and (prefers-color-scheme: dark) {
  .navigation-mobile .navigation .nav.menu .nav-child {
    border-color: #87aebc;
  }
}
@media screen and (max-width: 1024px) and (prefers-color-scheme: dark) {
  .navigation-mobile .navigation .nav.menu .nav-child li a {
    color: #fff;
  }
}
@media screen and (max-width: 1024px) and (prefers-color-scheme: dark) {
  .navigation-mobile .navigation .nav.menu .nav-child li a:hover {
    color: #fff;
    background: #111;
  }
}
@media screen and (max-width: 1023px) {
  header .document-center nav .nav.menu {
    display: none !important;
  }
}
header .document-center nav .logo {
  display: block;
  float: left;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  margin: 0;
}
header .document-center nav .logo img {
  height: 66px;
}
@media screen and (max-width: 768px) {
  header .document-center nav .logo img {
    height: 44px;
  }
}
header .document-center nav .menu {
  display: block;
  float: left;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  width: auto;
  float: right;
  margin: 20px 0 0;
  padding: 0;
  list-style: none;
  position: relative;
  z-index: 15;
}
header .document-center nav .menu .relative-container {
  display: block;
  float: left;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  width: 100%;
  position: relative;
  padding-right: 32px;
}
header .document-center nav .menu li {
  display: block;
  float: left;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  width: auto;
  margin: 0 1px 0 0;
  padding: 0;
  position: relative;
  z-index: 10;
}
header .document-center nav .menu li a,
header .document-center nav .menu li .relative-container {
  display: block;
  float: left;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  width: auto;
  color: #222;
  font-size: 18px;
  text-decoration: none;
  padding: 20px;
  white-space: nowrap;
  z-index: 12;
  position: relative;
  transition: 0.2s;
  -webkit-transition: 0.2s;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}
@media (prefers-color-scheme: dark) {
  header .document-center nav .menu li a,
  header .document-center nav .menu li .relative-container {
    color: #fff;
  }
}
header .document-center nav .menu li .relative-container {
  padding-right: 40px;
}
header .document-center nav .menu li:hover,
header .document-center nav .menu li.isVisible {
  z-index: 12;
}
header .document-center nav .menu li:hover ul,
header .document-center nav .menu li.isVisible ul {
  display: block;
}
header .document-center nav .menu li:hover ul li:hover a,
header .document-center nav .menu li.isVisible ul li:hover a {
  color: #0e5c79;
}
@media (prefers-color-scheme: dark) {
  header .document-center nav .menu li:hover ul li:hover a,
  header .document-center nav .menu li.isVisible ul li:hover a {
    color: #87aebc;
  }
}
header .document-center nav .menu li:hover a,
header .document-center nav .menu li.isVisible a {
  color: #000;
}
@media (prefers-color-scheme: dark) {
  header .document-center nav .menu li:hover a,
  header .document-center nav .menu li.isVisible a {
    color: #fff;
  }
}
header .document-center nav .menu li .expander {
  display: block;
  position: absolute;
  left: auto;
  right: 0;
  top: 0;
  bottom: 0;
  background: #ccc;
  bottom: 0px;
  cursor: pointer;
  width: 32px;
  content: " ";
  background: url('../img/icon_dropdown.png') no-repeat center center;
  z-index: 3;
}
header .document-center nav .menu li ul {
  display: none;
  float: left;
  position: absolute;
  left: 0;
  top: 60px;
  width: auto;
  border-width: 1px 1px 0px 1px;
  box-shadow: 1px 12px 12px -12px rgba(0,0,0,0.2), 1px -6px 12px -12px rgba(0,0,0,0.2);
  background: #ffffff;
  border-radius: 3px;
  z-index: 12;
  padding: 6px 0;
}
@media (prefers-color-scheme: dark) {
  header .document-center nav .menu li ul {
    background: #1e1e1e;
  }
}
header .document-center nav .menu li ul li {
  width: 100%;
  clear: both;
  z-index: 2;
  padding: 0;
}
header .document-center nav .menu li ul li:hover ul {
  display: block;
}
header .document-center nav .menu li ul li a {
  color: #222;
  width: 100%;
  padding: 10px 20px;
  display: block;
  float: left;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}
@media (prefers-color-scheme: dark) {
  header .document-center nav .menu li ul li a {
    color: #fff;
  }
}
@media screen and (max-width: 600px) {
  header .document-center nav .menu-icon {
    display: block;
  }
  header .document-center nav .menu {
    display: none;
    width: 100%;
  }
  header .document-center nav .menu li:hover ul {
    display: none;
  }
  header .document-center nav .menu li.isVisible:hover ul {
    display: block;
  }
  header .document-center nav .menu li {
    width: 100%;
    clear: both;
  }
  header .document-center nav .menu li a {
    width: 100%;
  }
  header .document-center nav .menu li ul {
    width: 100%;
    position: relative;
    top: 0;
    left: 0;
  }
}
html {
  font-size: 10px;
  overflow-x: hidden;
  scroll-behavior: smooth;
}
@media (prefers-color-scheme: dark) {
  html {
    color-scheme: dark;
  }
}
img {
  height: auto !important;
}
@media (prefers-color-scheme: dark) {
  .my-name {
    fill: #fff;
  }
}
.wrapper {
  display: flex;
  min-height: 100vh;
  flex-direction: column;
  float: left;
  width: 100%;
}
.wrapper > * {
  float: left;
  width: 100%;
}
.wrapper .content-wrapper {
  flex-grow: 1;
  flex-shrink: 0;
}
.circle {
  display: block;
  width: 200px;
  height: 200px;
  background: linear-gradient(135deg,#e4f7f2,#bed7dc);
  z-index: 1;
  position: absolute;
  right: 0;
  top: -50px;
  border-radius: 50%;
  transform: translateX(50%);
  opacity: 0.4;
}
@media (prefers-color-scheme: dark) {
  .circle {
    background: #141414;
    opacity: 1;
  }
}
.category-desc,
.article-content {
  position: relative;
  z-index: 2;
}
.transition {
  transition: 0.2s;
  -webkit-transition: 0.2s;
}
.btn.btn-primary {
  background: transparent;
  color: #0e5c79;
  border-color: #0e5c79;
  font-size: 20px;
}
.btn.btn-primary:hover,
.btn.btn-primary:active,
.btn.btn-primary:focus {
  color: #fff;
  background: #2380a2;
  border-color: #2380a2;
}
@media (prefers-color-scheme: dark) {
  .btn.btn-primary {
    color: #87aebc;
    border-color: #87aebc;
  }
}
.sizing {
  display: block;
  float: left;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}
.transition {
  transition: 0.2s;
  -webkit-transition: 0.3s;
}
.shadow {
  box-shadow: 0 0 12px rgba(0,0,0,0.4);
}
html {
  background: #fff;
}
.timeline-debug {
  position: fixed;
  left: 0;
  bottom: 0;
  background: #fff;
  color: #000;
  padding: 10px;
  display: block;
  z-index: 10000;
}
body {
  font-size: 20px;
  line-height: 1.4;
  overflow-x: hidden;
  margin: 0;
  padding: 0;
  color: #000;
}
@media (prefers-color-scheme: dark) {
  body {
    color: #fff;
  }
}
small {
  font-size: 1.2rem;
  line-height: 1.4;
  display: block;
}
.subheading-category {
  display: none;
}
ul,
li {
  margin: 0;
  padding: 0;
  list-style: none;
}
p {
  margin: 0 0 13.333333333333px;
  padding: 0;
}
a img {
  border-width: 0;
}
img {
  max-width: 100%;
}
#logo {
  display: none;
}
h1,
h2,
h3,
h4,
h5,
h6 p,
input,
button,
textarea,
select,
option,
div,
span,
body,
html {
  font-family: "Open Sans", Segoe UI, Arial, Verdana, Helvetica;
}
body h1,
body h2,
body h3,
body h4,
body h5,
body h6 {
  font-weight: 500;
}
h1.title,
h2.title,
h3.title,
h4.title,
h5.title,
h6.title {
  text-align: center;
  text-transform: uppercase;
  margin-top: 40px;
  margin-bottom: 20px;
  color: #000000;
}
h1.page-header,
h2.page-header,
h3.page-header,
h4.page-header,
h5.page-header,
h6.page-header {
  text-align: center;
}
h1 {
  font-size: 36px;
  line-height: 1.05;
  font-weight: 500;
}
h2 {
  font-size: 27px;
  font-weight: 500;
  margin-bottom: 20px;
}
h2:has( + p ) {
  margin-bottom: 0;
}
h3 {
  font-size: 22px;
  font-weight: 400;
}
h4 {
  font-size: 20px;
  font-weight: 400;
}
a:link,
a:visited,
a:hover {
  color: #0e5c79;
}
@media (prefers-color-scheme: dark) {
  a:link,
  a:visited,
  a:hover {
    color: #87aebc;
  }
}
.document-center {
  display: block;
  float: left;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  float: none;
  max-width: 1200px;
  padding: 20px;
  width: 100%;
  margin: 0 auto;
}
.icons {
  display: block;
  float: left;
  width: 50px;
  height: 50px;
  position: relative;
  background-repeat: no-repeat;
}
.icons.email {
  background-image: url('../img/icon_mail.png');
  background-position: center center;
}
.icons.menu {
  background-image: url('../img/icon_menu.png');
  background-position: center center;
}
body > header {
  display: block;
  float: left;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  width: 100%;
  margin-bottom: 20px;
}
nav {
  display: block;
  width: 100%;
  float: left;
}
.invisible {
  position: absolute;
  left: -9999px;
}
.words-splitter {
  color: #0e5c79;
}
.main-info {
  display: block;
  float: left;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  width: 100%;
  text-align: center;
  position: relative;
}
.left-info,
.right-info {
  display: block;
  float: left;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  width: 50%;
}
.left-info {
  padding-right: 170px;
  padding-right: 20px;
  text-align: right;
}
.right-info {
  padding-left: 170px;
  padding-left: 20px;
  text-align: left;
}
.michal {
  display: block;
  float: left;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  position: absolute;
  left: 50%;
  top: 100px;
  margin-left: -150px;
}
.right-info .section-title,
.left-info .section-title {
  display: block;
  float: left;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  width: 100%;
  font-size: 28px;
  line-height: 34px;
  color: #0e5c79;
  font-weight: 400;
  text-transform: uppercase;
  margin-bottom: 5px;
}
.right-info .section-info,
.left-info .section-info {
  display: block;
  float: left;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  width: 100%;
  font-size: 18px;
  color: #000;
  font-weight: 400;
  margin-bottom: 20px;
}
@media screen and (max-width: 1100px) {
  .left-info {
    padding-right: 20px;
  }
  .right-info {
    padding-left: 20px;
  }
  .michal {
    position: static;
    left: 0;
    top: 0;
    margin: 0 auto;
    width: 100%;
    text-align: center;
  }
}
.cv-download {
  display: block;
  float: left;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  font-size: 24px;
  white-space: nowrap;
  background: #0e5c79;
  color: #fff;
  border-radius: 20px;
  padding: 10px 30px;
  display: inline-block;
  float: none;
  margin: 20px auto;
  cursor: pointer;
  transition: 0.2s;
  -webkit-transition: 0.2s;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}
.cv-download:hover {
  background: #888;
  color: #fff;
}
.blog {
  display: block;
  float: left;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  width: 100%;
}
.abilities {
  display: block;
  float: left;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  width: 100%;
}
.abilities .left {
  display: block;
  float: left;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  width: 50%;
  padding-right: 20px;
}
.abilities .left img {
  float: left;
  max-width: 100%;
}
.abilities .right {
  display: block;
  float: left;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  width: 50%;
  padding-left: 20px;
}
.abilities .right .module {
  display: block;
  float: left;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  width: 100%;
  margin-bottom: 20px;
  padding: 20px;
  background: #eee;
}
.abilities .right .module h1,
.abilities .right .module h2,
.abilities .right .module h3,
.abilities .right .module h4,
.abilities .right .module h5,
.abilities .right .module h6 {
  margin: 0;
  padding: 0;
}
.abilities .left,
.abilities .right {
  margin: 0;
}
.abilities .left ul,
.abilities .right ul {
  display: block;
  float: left;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  width: 100%;
  list-style: none;
  margin: 0;
  padding: 0;
}
.abilities .left ul li,
.abilities .right ul li {
  display: block;
  float: left;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  width: 100%;
  padding: 5px 0;
  margin: 0;
  border-bottom: 1px solid #888;
}
.container {
  max-width: 1170px;
  padding-left: 20px;
  padding-right: 20px;
}
main {
  display: block;
  float: left;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  width: 100%;
}
main .article-title {
  padding: 0;
  margin: 0;
  width: 100%;
  float: left;
  position: relative;
  z-index: 0;
}
main .article-title span {
  width: 100%;
  float: left;
  font-weight: normal;
  font-family: "Open Sans", Segoe UI, Arial, Verdana, Helvetica;
  border-bottom: 1px solid #0e5c79;
  font-size: 20px *1 .3;
  padding: 0 0 10px;
  margin: 0;
  line-height: 1.4;
  z-index: 2;
  position: relative;
}
main .article-title:after {
  display: block;
  width: 200px;
  height: 200px;
  background: linear-gradient(135deg,#e4f7f2,#bed7dc);
  z-index: 1;
  position: absolute;
  right: 0;
  top: -50px;
  border-radius: 50%;
  transform: translateX(50%);
  opacity: 0.4;
  content: " ";
  z-index: 0;
  right: auto;
  left: 0;
  transform: translate(-50%,20%);
}
@media (prefers-color-scheme: dark) {
  main .article-title:after {
    background: #141414;
    opacity: 1;
  }
}
main ul {
  padding-left: 15px;
  margin: 0 0 13.333333333333px;
}
main ul li {
  list-style: square;
}
#owl-carousel-cms {
  display: block;
  float: left;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  width: 100%;
  margin: 40px 0;
}
@media screen and (min-width: 601px) {
  header nav .menu {
    display: block !important;
  }
}
@media screen and (max-width: 600px) {
  h4 {
    font-size: 20px;
  }
  h2 {
    font-size: 23px;
  }
  .abilities .left,
  .abilities .right {
    width: 100%;
    padding: 0;
    margin-top: 20px;
  }
  .left-info,
  .right-info,
  .right-info .section-title,
  .left-info .section-title,
  .right-info .section-info,
  .left-info .section-info {
    width: 100%;
    text-align: center;
    padding: 0;
    min-height: auto;
  }
  .cv-download {
    padding: 10px 20px;
    font-size: 14px;
  }
  .top-right {
    height: auto;
  }
}
.transition {
  -webkit-transition: 0.3s;
  transition: 0.3s;
}
.transition2x {
  -webkit-transition: 0.6s;
  transition: 0.6s;
}
.transition3x {
  -webkit-transition: 0.9s;
  transition: 0.9s;
}
.sizing {
  display: block;
  float: left;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}
h1,
h2,
h3,
h4,
h5,
h6 {
  color: #000;
  font-weight: 600;
  margin-top: 0;
}
h1 span:first-child,
h2 span:first-child,
h3 span:first-child,
h4 span:first-child,
h5 span:first-child,
h6 span:first-child {
  color: #0e5c79;
}
@media (prefers-color-scheme: dark) {
  h1,
  h2,
  h3,
  h4,
  h5,
  h6 {
    color: #fff;
  }
  h1 span:first-child,
  h2 span:first-child,
  h3 span:first-child,
  h4 span:first-child,
  h5 span:first-child,
  h6 span:first-child {
    color: #87aebc;
  }
}
body {
  background: #f6fafd;
  font-size: 20px;
  line-height: 1.55;
}
@media (prefers-color-scheme: dark) {
  body {
    background: #111;
  }
}
nav {
  display: block;
  width: 100%;
  float: left;
}
header nav .logo {
  display: block;
  float: left;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  margin: 0;
}
header nav .logo img,
header nav .logo svg {
  height: 66px !important;
  width: auto !important;
}
@media screen and (max-width: 1024px) {
  header nav .logo img,
  header nav .logo svg {
    height: 40px !important;
    width: 180px !important;
    height: auto !important;
  }
}
.invisible {
  position: absolute;
  left: -9999px;
}
.jumbotron {
  color: #fff;
  padding: 60px;
  text-align: center;
  background: #0e5c79;
  position: relative;
  width: 100%;
  float: left;
}
.jumbotron p:last-child {
  margin-bottom: 0;
}
.jumbotron h1,
.jumbotron h2,
.jumbotron h3,
.jumbotron h4,
.jumbotron h5,
.jumbotron h6 {
  color: #fff;
}
.jumbotron h1 span,
.jumbotron h2 span,
.jumbotron h3 span,
.jumbotron h4 span,
.jumbotron h5 span,
.jumbotron h6 span {
  color: #fff;
}
@media screen and (max-width: 768px) {
  .jumbotron {
    padding: 30px;
  }
}
@media screen and (max-width: 480px) {
  .jumbotron {
    padding: 40px 20px;
  }
}
.no-margin {
  margin: 0 !important;
}
.competence-list {
  padding-top: 60px;
  float: left;
  width: 100%;
}
.competence-list h3 {
  margin-bottom: 20px;
}
.competence-list .custom {
  display: block;
  float: left;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  width: 100%;
}
.competence-list .custom ul {
  width: 100%;
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
}
.competence-list .custom ul li {
  width: 50%;
}
@media screen and (max-width: 768px) {
  .competence-list .custom ul li {
    width: 100%;
  }
}
.parallax-baner {
  background-size: cover;
  color: #fff;
  margin: 40px 0;
  padding: 100px 10px;
  text-align: center;
  float: left;
  width: 100%;
  box-sizing: border-box;
  position: relative;
  z-index: 222;
}
.parallax-baner .parallax-bg-overflow {
  overflow: hidden;
  position: absolute;
  left: 0;
  top: 0;
  right: 0;
  bottom: 0;
  display: block;
}
.parallax-baner .parallax-bg-overflow .rellax {
  box-sizing: border-box;
  color: #223;
  display: block;
  left: 0;
  line-height: 25vh;
  padding: 0 42pt;
  position: absolute;
  text-align: left;
  top: 0;
  width: 100%;
  height: 200vh;
  background-size: cover;
  background-repeat: no-repeat;
  background: #0e5c79;
}
.parallax-baner .parallax-content {
  position: relative;
  z-index: 2;
}
.parallax-baner.title-baner {
  margin-top: 0;
}
.parallax-baner h1,
.parallax-baner h2,
.parallax-baner h3,
.parallax-baner h4,
.parallax-baner h5,
.parallax-baner h6,
.parallax-baner h1 a,
.parallax-baner h2 a,
.parallax-baner h3 a,
.parallax-baner h4 a,
.parallax-baner h5 a,
.parallax-baner h6 a {
  color: #fff;
}
.parallax-baner h1,
.parallax-baner h2,
.parallax-baner h3,
.parallax-baner h4,
.parallax-baner h5,
.parallax-baner h6 {
  font-size: 6.0rem;
  font-weight: 500;
}
@media screen and (max-width: 768px) {
  .parallax-baner {
    padding: 0;
  }
  .parallax-baner h1,
  .parallax-baner h2,
  .parallax-baner h3,
  .parallax-baner h4,
  .parallax-baner h5,
  .parallax-baner h6 {
    font-size: 2.0rem;
  }
}
.know-me {
  display: block;
  float: left;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  display: flex;
  flex-flow: row wrap;
  background: #2380a2;
  color: #fff;
  padding: 20px;
  margin: -140px 0;
}
.know-me .about-box {
  display: block;
  float: left;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  flex-grow: 1;
  flex-wrap: wrap;
  padding: 20px;
  width: 50%;
  position: relative;
}
.know-me .about-box:before,
.know-me .about-box:after,
.know-me .about-box .bordered:before,
.know-me .about-box .bordered:after {
  border: 1px solid #fff;
  width: 90px;
  height: 60px;
  position: absolute;
  content: " ";
  -webkit-transition: 0.9s;
  transition: 0.9s;
}
.know-me .about-box:before {
  left: 20px;
  top: 20px;
  border-width: 1px 0 0 1px;
}
.know-me .about-box:after {
  right: 20px;
  top: 20px;
  border-width: 1px 1px 0 0;
}
.know-me .about-box .bordered:before {
  right: 20px;
  bottom: 20px;
  border-width: 0 1px 1px 0;
}
.know-me .about-box .bordered:after {
  left: 20px;
  bottom: 20px;
  border-width: 0 0 1px 1px;
}
.know-me .about-box .about-wrapper {
  display: block;
  float: left;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding: 20px;
}
.know-me .about-box h1,
.know-me .about-box h2,
.know-me .about-box h3,
.know-me .about-box h34,
.know-me .about-box h5,
.know-me .about-box h6 {
  font-weight: normal;
  font-size: 3rem;
  margin: 40px 0 0;
}
@media screen and (max-width: 768px) {
  .know-me {
    display: block;
    float: left;
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    display: flex;
    flex-flow: row wrap;
    padding: 0;
    margin: 0;
  }
  .know-me .about-box {
    display: flex;
    padding: 20px;
    width: 50%;
  }
  .know-me .about-box:before,
  .know-me .about-box:after,
  .know-me .about-box .bordered:before,
  .know-me .about-box .bordered:after {
    width: 40px;
    height: 30px;
  }
  .know-me .about-box h1,
  .know-me .about-box h2,
  .know-me .about-box h3,
  .know-me .about-box h34,
  .know-me .about-box h5,
  .know-me .about-box h6 {
    font-weight: normal;
    font-size: 2rem;
    margin: 0;
  }
  .know-me .about-box .about-wrapper {
    padding: 10px;
  }
}
@media screen and (max-width: 460px) {
  .know-me .about-box {
    width: 100%;
  }
}
footer.page-footer {
  display: block;
  float: left;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  width: 100%;
  background: #454545;
  padding: 60px 0 20px;
  color: #fff;
  text-align: center;
}
@media screen and (max-width: 767px) {
  footer.page-footer {
    padding: 30px 0 30px;
  }
}
footer.page-footer h1,
footer.page-footer h2,
footer.page-footer h3,
footer.page-footer h4,
footer.page-footer h5,
footer.page-footer h6 {
  color: #bbb;
}
footer.page-footer h1 span:first-child,
footer.page-footer h2 span:first-child,
footer.page-footer h3 span:first-child,
footer.page-footer h4 span:first-child,
footer.page-footer h5 span:first-child,
footer.page-footer h6 span:first-child {
  color: #fff;
}
@media screen and (max-width: 414px) {
  footer.page-footer h1,
  footer.page-footer h2,
  footer.page-footer h3,
  footer.page-footer h4,
  footer.page-footer h5,
  footer.page-footer h6 {
    font-size: 22px;
    line-height: 1.4;
  }
}
footer.page-footer a:link,
footer.page-footer a:visited,
footer.page-footer a:hover {
  color: #ddd;
}
footer.page-footer .static-logos {
  margin: 20px 0;
}
footer.page-footer .static-logos img {
  margin: 20px;
  height: 40px !important;
  width: auto !important;
}
@media screen and (max-width: 767px) {
  footer.page-footer .static-logos {
    margin: 20px 10px 30px;
  }
  footer.page-footer .static-logos img {
    margin: 10px;
    height: 30px !important;
    width: auto !important;
  }
}
@media (prefers-color-scheme: dark) {
  footer.page-footer {
    background: #000;
  }
}
.tag {
  display: inline-block;
  padding: 2px 15px;
  background: #666;
  color: #fff;
  margin: 0 5px 5px 0;
  border-radius: 50px;
}
h1.article-title {
  color: #2380a2;
  margin-bottom: 10px;
  margin-top: 20px;
}
.portfolio-item {
  margin: 20px 0;
  float: left;
  width: 100%;
}
.portfolio-item .gallery-item {
  width: 33.3333%;
  float: left;
  position: relative;
}
@media screen and (max-width: 1024px) {
  .portfolio-item .gallery-item {
    width: 50%;
  }
}
@media screen and (max-width: 757px) {
  .portfolio-item .gallery-item {
    width: 100%;
  }
}
.portfolio-item .gallery-item .gallery-intro-img {
  position: absolute;
  display: block;
  background-size: cover;
  position: relative;
  padding-bottom: 100%;
  z-index: 1;
}
.portfolio-item .gallery-item .gallery-intro-img img {
  max-width: 100%;
}
.portfolio-item .gallery-item h2 {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  margin: 0;
  top: 0;
  z-index: 2;
}
.portfolio-item .gallery-item h2 a {
  display: block;
  float: left;
  margin: 0;
  width: 100%;
}
.portfolio-item .gallery-item h2 a .text {
  display: block;
  float: left;
  margin: 0;
  width: 100%;
  background: rgba(0,0,0,0.75);
  position: absolute;
  bottom: 0;
  padding: 10px;
  color: #0e5c79;
  font-weight: bold;
  text-decoration: none;
  font-size: 20px;
}
@media screen and (max-width: 1024px) {
  .portfolio-item .gallery-item h2 a .text {
    font-size: 16px;
  }
}
.portfolio-item .gallery-item h2 a .clickarea {
  left: 0;
  right: 0;
  bottom: 0;
  top: 0;
  position: absolute;
  display: block;
  z-index: 3;
}
.gallery-item-layout,
.portfolio-additional-renders {
  display: table;
  width: 100%;
  float: left;
}
.gallery-item-layout > .gallery-img,
.portfolio-additional-renders > .gallery-img {
  width: 40%;
}
.gallery-item-layout > .gallery-img img,
.portfolio-additional-renders > .gallery-img img {
  width: 100%;
  max-width: 100%;
  box-shadow: 0 0 12px rgba(0,0,0,0.2);
}
.gallery-item-layout > .description,
.portfolio-additional-renders > .description {
  padding-left: 60px;
}
.gallery-item-layout > .description h1,
.gallery-item-layout > .description h2,
.gallery-item-layout > .description h3,
.gallery-item-layout > .description h4,
.portfolio-additional-renders > .description h1,
.portfolio-additional-renders > .description h2,
.portfolio-additional-renders > .description h3,
.portfolio-additional-renders > .description h4 {
  display: block;
  float: left;
  width: 100%;
}
.gallery-item-layout > .gallery-img,
.gallery-item-layout > .description,
.portfolio-additional-renders > .gallery-img,
.portfolio-additional-renders > .description {
  display: table-cell;
  vertical-align: top;
  position: relative;
}
@media screen and (max-width: 767px) {
  .gallery-item-layout,
  .portfolio-additional-renders {
    display: block;
  }
  .gallery-item-layout > .gallery-img,
  .gallery-item-layout > .description,
  .portfolio-additional-renders > .gallery-img,
  .portfolio-additional-renders > .description {
    float: left;
    width: 100%;
    padding-left: 0;
    padding-right: 0;
    margin-bottom: 40px;
  }
}
.gallery-item-layout h2,
.portfolio-additional-renders h2 {
  margin-top: 40px;
  margin-bottom: 20px;
  color: #26b271;
  position: relative;
  z-index: 2;
}
.portfolio-tablet-gallery-items {
  display: none;
}
.technologies-used ul {
  list-style: none;
  margin: 10px 0 0;
  padding: 0;
  display: block;
  float: left;
  width: 100%;
}
.technologies-used ul li {
  padding: 0 0 0 50px;
  margin-bottom: 10px;
  position: relative;
  display: block;
  float: left;
  width: 100%;
}
.technologies-used ul li:last-child {
  margin-bottom: 0;
}
.technologies-used ul li:before {
  content: "\f00c";
  font-family: "Font Awesome 5 Free";
  font-style: normal;
  font-weight: bold;
  line-height: 1;
  font-size: 20px;
  color: #0e5c79;
  display: block;
  position: absolute;
  left: 16px;
  top: 2px;
}
@media (prefers-color-scheme: dark) {
  .technologies-used ul li:before {
    color: #87aebc;
  }
}
.portfolio-desktop-gallery-items .gallery-container .gallery-item {
  width: 40%;
}
.mobile-project {
  display: block;
  width: 100%;
  float: left;
  position: relative;
}
.mobile-project:before {
  display: block;
  width: 200px;
  height: 200px;
  background: linear-gradient(135deg,#e4f7f2,#bed7dc);
  z-index: 1;
  position: absolute;
  right: 0;
  top: -50px;
  border-radius: 50%;
  transform: translateX(50%);
  opacity: 0.4;
  content: " ";
  left: 20px;
  right: auto;
  transform: none;
  z-index: 0;
  top: 40px;
  width: 460px;
  height: 460px;
}
@media (prefers-color-scheme: dark) {
  .mobile-project:before {
    background: #141414;
    opacity: 1;
  }
}
.mobile-project .mobile-project-container {
  display: block;
  width: 263px;
  height: 557px;
  position: relative;
  z-index: 2;
  float: left;
  background-image: url('../img/mobile.png');
}
.mobile-project .mobile-project-container .mobile-screen {
  overflow-y: scroll;
  position: absolute;
  top: 20px;
  left: 8px;
  right: 8px;
  bottom: 30px;
  display: block;
  border-radius: 28px;
  scroll-behavior: smooth;
  scrollbar-width: thin;
  scrollbar-color: #444 #000;
}
.mobile-project .mobile-project-container .mobile-screen::-webkit-scrollbar {
  width: 6px;
  background: rgba(0,0,0,0.2);
}
.mobile-project .mobile-project-container .mobile-screen::-webkit-scrollbar-track {
  border-radius: 10px;
}
.mobile-project .mobile-project-container .mobile-screen::-webkit-scrollbar-thumb {
  border-radius: 10px;
  background: #444;
}
.mobile-project .mobile-project-container .mobile-screen img {
  width: 100%;
}
.item-page,
footer {
  position: relative;
}
.hd-keeper {
  width: 100%;
  max-width: 1920px;
  margin: 0 auto;
}
#blueimp-gallery .indicator {
  display: none !important;
}
#blueimp-gallery .slide {
  height: calc(100vh - 40px) !important;
}
.gallery-container {
  display: block;
  margin: 0px -10px;
  width: calc(100% + 20px);
  max-width: unset;
}
.gallery-container .gallery-item {
  display: block;
  float: left;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  width: 25%;
  padding: 10px;
}
@media screen and (max-width: 1024px) {
  .gallery-container .gallery-item {
    width: 33%;
  }
}
@media screen and (max-width: 767px) {
  .gallery-container .gallery-item {
    width: 50%;
  }
}
.gallery-container .gallery-item a {
  display: block;
  float: left;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  width: 100%;
  padding-bottom: 100%;
  position: relative;
  overflow: hidden;
  border: 1px solid #eee;
  background-size: cover;
}
.gallery-container .gallery-item a .image-thumb {
  display: block;
  float: left;
  width: 100%;
  height: 100%;
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%,-50%);
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  -moz-transition: 0.3s;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}
.gallery-container .gallery-item a img {
  max-width: 100%;
  opacity: 0;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: 0;
  width: 100%;
}
.gallery-container .gallery-item a:hover .image-thumb {
  transform: translate(-50%,-50%) scale(1.2) rotate(5deg);
  opacity: 0.7;
}
body .portfolio * {
  max-width: 100%;
}
section.portfolio {
  display: block;
  float: left;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  display: inline;
  margin: 0 -20px;
  width: auto;
  min-width: 100%;
}
section.portfolio > article {
  display: block;
  float: left;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  width: 33.3333%;
  padding: 20px 20px 30px;
  position: relative;
}
section.portfolio > article:before {
  display: block;
  width: 200px;
  height: 200px;
  background: linear-gradient(135deg,#e4f7f2,#bed7dc);
  z-index: 1;
  position: absolute;
  right: 0;
  top: -50px;
  border-radius: 50%;
  transform: translateX(50%);
  opacity: 0.4;
}
@media (prefers-color-scheme: dark) {
  section.portfolio > article:before {
    background: #141414;
    opacity: 1;
  }
}
section.portfolio > article:nth-child(5n + 5):before {
  content: " ";
}
section.portfolio > article .item {
  display: block;
  float: left;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  position: relative;
  width: 100%;
  z-index: 2;
}
section.portfolio > article .hover-overlay {
  display: block;
  float: left;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  opacity: 0.0;
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  right: 0;
  text-decoration: none;
  text-align: center;
  z-index: 10;
  background: rgba(255,255,255,0.2);
  transition: 0.2s;
  -webkit-transition: 0.2s;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}
section.portfolio > article .hover-overlay .btn {
  display: inline-block;
  padding: 10px 20px;
  border: 2px solid #0e5c79;
  color: #0e5c79;
}
section.portfolio > article .img {
  display: block;
  float: left;
  margin: 0;
  width: 100%;
  position: relative;
  transition: 0.2s;
}
section.portfolio > article .img img {
  float: left;
  transition: 0.2s;
  border-radius: 10px;
  overflow: hidden;
  position: relative;
  z-index: 2;
  transform-origin: bottom;
}
section.portfolio > article .img .led-shadow {
  display: block;
  position: absolute;
  z-index: 1;
  left: 0;
  right: 0;
  bottom: 0;
  top: 0;
  background-size: 120%;
  filter: contrast(10) blur(32px) contrast(1);
  opacity: 0.5;
}
@media (prefers-color-scheme: dark) {
  section.portfolio > article .img .led-shadow {
    opacity: 0.25;
  }
}
section.portfolio > article:hover .img {
  filter: grayscale(1.0);
}
section.portfolio > article:hover .img img {
  transform: scale(1.05);
}
section.portfolio > article:hover .hover-overlay {
  display: block;
}
section.portfolio > article h2 {
  font-size: 16px;
  line-height: normal;
  display: block;
  float: left;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  width: 100%;
  position: static;
  opacity: 1;
  top: -20px;
  z-index: 12;
  transition: 0.2s;
  -webkit-transition: 0.2s;
  -webkit-transition: 0.3s;
  transition: 0.3s;
  text-align: center;
}
section.portfolio > article h2 a {
  font-size: 16px;
  color: #9a9a9a;
  text-decoration: none;
  padding: 10px;
  font-weight: normal;
  display: block;
  float: left;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  width: 100%;
}
section.portfolio > article .readmore {
  margin: 0;
  padding: 5px;
  display: block;
  float: left;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  position: absolute;
  right: 0;
  bottom: -20px;
  background: #fff;
  opacity: 0;
  z-index: 13;
  transition: 0.2s;
  -webkit-transition: 0.2s;
  -webkit-transition: 0.3s;
  transition: 0.3s;
  display: none;
}
section.portfolio > article .readmore a {
  display: inline-block;
  text-decoration: none;
  padding: 0;
  margin-bottom: 0;
  transition: 0.2s;
  -webkit-transition: 0.2s;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}
@media screen and (max-width: 980px) {
  section.portfolio > article {
    width: 50%;
  }
}
@media screen and (max-width: 600px) {
  section.portfolio > article {
    width: 100%;
  }
  section.portfolio > article img {
    width: 100%;
  }
}
.www-items .gallery-container a .image-thumb {
  background-position: top center;
}
.portfolio-additional-renders {
  display: block;
}
.portfolio-additional-renders h2 {
  text-align: center;
}
.portfolio-additional-renders .gallery-container {
  text-align: center;
}
.portfolio-additional-renders .gallery-container .gallery-item {
  float: none;
  display: inline-block;
}
.home-section-www .home-text,
.home-section-3d .home-text {
  width: 400px;
  max-width: 100%;
  text-align: center;
}
.home-section-www .home-text h3,
.home-section-3d .home-text h3 {
  color: #0e5c79;
  margin-bottom: 20px;
  font-size: 40px;
  font-weight: 300;
}
@media (prefers-color-scheme: dark) {
  .home-section-www .home-text h3,
  .home-section-3d .home-text h3 {
    color: #cccccc;
  }
}
.home-section-www .home-text .custom,
.home-section-3d .home-text .custom {
  color: #000;
}
@media (prefers-color-scheme: dark) {
  .home-section-www .home-text .custom,
  .home-section-3d .home-text .custom {
    color: #fff;
  }
}
@media screen and (max-width: 414px) {
  .home-section-www .home-text h3,
  .home-section-3d .home-text h3 {
    font-size: 30px;
    margin-bottom: 20px;
    text-align: left;
  }
  .home-section-www .home-text .custom,
  .home-section-3d .home-text .custom {
    hyphens: auto;
    text-align: left;
    text-align: justify;
  }
}
.home-section-www .animated-text,
.home-section-3d .animated-text {
  position: relative;
  z-index: 2;
  font-size: 160px;
  font-weight: bold;
  color: #f6fafd;
  text-shadow: -2px -2px 0 #bbb, -2px 0px 0 #bbb, -2px 2px 0 #bbb, 0 -2px 0 #bbb, 0 -1px 0 #bbb, 0 0 0 #bbb, 0 1px 0 #bbb, 0 2px 0 #bbb, 2px -2px 0 #bbb, 2px 0 0 #bbb, 2px 2px 0 #bbb, -1px -1px 0 #bbb, -1px 0 0 #bbb, -1px 1px 0 #bbb, 1px -1px 0 #bbb, 1px 1px 0 #bbb;
}
@media (prefers-color-scheme: dark) {
  .home-section-www .animated-text,
  .home-section-3d .animated-text {
    text-shadow: -2px -2px 0 #666, -2px 0px 0 #666, -2px 2px 0 #666, 0 -2px 0 #666, 0 -1px 0 #666, 0 0 0 #666, 0 1px 0 #666, 0 2px 0 #666, 2px -2px 0 #666, 2px 0 0 #666, 2px 2px 0 #666, -1px -1px 0 #666, -1px 0 0 #666, -1px 1px 0 #666, 1px -1px 0 #666, 1px 1px 0 #666;
    color: #111;
  }
}
@media screen and (max-width: 1200px) {
  .home-section-www .animated-text,
  .home-section-3d .animated-text {
    font-size: 120px;
  }
}
@media screen and (max-width: 1024px) {
  .home-section-www .animated-text,
  .home-section-3d .animated-text {
    font-size: 100px;
  }
}
@media screen and (max-width: 768px) {
  .home-section-www .animated-text,
  .home-section-3d .animated-text {
    font-size: 70px;
  }
}
@media screen and (max-width: 414px) {
  .home-section-www .animated-text,
  .home-section-3d .animated-text {
    font-size: 60px;
  }
}
.home-section-www {
  display: block;
  float: left;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  width: 100%;
  position: relative;
  display: flex;
  flex-wrap: wrap;
  margin-top: 40px;
  padding-left: 20px;
  padding-right: 20px;
}
.home-section-www .left-side {
  display: block;
  float: left;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  width: 50%;
  position: relative;
}
.home-section-www .left-side .section-text-composer {
  width: 700px;
  max-width: 100%;
  height: 100%;
  position: relative;
  float: right;
}
.home-section-www .left-side .section-text-composer .circle {
  left: 50%;
  right: auto;
  top: 0;
  transform: translateX(-50%);
}
.home-section-www .left-side .section-text-composer .home-text {
  margin: 0 auto;
  top: 50%;
  position: absolute;
  transform: translate(-50%);
  float: none;
  left: 50%;
}
.home-section-www .right-side {
  display: block;
  float: left;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  width: 50%;
}
.home-section-www .right-side img {
  width: 600px;
  max-width: 100%;
  box-shadow: 0 0 64px rgba(255,122,0,0.2);
}
.home-section-www .animated-lines-svg {
  position: absolute;
  left: 0;
  bottom: -80%;
}
.home-section-www .project-wrapper {
  float: left;
  position: relative;
  display: flex;
}
.home-section-www .project-wrapper .project {
  float: left;
  width: 100%;
  z-index: 3;
  position: relative;
}
@media screen and (max-width: 768px) {
  .home-section-www .left-side,
  .home-section-www .right-side {
    width: 100%;
  }
  .home-section-www .left-side .section-text-composer .home-text {
    position: static;
    transform: none;
  }
  .home-section-www .left-side .circle {
    display: none;
  }
  .home-section-www .animated-text {
    position: static;
  }
}
@media screen and (max-width: 414px) {
  .home-section-www .left-side,
  .home-section-www .right-side {
    width: 100%;
  }
  .home-section-www .left-side .section-text-composer .home-text {
    position: static;
    transform: none;
  }
  .home-section-www .left-side .circle {
    display: none;
  }
  .home-section-www .animated-text {
    position: relative;
    text-align: center;
  }
}
.home-section-3d {
  display: block;
  float: left;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  width: 100%;
  padding-top: 60px;
}
.home-section-3d .animated-text {
  position: relative;
  transform: translateX(15%);
}
.home-section-3d .left-side,
.home-section-3d .right-side {
  width: 50%;
  float: left;
}
.home-section-3d .left-side .home-text {
  text-align: left;
}
.home-section-3d .right-side .custom {
  float: right;
  width: auto !important;
}
.home-section-3d .right-side .custom ul li {
  color: #000;
  width: auto;
  clear: both;
}
@media (prefers-color-scheme: dark) {
  .home-section-3d .right-side .custom ul li {
    color: #fff;
  }
}
@media screen and (max-width: 1200px) {
  .home-section-3d .animated-text {
    transform: none;
    text-align: center;
  }
}
@media screen and (max-width: 768px) {
  .home-section-3d {
    padding-top: 30px;
  }
  .home-section-3d .left-side,
  .home-section-3d .right-side {
    width: 100%;
    float: left;
  }
  .home-section-3d .left-side .custom,
  .home-section-3d .right-side .custom {
    float: left;
  }
}
.home-section-3d .grid3d {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  grid-gap: 12px;
  grid-auto-rows: minmax(100px,auto);
  margin: 40px 0;
}
.home-section-3d .grid3d .grid-thumb {
  position: relative;
}
.home-section-3d .grid3d .grid-thumb .shadow {
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
  display: block;
  position: absolute;
  z-index: 1;
  opacity: 0.25;
  filter: blur(32px);
}
.home-section-3d .grid3d .grid-thumb img {
  max-width: 100%;
  float: left;
  position: relative;
  z-index: 2;
  transition: 0.3s;
  border-radius: 10px;
  border: 1px solid #bbb;
}
@media (prefers-color-scheme: dark) {
  .home-section-3d .grid3d .grid-thumb img {
    border-color: #444;
  }
}
.home-section-3d .grid3d .grid-thumb img:hover {
  filter: saturate(0);
}
.home-section-3d .grid3d .grid-thumb.thumb1 {
  grid-column: 3;
  grid-row: 1;
  align-self: end;
}
.home-section-3d .grid3d .grid-thumb.thumb2 {
  grid-column: 4;
  grid-row: 1;
  align-self: end;
}
.home-section-3d .grid3d .grid-thumb.thumb3 {
  grid-column: 3;
  grid-row: 2;
  align-self: start;
}
.home-section-3d .grid3d .grid-thumb.thumb4 {
  grid-column: 2;
  grid-row: 2;
  align-self: start;
}
.home-section-3d .grid3d .left-side {
  grid-column: 1 / 3;
  grid-row: 1;
  width: 100%;
  padding-bottom: 40px;
  padding-right: 40px;
}
.home-section-3d .grid3d .right-side {
  grid-column: 4 / 6;
  grid-row: 2;
  width: 100%;
  padding: 0px 0 0 12px;
}
.home-section-3d .grid3d .right-side .custom {
  float: left;
  width: 100% !important;
}
@media screen and (min-width: 1024px) and (max-width: 1200px) {
  .home-section-3d .grid3d .left-side .home-text h3 {
    font-size: 36px;
  }
}
@media screen and (min-width: 768px) and (max-width: 1023px) {
  .home-section-3d .grid3d {
    grid-template-columns: repeat(6, 1fr);
  }
  .home-section-3d .grid3d .left-side {
    grid-column: 1 / 4;
    grid-row: 1;
  }
  .home-section-3d .grid3d .left-side .home-text h3 {
    font-size: 36px;
  }
  .home-section-3d .grid3d .right-side {
    grid-column: 4 / 7;
    grid-row: 1;
    padding-top: 0;
    padding-bottom: 40px;
  }
  .home-section-3d .grid3d .right-side ul li {
    font-size: 17px;
  }
  .home-section-3d .grid3d .grid-thumb.thumb1 {
    grid-column: 2;
    grid-row: 2;
    align-self: start;
  }
  .home-section-3d .grid3d .grid-thumb.thumb2 {
    grid-column: 3;
    grid-row: 2;
    align-self: start;
  }
  .home-section-3d .grid3d .grid-thumb.thumb3 {
    grid-column: 4;
    grid-row: 2;
    align-self: start;
  }
  .home-section-3d .grid3d .grid-thumb.thumb4 {
    grid-column: 5;
    grid-row: 2;
    align-self: start;
  }
}
@media screen and (min-width: 415px) and (max-width: 767px) {
  .home-section-3d .grid3d {
    grid-template-columns: repeat(4, 1fr);
  }
  .home-section-3d .grid3d .left-side {
    grid-column: 1 / 5;
    grid-row: 1;
    padding: 0;
  }
  .home-section-3d .grid3d .left-side .home-text {
    width: 100%;
  }
  .home-section-3d .grid3d .left-side .home-text h3 {
    font-size: 36px;
  }
  .home-section-3d .grid3d .right-side {
    grid-column: 1 / 5;
    grid-row: 2;
    padding: 0 0 40px;
  }
  .home-section-3d .grid3d .grid-thumb.thumb1 {
    grid-column: 1;
    grid-row: 3;
    align-self: start;
  }
  .home-section-3d .grid3d .grid-thumb.thumb2 {
    grid-column: 2;
    grid-row: 3;
    align-self: start;
  }
  .home-section-3d .grid3d .grid-thumb.thumb3 {
    grid-column: 3;
    grid-row: 3;
    align-self: start;
  }
  .home-section-3d .grid3d .grid-thumb.thumb4 {
    grid-column: 4;
    grid-row: 3;
    align-self: start;
  }
}
@media screen and (max-width: 414px) {
  .home-section-3d .grid3d {
    grid-template-columns: repeat(2, 1fr);
  }
  .home-section-3d .grid3d .left-side {
    grid-column: 1 / 3;
    grid-row: 1;
    padding: 0;
  }
  .home-section-3d .grid3d .left-side .home-text {
    width: 100%;
  }
  .home-section-3d .grid3d .left-side .home-text h3 {
    font-size: 36px;
  }
  .home-section-3d .grid3d .right-side {
    grid-column: 1 / 3;
    grid-row: 2;
    padding: 0 0 40px;
  }
  .home-section-3d .grid3d .grid-thumb.thumb1 {
    grid-column: 1;
    grid-row: 3;
    align-self: start;
  }
  .home-section-3d .grid3d .grid-thumb.thumb2 {
    grid-column: 2;
    grid-row: 3;
    align-self: start;
  }
  .home-section-3d .grid3d .grid-thumb.thumb3 {
    grid-column: 1;
    grid-row: 4;
    align-self: start;
  }
  .home-section-3d .grid3d .grid-thumb.thumb4 {
    grid-column: 2;
    grid-row: 4;
    align-self: start;
  }
}
.about-me-info {
  display: block;
  float: left;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  display: table;
  width: 100%;
  table-layout: fixed;
  margin-bottom: 80px;
}
.about-me-info .left-side,
.about-me-info .right-side {
  display: block;
  float: left;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  float: none;
  display: table-cell;
  vertical-align: top;
  padding: 40px 0;
}
.about-me-info .left-side h1,
.about-me-info .left-side h2,
.about-me-info .left-side h3,
.about-me-info .right-side h1,
.about-me-info .right-side h2,
.about-me-info .right-side h3 {
  margin-bottom: 20px;
}
.about-me-info .left-side {
  max-width: 100%;
  width: 360px;
}
.about-me-info .left-side img {
  max-width: 100%;
  position: relative;
  z-index: 2;
}
.about-me-info .right-side {
  padding-left: 120px;
  position: relative;
  color: #222;
}
@media (prefers-color-scheme: dark) {
  .about-me-info .right-side {
    color: #fff;
  }
}
.about-me-info .right-side h1 {
  font-size: 40px;
}
.about-me-info .right-side .btn {
  font-size: 20px;
  margin-top: 20px;
}
.about-me-info .right-side * {
  z-index: 2;
  position: relative;
}
.about-me-info .right-side:before {
  z-index: 1;
  display: block;
  width: 200px;
  height: 200px;
  background: linear-gradient(135deg,#e4f7f2,#bed7dc);
  position: absolute;
  right: 0;
  top: -50px;
  border-radius: 50%;
  transform: translateX(50%);
  opacity: 0.4;
  content: " ";
  left: 20px;
  right: auto;
  transform: none;
  z-index: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 460px;
  height: 460px;
}
@media (prefers-color-scheme: dark) {
  .about-me-info .right-side:before {
    background: #141414;
    opacity: 1;
  }
}
@media screen and (max-width: 768px) {
  .about-me-info {
    display: block;
  }
  .about-me-info .left-side,
  .about-me-info .right-side {
    display: block;
    float: left;
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    text-align: center;
  }
  .about-me-info .left-side {
    max-width: 100%;
    width: 60%;
    padding-bottom: 50%;
    overflow: hidden;
    position: relative;
    margin: 20px 20%;
  }
  .about-me-info .left-side img {
    max-width: 100%;
    position: absolute;
    z-index: 2;
    left: 0;
    top: 0;
  }
  .about-me-info .right-side {
    padding-left: 0;
    padding-top: 0;
  }
  .about-me-info .right-side h1 {
    font-size: 30px;
  }
}
.skillbar-section {
  display: block;
  float: left;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  width: 100%;
  padding: 60px 0;
}
.skillbar-section h3 {
  margin-bottom: 20px;
}
.skillbar-section .left {
  display: block;
  float: left;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  width: 50%;
  padding-right: 20px;
  margin: 0;
}
.skillbar-section .right {
  display: block;
  float: left;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  width: 50%;
  padding-left: 20px;
  margin: 0;
}
.skillbar-section + small {
  margin-bottom: 20px;
}
.skillbar-section .skillbar {
  display: block;
  float: left;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  width: 100%;
  margin-bottom: 20px;
  position: relative;
}
.skillbar-section .skillbar .progress {
  display: block;
  float: left;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  position: static;
  left: 0;
  top: 0;
  bottom: 0;
  background: #0e5c79;
  color: #fff;
  padding: 20px 20px;
  width: 70%;
  margin-bottom: 0;
}
.skillbar-section .skillbar .progress-name {
  display: block;
  float: left;
  position: static;
  width: 100%;
  padding-bottom: 5px;
}
.skillbar-section .skillbar .percent {
  position: absolute;
  left: 10px;
  margin-top: 37px;
  color: #fff;
}
@media screen and (max-width: 600px) {
  .skillbar-section {
    display: block;
    float: left;
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    width: 100%;
  }
  .skillbar-section .left,
  .skillbar-section .right {
    display: block;
    float: left;
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    width: 100%;
    padding: 0;
  }
}
@-webkit-keyframes migotanie2 {
  0% {
    border-top-color: #fff;
    color: #fff;
  }
  50% {
    border-top-color: rgba(255,255,255,0);
    color: rgba(255,255,255,0);
  }
  100% {
    border-top-color: #fff;
    color: #fff;
  }
}
@keyframes migotanie2 {
  0% {
    border-top-color: #fff;
    color: #fff;
  }
  50% {
    border-top-color: rgba(255,255,255,0);
    color: rgba(255,255,255,0);
  }
  100% {
    border-top-color: #fff;
    color: #fff;
  }
}
.infographic-group {
  position: relative;
  float: left;
  width: 100%;
  display: block;
  overflow: hidden;
  background: #f6fafd;
}
@media (prefers-color-scheme: dark) {
  .infographic-group {
    background: #111;
  }
}
.infographic-group .blank-screen {
  float: left;
  width: 100vw;
  height: 100vh;
}
.infographic-group .infographic-screen {
  position: relative;
  left: 0;
  top: 0;
  right: 0;
  bottom: 0;
  width: 100%;
  height: 100vh;
  transition: width 0s, height 0s, opacity .4s;
  z-index: 2;
  opacity: 0;
  box-sizing: border-box;
  overflow: hidden;
}
.infographic-group .infographic-screen .desc {
  position: relative;
  box-sizing: border-box;
  top: 15%;
  transition: .3s;
  width: 100%;
  max-width: 100%;
  transform: translateX(-25%);
  padding-left: 50%;
}
.infographic-group .infographic-screen .desc .responsibilities {
  display: block;
  float: left;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  position: relative;
  padding: 60px;
}
.infographic-group .infographic-screen .desc .responsibilities:before,
.infographic-group .infographic-screen .desc .responsibilities:after,
.infographic-group .infographic-screen .desc .responsibilities .bordered:before,
.infographic-group .infographic-screen .desc .responsibilities .bordered:after {
  border: 2px solid #0e5c79;
  width: 90px;
  height: 60px;
  max-height: 1px;
  max-width: 1px;
  opacity: 0;
  position: absolute;
  content: " ";
  -webkit-transition: 0.9s;
  transition: 0.9s;
}
.infographic-group .infographic-screen .desc .responsibilities:before {
  left: 0;
  top: 0;
  border-width: 2px 0 0 2px;
}
.infographic-group .infographic-screen .desc .responsibilities:after {
  right: 0;
  top: 0;
  border-width: 2px 2px 0 0;
}
.infographic-group .infographic-screen .desc .responsibilities .bordered:before {
  right: 0;
  bottom: 0;
  border-width: 0 2px 2px 0;
}
.infographic-group .infographic-screen .desc .responsibilities .bordered:after {
  left: 0;
  bottom: 0;
  border-width: 0 0 2px 2px;
}
.infographic-group .infographic-screen .desc .responsibilities .resp-wrapper {
  opacity: 0.0;
  transform: scale(0.5);
  -webkit-transition: 0.6s;
  transition: 0.6s;
}
.infographic-group .infographic-screen .desc .responsibilities .resp-wrapper p:last-child {
  margin-bottom: 0;
}
.infographic-group .infographic-screen h1,
.infographic-group .infographic-screen h2,
.infographic-group .infographic-screen h3 {
  color: #000;
  font-weight: 400;
  font-size: 4.0rem;
  margin-top: 0;
  -webkit-transition: 0.6s;
  transition: 0.6s;
  -webkit-transition-delay: 0.3s;
  transition-delay: 0.3s;
}
@media (prefers-color-scheme: dark) {
  .infographic-group .infographic-screen h1,
  .infographic-group .infographic-screen h2,
  .infographic-group .infographic-screen h3 {
    color: #fff;
  }
}
.infographic-group .infographic-screen h1 span,
.infographic-group .infographic-screen h2 span,
.infographic-group .infographic-screen h3 span {
  color: #0e5c79;
  -webkit-transition: 0.6s;
  transition: 0.6s;
}
@media (prefers-color-scheme: dark) {
  .infographic-group .infographic-screen h1 span,
  .infographic-group .infographic-screen h2 span,
  .infographic-group .infographic-screen h3 span {
    color: #87aebc;
  }
}
@media screen and (min-width: 1200px) {
  .infographic-group .infographic-screen h1,
  .infographic-group .infographic-screen h2,
  .infographic-group .infographic-screen h3 {
    margin-left: -20px;
  }
  .infographic-group .infographic-screen h1 span,
  .infographic-group .infographic-screen h2 span,
  .infographic-group .infographic-screen h3 span {
    margin-right: 60px;
  }
}
.infographic-group .infographic-screen .work-date {
  font-size: 18px;
  margin-top: 6px;
}
.infographic-group .infographic-screen p {
  color: #676767;
  line-height: 1.5;
  margin-bottom: 40px;
}
@media (prefers-color-scheme: dark) {
  .infographic-group .infographic-screen p {
    color: #fff;
  }
}
.infographic-group .infographic-screen.active {
  z-index: 3;
  opacity: 1;
}
.infographic-group .infographic-screen.active h1,
.infographic-group .infographic-screen.active h2,
.infographic-group .infographic-screen.active h3 {
  margin-left: 0;
  -webkit-transition-delay: 0s;
  transition-delay: 0;
}
.infographic-group .infographic-screen.active h1 span,
.infographic-group .infographic-screen.active h2 span,
.infographic-group .infographic-screen.active h3 span {
  margin-right: 0px;
}
.infographic-group .infographic-bg-static {
  z-index: 1;
  left: 0;
  top: 0;
  right: 0;
  bottom: 0;
  width: 100%;
  height: 100vh;
  position: absolute;
  overflow: hidden;
}
.infographic-group .infographic-bg-static:before {
  content: " ";
  left: -200px;
  bottom: -25%;
  right: -200px;
  top: 140%;
  background: #0e5c79;
  display: block;
  position: absolute;
  -webkit-transform: rotate(-8deg);
  transform: rotate(-8deg);
  transition: 0.2s;
  -webkit-transition: 0.2s;
  -webkit-transition: 0.3s;
  transition: 0.3s;
  opacity: 0;
}
.infographic-group .infographic-bg-static:after {
  content: " ";
  top: -200px;
  right: -15%;
  bottom: -200px;
  left: 140%;
  background: #26b271;
  display: block;
  position: absolute;
  -webkit-transform: rotate(-10deg);
  transform: rotate(-10deg);
  transition: 0.2s;
  -webkit-transition: 0.2s;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}
.infographic-group .screen-content {
  height: 100vh;
  float: left;
  width: 100%;
  left: 0;
  top: 0;
}
.infographic-group.fixed .infographic-screen .screen-content {
  position: fixed;
}
.infographic-group.fixed .infographic-bg-static {
  position: fixed;
}
.infographic-group.bottom .infographic-bg-static {
  bottom: 0;
  top: auto;
}
.infographic-group.entered .infographic-bg-static:before {
  top: 87%;
  opacity: 1;
}
.infographic-group.entered .infographic-bg-static:after {
  left: 87%;
  opacity: 1;
}
.infographic-group .timeline {
  display: block;
  float: left;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  left: 10%;
  top: 0;
  height: 100vh;
  position: absolute;
  z-index: 10000;
}
.infographic-group .timeline .axis {
  position: absolute;
  top: 70px;
  bottom: 70px;
}
@media screen and (max-height: 767px) {
  .infographic-group .timeline .axis {
    display: none !important;
  }
}
.infographic-group .timeline .axis .endaxis,
.infographic-group .timeline .axis .startaxis {
  position: absolute;
  padding: 20px;
  transform: translateX(-50%);
  color: #2380a2;
  font-weight: bold;
}
.infographic-group .timeline .axis .startaxis {
  bottom: 0;
}
.infographic-group .timeline .axis .endaxis {
  top: 0;
}
.infographic-group .timeline .axis .values {
  display: block;
  float: left;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  position: absolute;
  display: flex;
  flex-flow: row wrap;
  left: 0;
  top: 60px;
  bottom: 60px;
  width: 70px;
}
.infographic-group .timeline .axis .values:before {
  background: #2380a2;
  left: -1px;
  top: 0;
  bottom: 0;
  width: 2px;
  display: block;
  content: " ";
  position: absolute;
}
.infographic-group .timeline .axis .values .number {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
}
.infographic-group .timeline .axis .values .number.years-x10 {
  -webkit-flex-grow: 10;
  flex-grow: 10;
}
.infographic-group .timeline .axis .values .number.years-x9 {
  -webkit-flex-grow: 9;
  flex-grow: 9;
}
.infographic-group .timeline .axis .values .number.years-x8 {
  -webkit-flex-grow: 8;
  flex-grow: 8;
}
.infographic-group .timeline .axis .values .number.years-x7 {
  -webkit-flex-grow: 7;
  flex-grow: 7;
}
.infographic-group .timeline .axis .values .number.years-x6 {
  -webkit-flex-grow: 6;
  flex-grow: 6;
}
.infographic-group .timeline .axis .values .number.years-x5 {
  -webkit-flex-grow: 5;
  flex-grow: 5;
}
.infographic-group .timeline .axis .values .number.years-x4 {
  -webkit-flex-grow: 4;
  flex-grow: 4;
}
.infographic-group .timeline .axis .values .number.years-x3 {
  -webkit-flex-grow: 3;
  flex-grow: 3;
}
.infographic-group .timeline .axis .values .number.years-x2 {
  -webkit-flex-grow: 2;
  flex-grow: 2;
}
.infographic-group .timeline .axis .values .number.years-x1 {
  -webkit-flex-grow: 1;
  flex-grow: 1;
}
.infographic-group .timeline .axis .values .number .number-wrap {
  display: block;
  float: left;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  border: 2px solid #2380a2;
  width: 70px;
  height: 70px;
  border-radius: 50%;
  text-align: center;
  margin: 10px 0;
  background: #2380a2;
  font-weight: bold;
  color: #2380a2;
  transition: 0.2s;
  -webkit-transition: 0.2s;
  -webkit-transition: 0.3s;
  transition: 0.3s;
  -webkit-transform: scale(0.2) translateX(-50%);
  transform: scale(0.2) translateX(-50%);
  -webkit-transform-origin: 0 50% 0;
  transform-origin: 0 50% 0;
  position: relative;
}
.infographic-group .timeline .axis .values .number .number-wrap span {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%,-50%);
  line-height: 1;
}
.infographic-group .timeline .axis .values .number.active .number-wrap {
  background: #f6fafd;
  -webkit-transform: scale(1) translateX(-50%);
  transform: scale(1) translateX(-50%);
}
@media (prefers-color-scheme: dark) {
  .infographic-group .timeline .axis .values .number.active .number-wrap {
    background: #111;
  }
}
.infographic-group.fixed .infographic-screen .desc .responsibilities:before,
.infographic-group.fixed .infographic-screen .desc .responsibilities:after,
.infographic-group.fixed .infographic-screen .desc .responsibilities .bordered:before,
.infographic-group.fixed .infographic-screen .desc .responsibilities .bordered:after,
.infographic-group.fixed .infographic-screen.active .desc .responsibilities:before,
.infographic-group.fixed .infographic-screen.active .desc .responsibilities:after,
.infographic-group.fixed .infographic-screen.active .desc .responsibilities .bordered:before,
.infographic-group.fixed .infographic-screen.active .desc .responsibilities .bordered:after,
.infographic-group.entered .infographic-screen .desc .responsibilities:before,
.infographic-group.entered .infographic-screen .desc .responsibilities:after,
.infographic-group.entered .infographic-screen .desc .responsibilities .bordered:before,
.infographic-group.entered .infographic-screen .desc .responsibilities .bordered:after,
.infographic-group.entered .infographic-screen.active .desc .responsibilities:before,
.infographic-group.entered .infographic-screen.active .desc .responsibilities:after,
.infographic-group.entered .infographic-screen.active .desc .responsibilities .bordered:before,
.infographic-group.entered .infographic-screen.active .desc .responsibilities .bordered:after,
.infographic-group.top.entered .infographic-screen .desc .responsibilities:before,
.infographic-group.top.entered .infographic-screen .desc .responsibilities:after,
.infographic-group.top.entered .infographic-screen .desc .responsibilities .bordered:before,
.infographic-group.top.entered .infographic-screen .desc .responsibilities .bordered:after,
.infographic-group.top.entered .infographic-screen.active .desc .responsibilities:before,
.infographic-group.top.entered .infographic-screen.active .desc .responsibilities:after,
.infographic-group.top.entered .infographic-screen.active .desc .responsibilities .bordered:before,
.infographic-group.top.entered .infographic-screen.active .desc .responsibilities .bordered:after {
  max-height: 120px;
  max-width: 120px;
  opacity: 1;
}
.infographic-group.fixed .infographic-screen .desc .responsibilities .resp-wrapper,
.infographic-group.fixed .infographic-screen.active .desc .responsibilities .resp-wrapper,
.infographic-group.entered .infographic-screen .desc .responsibilities .resp-wrapper,
.infographic-group.entered .infographic-screen.active .desc .responsibilities .resp-wrapper,
.infographic-group.top.entered .infographic-screen .desc .responsibilities .resp-wrapper,
.infographic-group.top.entered .infographic-screen.active .desc .responsibilities .resp-wrapper {
  opacity: 1.0;
  transform: scale(1.0);
}
.infographic-group.fixed > .timeline {
  position: fixed;
}
.infographic-group.top > .timeline,
.infographic-group.bottom > .timeline {
  position: absolute;
}
.infographic-group.top > .timeline {
  top: 0;
  bottom: auto;
}
.infographic-group.bottom > .timeline {
  top: auto;
  bottom: 0;
}
@media screen and (max-width: 1200px) {
  .infographic-group .infographic-screen {
    transition: width 0s, height 0s, opacity .4s;
    z-index: 2;
    opacity: 0;
  }
  .infographic-group .infographic-screen .desc {
    top: 20%;
    max-width: 80%;
    transition: .3s;
    transform: translateX(0);
    padding-left: 20%;
  }
  .infographic-group .infographic-screen .desc .responsibilities {
    padding: 20px;
  }
  .infographic-group .infographic-screen .desc .responsibilities .resp-wrapper {
    opacity: 0.0;
    transform: scale(0.5);
    -webkit-transition: 0.6s;
    transition: 0.6s;
  }
  .infographic-group .infographic-screen h1,
  .infographic-group .infographic-screen h2,
  .infographic-group .infographic-screen h3 {
    font-size: 3.2rem;
    margin-top: 0;
  }
  .infographic-group .infographic-screen h1 span,
  .infographic-group .infographic-screen h2 span,
  .infographic-group .infographic-screen h3 span {
    color: #0e5c79;
    -webkit-transition: 0.6s;
    transition: 0.6s;
  }
  .infographic-group .infographic-screen p {
    margin-bottom: 20px;
  }
  .infographic-group .infographic-screen.active {
    z-index: 3;
    opacity: 1;
  }
  .infographic-group .infographic-screen.active h1,
  .infographic-group .infographic-screen.active h2,
  .infographic-group .infographic-screen.active h3 {
    margin-left: 0;
    -webkit-transition-delay: 0s;
    transition-delay: 0;
  }
  .infographic-group .infographic-screen.active h1 span,
  .infographic-group .infographic-screen.active h2 span,
  .infographic-group .infographic-screen.active h3 span {
    margin-right: 0px;
  }
  .infographic-group.bottom .infographic-bg-static {
    bottom: 0;
    top: auto;
  }
}
@media screen and (max-width: 1200px) and (prefers-color-scheme: dark) {
  .infographic-group .infographic-screen h1 span,
  .infographic-group .infographic-screen h2 span,
  .infographic-group .infographic-screen h3 span {
    color: #87aebc;
  }
}
@media screen and (max-width: 1024px) {
  .infographic-group .infographic-screen {
    transition: width 0s, height 0s, opacity .4s;
    padding: 20px;
    z-index: 2;
    opacity: 0;
  }
  .infographic-group .infographic-screen .desc {
    top: 20%;
    max-width: 80%;
    transition: .3s;
    transform: translateX(0);
    padding-left: 20%;
  }
  .infographic-group .infographic-screen .desc .responsibilities {
    padding: 20px;
  }
  .infographic-group .infographic-screen .desc .responsibilities .resp-wrapper {
    opacity: 0.0;
    transform: scale(0.5);
    -webkit-transition: 0.6s;
    transition: 0.6s;
  }
  .infographic-group .infographic-screen h1,
  .infographic-group .infographic-screen h2,
  .infographic-group .infographic-screen h3 {
    font-size: 3rem;
    margin-top: 0;
  }
  .infographic-group .infographic-screen h1 span,
  .infographic-group .infographic-screen h2 span,
  .infographic-group .infographic-screen h3 span {
    color: #0e5c79;
    -webkit-transition: 0.6s;
    transition: 0.6s;
  }
  .infographic-group .infographic-screen p {
    margin-bottom: 20px;
  }
  .infographic-group .infographic-screen.active {
    z-index: 3;
    opacity: 1;
  }
  .infographic-group .infographic-screen.active h1,
  .infographic-group .infographic-screen.active h2,
  .infographic-group .infographic-screen.active h3 {
    margin-left: 0;
    -webkit-transition-delay: 0s;
    transition-delay: 0;
  }
  .infographic-group .infographic-screen.active h1 span,
  .infographic-group .infographic-screen.active h2 span,
  .infographic-group .infographic-screen.active h3 span {
    margin-right: 0px;
  }
  .infographic-group.bottom .infographic-bg-static {
    bottom: 0;
    top: auto;
  }
}
@media screen and (max-width: 1024px) and (prefers-color-scheme: dark) {
  .infographic-group .infographic-screen h1 span,
  .infographic-group .infographic-screen h2 span,
  .infographic-group .infographic-screen h3 span {
    color: #87aebc;
  }
}
@media screen and (max-width: 767px) {
  .infographic-group {
    position: relative !important;
  }
  .infographic-group .screen-content {
    position: static !important;
    height: auto !important;
  }
  .infographic-group .infographic-screen {
    position: relative;
    height: auto !important;
    transition: width 0s, height 0s, opacity .4s;
    padding: 20px;
    z-index: 2;
    opacity: 1;
  }
  .infographic-group .infographic-screen .desc {
    top: 0;
    transition: .3s;
    transform: translateX(0);
    padding-left: 0;
    max-width: 100%;
  }
  .infographic-group .infographic-screen .desc .responsibilities {
    position: relative;
    padding: 20px;
  }
  .infographic-group .infographic-screen .desc .responsibilities .resp-wrapper {
    opacity: 1.0;
    transform: scale(1.0);
    -webkit-transition: 0.6s;
    transition: 0.6s;
  }
  .infographic-group .infographic-screen .desc .responsibilities:before,
  .infographic-group .infographic-screen .desc .responsibilities:after,
  .infographic-group .infographic-screen .desc .responsibilities .bordered:before,
  .infographic-group .infographic-screen .desc .responsibilities .bordered:after {
    max-height: 120px;
    max-width: 120px;
    opacity: 1;
  }
  .infographic-group .infographic-screen h1,
  .infographic-group .infographic-screen h2,
  .infographic-group .infographic-screen h3 {
    font-size: 2rem;
    margin-top: 0;
    margin-left: 0px;
    margin-bottom: 0;
    font-weight: bold;
  }
  .infographic-group .infographic-screen h1 span,
  .infographic-group .infographic-screen h2 span,
  .infographic-group .infographic-screen h3 span {
    color: #0e5c79;
    -webkit-transition: 0.6s;
    transition: 0.6s;
    margin-right: 0x;
  }
  .infographic-group .infographic-screen .work-date {
    font-size: 14px;
    margin-top: 0;
  }
  .infographic-group .infographic-screen.active {
    z-index: 3;
    opacity: 1;
  }
  .infographic-group .infographic-screen.active h1,
  .infographic-group .infographic-screen.active h2,
  .infographic-group .infographic-screen.active h3 {
    margin-left: 0;
    -webkit-transition-delay: 0s;
    transition-delay: 0;
  }
  .infographic-group .infographic-screen.active h1 span,
  .infographic-group .infographic-screen.active h2 span,
  .infographic-group .infographic-screen.active h3 span {
    margin-right: 0px;
  }
  .infographic-group .infographic-bg-static {
    display: none !important;
  }
  .infographic-group.fixed .infographic-screen {
    position: relative;
  }
  .infographic-group.fixed .infographic-bg-static {
    position: relative;
  }
  .infographic-group.bottom .infographic-bg-static {
    bottom: 0;
    top: auto;
  }
  .infographic-group .timeline {
    display: none !important;
  }
}
@media screen and (max-width: 767px) and (prefers-color-scheme: dark) {
  .infographic-group .infographic-screen h1 span,
  .infographic-group .infographic-screen h2 span,
  .infographic-group .infographic-screen h3 span {
    color: #87aebc;
  }
}
.contact-columns {
  position: relative;
  z-index: 2;
  float: left;
  width: 100%;
  margin-top: 40px;
  margin-bottom: 20px;
}
.contact-columns .simple {
  width: 50%;
  float: left;
  margin-bottom: 40px;
  padding-left: 20px;
}
.contact-columns .simple:nth-child(2n+1) {
  padding-right: 20px;
  padding-left: 0;
}
@media screen and (max-width: 768px) {
  .contact-columns .simple {
    width: 100%;
    padding-left: 0 !important;
    padding-right: 0 !important;
  }
}
.contact-columns .simple h3 {
  font-size: 26px;
  margin-bottom: 20px;
}
.progress {
  position: fixed;
  width: 100%;
  top: 0;
  left: 0;
  right: 0;
  z-index: 100;
  background: none;
  border: 0;
  height: auto;
  margin: 0;
  padding: 0;
  z-index: 100000;
  border-radius: 0;
}
.progress progress {
  position: relative;
  display: block;
  height: 12px;
  width: 100%;
  border: 0;
  background-color: rgba(255,255,255,0.2);
}
@media screen and (max-width: 768px) {
  .progress progress {
    height: 8px;
  }
}
.progress progress::-moz-progress-bar {
  background-color: #0e5c79;
}
.progress progress::-webkit-progress-bar {
  background-color: transparent;
}
.progress progress::-webkit-progress-value {
  background-color: #0e5c79;
}
b,
strong {
  font-weight: 600;
}
body,
li {
  font-size: 2rem;
  font-family: "Open Sans", Segoe UI, Arial, Verdana, Helvetica;
}
@media screen and (max-width: 1200px) {
  body,
  li {
    font-size: 18px;
  }
}
@media screen and (max-width: 960px) {
  body,
  li {
    font-size: 17px;
  }
}
@media screen and (max-width: 414px) {
  body,
  li {
    font-size: 16px;
  }
}
.code {
  background: #e0e0e0;
  padding: 20px;
  position: relative;
  border-radius: 6px;
  margin: 8px 0 12px;
  float: left;
  width: 100%;
}
@media (prefers-color-scheme: dark) {
  .code {
    background: #333;
  }
}
.code:before {
  position: absolute;
  left: 6px;
  top: 0;
  transform: translateY(-50%);
  content: "Code";
  color: #666;
  background: #fff;
  border: 1px solid #ddd;
  border-radius: 50px;
  font-size: 12px;
  padding: 3px 10px;
}
@media (prefers-color-scheme: dark) {
  .code:before {
    border-color: #222;
    color: #aaa;
    background: #444;
  }
}
ol {
  list-style-type: none;
  counter-reset: olcounter;
  margin-left: 0;
  padding-left: 0;
}
ol li {
  margin-bottom: 20px;
  padding-left: 32px;
  position: relative;
}
ol li:before {
  counter-increment: olcounter;
  content: counter(olcounter,decimal) ")";
  font-weight: 600;
  margin-right: 10px;
  display: inline-block;
  width: 30px;
  height: 30px;
  line-height: 28px;
  text-align: center;
  position: absolute;
  margin-top: -5px;
  left: 0;
  top: 5px;
  border-radius: 50%;
  z-index: 2;
  font-size: inherit;
  line-height: inherit;
}
p:has( + ul,
+ ol) {
  margin-bottom: 0;
}
article .custom,
.contact-columns .simple .custom,
.big-li .custom,
.competence-list .custom {
  display: block;
  float: left;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  width: 100%;
}
article ul,
.contact-columns .simple ul,
.big-li ul,
.competence-list ul {
  display: block;
  float: left;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  margin: 0;
  padding: 0;
  list-style: none;
}
article ul li,
.contact-columns .simple ul li,
.big-li ul li,
.competence-list ul li {
  padding-left: 30px;
  padding-bottom: 10px;
  padding-top: 5px;
  min-height: 31px;
  display: block;
  float: left;
  width: 100%;
  position: relative;
  font-weight: 400;
}
article ul li:before,
.contact-columns .simple ul li:before,
.big-li ul li:before,
.competence-list ul li:before {
  content: " ";
  display: block;
  position: absolute;
  left: 0;
  top: 15px;
  width: 14px;
  height: 14px;
  border: 2px solid #35BD7F;
  border-radius: 50%;
}
@media screen and (max-width: 1200px) {
  article ul li:before,
  .contact-columns .simple ul li:before,
  .big-li ul li:before,
  .competence-list ul li:before {
    top: 12px;
    height: 13px;
    width: 13px;
  }
}
@media screen and (max-width: 960px) {
  article ul li:before,
  .contact-columns .simple ul li:before,
  .big-li ul li:before,
  .competence-list ul li:before {
    top: 13px;
    height: 13px;
    width: 13px;
  }
}
@media (max-width: 414px) {
  article ul li:before,
  .contact-columns .simple ul li:before,
  .big-li ul li:before,
  .competence-list ul li:before {
    top: 12px;
    height: 12px;
    width: 12px;
  }
}
article h2,
.contact-columns .simple h2 {
  font-weight: 400;
}
article p + h2,
.contact-columns .simple p + h2 {
  margin-top: 18px;
}
article ul,
article ol,
.contact-columns .simple ul,
.contact-columns .simple ol {
  margin: 10px 0 18px;
}
body.lb-disable-scrolling {
  overflow: hidden;
}

.lightboxOverlay {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 9999;
  background-color: black;
  filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=80);
  opacity: 0.8;
  display: none;
}

.lightbox {
  position: absolute;
  left: 0;
  width: 100%;
  z-index: 10000;
  text-align: center;
  line-height: 0;
  font-weight: normal;
  outline: none;
}

.lightbox .lb-image {
  display: block;
  height: auto;
  max-width: inherit;
  max-height: none;
  border-radius: 3px;

  /* Image border */
  border: 4px solid white;
}

.lightbox a img {
  border: none;
}

.lb-outerContainer {
  position: relative;
  *zoom: 1;
  width: 250px;
  height: 250px;
  margin: 0 auto;
  border-radius: 4px;

  /* Background color behind image.
     This is visible during transitions. */
  background-color: white;
}

.lb-outerContainer:after {
  content: "";
  display: table;
  clear: both;
}

.lb-loader {
  position: absolute;
  top: 43%;
  left: 0;
  height: 25%;
  width: 100%;
  text-align: center;
  line-height: 0;
}

.lb-cancel {
  display: block;
  width: 32px;
  height: 32px;
  margin: 0 auto;
  background: url(../images/loading.gif) no-repeat;
}

.lb-nav {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  z-index: 10;
}

.lb-container > .nav {
  left: 0;
}

.lb-nav a {
  outline: none;
  background-image: url('data:image/gif;base64,R0lGODlhAQABAPAAAP///wAAACH5BAEAAAAALAAAAAABAAEAAAICRAEAOw==');
}

.lb-prev, .lb-next {
  height: 100%;
  cursor: pointer;
  display: block;
}

.lb-nav a.lb-prev {
  width: 34%;
  left: 0;
  float: left;
  background: url(../images/prev.png) left 48% no-repeat;
  filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=0);
  opacity: 0;
  -webkit-transition: opacity 0.6s;
  -moz-transition: opacity 0.6s;
  -o-transition: opacity 0.6s;
  transition: opacity 0.6s;
}

.lb-nav a.lb-prev:hover {
  filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=100);
  opacity: 1;
}

.lb-nav a.lb-next {
  width: 64%;
  right: 0;
  float: right;
  background: url(../images/next.png) right 48% no-repeat;
  filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=0);
  opacity: 0;
  -webkit-transition: opacity 0.6s;
  -moz-transition: opacity 0.6s;
  -o-transition: opacity 0.6s;
  transition: opacity 0.6s;
}

.lb-nav a.lb-next:hover {
  filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=100);
  opacity: 1;
}

.lb-dataContainer {
  margin: 0 auto;
  padding-top: 5px;
  *zoom: 1;
  width: 100%;
  border-bottom-left-radius: 4px;
  border-bottom-right-radius: 4px;
}

.lb-dataContainer:after {
  content: "";
  display: table;
  clear: both;
}

.lb-data {
  padding: 0 4px;
  color: #ccc;
}

.lb-data .lb-details {
  width: 85%;
  float: left;
  text-align: left;
  line-height: 1.1em;
}

.lb-data .lb-caption {
  font-size: 13px;
  font-weight: bold;
  line-height: 1em;
}

.lb-data .lb-caption a {
  color: #4ae;
}

.lb-data .lb-number {
  display: block;
  clear: left;
  padding-bottom: 1em;
  font-size: 12px;
  color: #999999;
}

.lb-data .lb-close {
  display: block;
  float: right;
  width: 30px;
  height: 30px;
  background: url(../images/close.png) top right no-repeat;
  text-align: right;
  outline: none;
  filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=70);
  opacity: 0.7;
  -webkit-transition: opacity 0.2s;
  -moz-transition: opacity 0.2s;
  -o-transition: opacity 0.2s;
  transition: opacity 0.2s;
}

.lb-data .lb-close:hover {
  cursor: pointer;
  filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=100);
  opacity: 1;
}
