#colorbox,#cboxOverlay,#cboxWrapper{position:absolute;top:0;left:0;z-index:9999;overflow:hidden;-webkit-transform:translate3d(0,0,0)}#cboxWrapper{max-width:none}#cboxOverlay{position:fixed;width:100%;height:100%}#cboxMiddleLeft,#cboxBottomLeft{clear:left}#cboxContent{position:relative}#cboxLoadedContent{overflow:auto;-webkit-overflow-scrolling:touch}#cboxTitle{margin:0}#cboxLoadingOverlay,#cboxLoadingGraphic{position:absolute;top:0;left:0;width:100%;height:100%}#cboxPrevious,#cboxNext,#cboxClose,#cboxSlideshow{cursor:pointer}.cboxPhoto{float:left;margin:auto;border:0;display:block;max-width:none;-ms-interpolation-mode:bicubic}.cboxIframe{width:100%;height:100%;display:block;border:0;padding:0;margin:0}#colorbox,#cboxContent,#cboxLoadedContent{box-sizing:content-box;-moz-box-sizing:content-box;-webkit-box-sizing:content-box}#cboxOverlay{background:#000;opacity:.9;filter:alpha(opacity = 90)}#colorbox{outline:0}#cboxContent{margin-top:20px;background:#000}.cboxIframe{background:#fff}#cboxError{padding:50px;border:1px solid #ccc}#cboxLoadedContent{border:5px solid #000;background:#fff}#cboxTitle{position:absolute;top:-20px;left:0;color:#ccc}#cboxCurrent{position:absolute;top:-20px;right:0;color:#ccc}#cboxLoadingGraphic{background:url(../../assets/colorbox/images/loading.gif) no-repeat center center}#cboxPrevious,#cboxNext,#cboxSlideshow,#cboxClose{border:0;padding:0;margin:0;overflow:visible;width:auto;background:0 0}#cboxPrevious:active,#cboxNext:active,#cboxSlideshow:active,#cboxClose:active{outline:0}#cboxSlideshow{position:absolute;top:-20px;right:90px;color:#fff}#cboxPrevious{position:absolute;top:50%;left:5px;margin-top:-32px;background:url(../../assets/colorbox/images/controls.png) no-repeat top left;width:28px;height:65px;text-indent:-9999px}#cboxPrevious:hover{background-position:bottom left}#cboxNext{position:absolute;top:50%;right:5px;margin-top:-32px;background:url(../../assets/colorbox/images/controls.png) no-repeat top right;width:28px;height:65px;text-indent:-9999px}#cboxNext:hover{background-position:bottom right}#cboxClose{position:absolute;top:5px;right:5px;display:block;background:url(../../assets/colorbox/images/controls.png) no-repeat top center;width:38px;height:19px;text-indent:-9999px}#cboxClose:hover{background-position:bottom center}
@charset "UTF-8";

/* Fonts rem trick >>> */
html {
  font-size: 62.5%;
}
/* <<< Fonts rem trick */

/* Sticky footer >>> */
* {
  box-sizing: border-box;
}

html,
body {
  box-sizing: border-box;
  height: 100%;
  padding: 0;
  margin: 0;
}

#wrapper {
  box-sizing: border-box;
  min-height: 100%;
  display: flex;
  flex-direction: column;
}

#header,
#footer {
  flex-grow: 0;
  flex-shrink: 0;
}

#container {
  flex-grow: 1;
}
/* <<< Sticky footer */

/* Defaults >>> */
* {
  /*outline: 1px solid green;*/
}

.invisible {
  display: none;
}

ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

ol {
  list-style: none;
  margin: 0;
  padding: 0;
}

a {
  color: rgb(38, 69, 95, 0.8);
  text-decoration: none;
}

a:hover {
  text-decoration: underline;
}

body {
  background-color: rgb(249, 250, 251);
  font-family: "Barlow", Arial, Helvetica, sans-serif;
  font-size: 2rem;
  font-weight: 300;
  line-height: 1.6rem;
}

code {
  font-family: "Ubuntu Sans Mono", monospace;
  font-weight: 400;
  /*font-size: 2.2rem;*/
}
/* <<< Defaults */

/* Text content >>> */
.rte > h2:nth-child(n+1) {
  margin-top: 2.6rem;
  margin-bottom: 2.2rem;
}

.rte > h3:nth-child(n+1) {
  margin-top: 2.2rem;
  margin-bottom: 1.8rem;
}

h1,
h2,
h3 {
  color: rgb(38, 69, 95);
}

h2 {
  border-left: 2px solid rgb(245, 122, 0);
  padding-left: 1.6rem;
}

h3 {
  border-left: 2px dotted rgb(245, 122, 0);
  padding-left: 1.6rem;
}

.content-table a,
.content-text a {
  text-decoration: underline dotted;
  text-decoration-thickness: 2px;
  text-decoration-color: rgba(245, 122, 0, 0.8);
}

.content-table strong,
.content-text strong {
  font-weight: 500;
}

.mod_article {
  position: relative;
  max-width: 72rem;
  
  margin-left: auto;
  margin-right: auto;

  font-weight: 300;
  line-height: 1.6;
  color: rgba(38, 69, 95, 0.8);

  padding-left: 2rem;
  padding-right: 2rem;

  @media (min-width: 1000px) {
    font-size: 2rem;
    max-width: 84rem;
  }
}

.mod_article > .ce_form:nth-child(n+1),
.mod_article > .content-text:nth-child(n+1) {
  /*padding-left: 2.6rem;*/
  /*padding-right: 2.6rem;*/
  /*margin-left: -2.6rem;*/
  /*margin-right: -2.6rem;*/

  /*padding-top: 1.3rem;*/
  /*padding-bottom: 2.6rem;*/
  /*margin-top: -1.3rem;*/
  /*margin-bottom: -2.6rem;*/

  /*margin-bottom: 2.6rem;*/
}

.mod_article > .content-text:nth-child(n+1) {
  /*border-top: 1px solid rgba(38, 69, 95, 0.03);*/
  /*border-bottom: 1px solid rgba(38, 69, 95, 0.03);*/
  /*background-color: rgba(38, 69, 95, 0.02);*/
}

.mod_article > .ce_form:nth-child(1),
.mod_article > .content-text:nth-last-child(1) {
  /*margin-bottom: 0;*/
}

.mod_article ul,
.mod_article ol {
  list-style-position: outside;
}

.mod_article > :not(.content-gallery) li {
    background: url("/files/contao-garage/system/images/icons/chevron-right.svg") no-repeat 0 9px transparent;
    padding: 0 0 0 2rem;
}

/* <<< Text content */

/* Forms >>> */
label {
  display: block;
  padding-bottom: 0.6rem;
  font-weight: 500;
}

.widget > .text,
.widget > .textarea {
  font-size: 2rem;
  line-height: 3.2rem;
  font-weight: 300;
  width: 100%;
  margin: 0;
  padding: 1rem 1rem 1rem 1rem;
  display: block;
  font-family: "Barlow", Arial, Helvetica, sans-serif;
  color: rgba(38, 69, 95, 0.8);
}

div + div:has(> label) {
  display: block;
  padding-top: 2rem;
}

.widget-submit > .submit {
  margin-top: 2rem;
  margin-bottom: 2rem;
}

button {
  cursor: pointer;
  font-size: 2rem;
  font-family: "Barlow", Arial, Helvetica, sans-serif;
  font-weight: 500;
  line-height: 1.6;
  padding: 0.6rem 2.4rem 0.8rem 2.4rem;
  color: rgb(255, 255, 255);
  background-color: rgb(38, 69, 95);
  border: 1px solid rgb(38, 69, 95);
  border-radius: 0.3rem;
  float: right;
}

button:hover,
button:focus,
button:active {
  cursor: pointer;
  text-decoration: none;
  background-color: rgb(245, 122, 0);
  border: 1px solid rgb(245, 122, 0);
  border-radius: 0.3rem;
}

button:focus {
  outline: 3px solid rgb(245, 122, 0);
  border-radius: 0.3rem;
}

input:focus,
textarea:focus {
  outline: 2px solid rgb(245, 122, 0);
  border-radius: 0.3rem;
  border: 1px solid rgb(255, 255, 255);
}

input,
textarea {
  border-radius: 0.3rem;
  border: 1px solid rgba(38, 69, 95, 0.2);
}

input:autofill {
  transition:
    background-color calc(infinity * 1s) step-end,
    background-image calc(infinity * 1s) step-end allow-discrete,
    color calc(infinity * 1s) step-end;
}
/* <<< Forms */

/* About-me image and text >>> */
.mod_article.about-me {
  display: flex;
  flex-direction: column-reverse;

  @media (min-width: 1000px) {
    flex-direction: row;
  }
}

.about-me.content-text {
  @media (min-width: 1000px) {
    max-width: 36rem;
  }
}

.about-me figure {
  display: block;

  @media (min-width: 1000px) {
    position: absolute;
    right: 0;
    margin-right: 0;
  }
}

.about-me img {
  display: block;
  margin: auto;
  border-radius: 1.2rem;
}

.listed-skill {
  position: absolute;
  left: 10rem;
}

td:nth-child(1) {
  width: 20rem;
  /*outline: 1px solid red;*/
  /*border: 1px solid red;*/
  /*background-color: red;*/
  text-align: right;
  align-items: top;
  padding-right: 6rem;
  /*padding-bottom: 1rem;*/
  vertical-align: baseline;
}

td:nth-child(2) {
  /*width: 20rem;*/
  /*border: 1px solid red;*/
  /*background-color: red;*/
  /*text-align: right;*/
  /*align-items: top;*/
  /*padding-right: 6rem;*/
  padding-bottom: 0.5rem;
  /*padding-bottom: 1rem;*/
  vertical-align: baseline;
}

::marker {
  /*font-size: 20px;*/
  /*color: red;*/
}

.content-gallery figure {
  padding: 0;
  margin: 0;
  display: flex;
  /*outline: 1px solid green;*/
    justify-content: left;

}

.content-gallery ol {
    display: flex;
    margin-top: 1rem;
}

.content-gallery ol > li {
  margin: 0 0.1rem;
  font-weight: 400;
  align-items: center;
  align-content: center;
  width: 3.6rem;
  height: 3.6rem;
  text-align: center;
  color: rgba(255, 255, 255, 1.0);
}

.content-gallery ol > li > a {
  display: flex;
  justify-content: center;
  color: rgba(38, 69, 95, 0.8);
  border-radius: 100%;
  text-decoration: underline 1px solid;
}

.content-gallery ol > li > a.active,
.content-gallery ol > li > a:active {
  border-radius: 100%;
  background-color: rgba(38, 69, 95, 0.8);
  border: 1px solid rgba(38, 69, 95, 0.8);
  background-clip: padding-box;
  color: rgba(255, 255, 255, 1.0);
  /*color: rgba(38, 69, 95, 0.8);*/
  text-decoration: none;
}

.content-gallery ol > li > a:hover,
.content-gallery ol > li > a:focus {
  border-radius: 100%;
  border: 1px solid rgba(38, 69, 95, 0.8);
  background-clip: padding-box;
  text-decoration: none;
}

.content-gallery img {
  border: 0.1rem solid rgb(38, 69, 95, 0.2);
  background-clip: padding-box;
}
/* <<< About-me image */

/* Footer >>> */
#footer > .inside > .footer-lead {
  margin-top: 3rem;

  @media (min-width: 1000px) {
    margin-top: 6rem;
  }
}

#footer > .inside > .footer-navigation {
  background-color: rgb(245, 122, 0);
  padding: 2rem;
}

.mod_customnav.footer {
  max-width: 72rem;
  margin: 0 auto;
  padding-left: 2rem;
  padding-right: 2rem;

  @media (min-width: 1000px) {
    max-width: 84rem;
  }
}

.footer-navigation li {
  line-height: 2.8rem;
  font-weight: 400;
  font-height: 400;

  @media (min-width: 1000px) {
    font-size: 2.2rem;
  }
}

.footer-navigation li > a,
.footer-navigation li > strong {
  color: rgb(255, 255, 255);
  text-decoration: none;
}

.footer-navigation li > a:hover {
  color: rgb(255, 255, 255);
  text-decoration: underline;
}
/* <<< Footer */
/* Header >>> */
.header-navigation {
   background-color: rgb(38, 69, 95);

  @media (min-width: 1000px) {
    /*margin-bottom: 12rem;*/
  }
}

.header a {
  color: rgb(255, 255, 255);
}

.header-logo {
  font-size: 4.2rem;
  line-height: 4.2rem;

  @media (min-width: 1000px) {
    z-index: 10;
    position: relative;
    max-width: 120rem;
    margin: 0 auto;
    padding: 0;
  }
}

.header-logo a {
  text-decoration: none;
}

.header-logo > .inside {
  display: flex;
  justify-content: center;
  padding-top: 2rem;
  padding-bottom: 2rem;

  @media (min-width: 1000px) {
      margin-top: 2.8rem;
      padding: 0;
      position: absolute;
    }
}

.header-logo-text {
  padding: 2rem;
  display: inline-block;
  box-sizing: content-box;
  background-color: rgb(255, 255, 255);
  padding-top: 1.4rem;
  padding-bottom: 1.8rem;
  padding-right: 1.6rem;
  padding-left: 1.6rem;
  border-radius: 1.2rem;
  border: 0.1rem solid rgb(38, 69, 95, 0.2);
}

.logo-text-orange {
  font-weight: 700;
  color: #f57a00;
}

.logo-text-blue {
  font-weight: 700;
  color: #26455f;
}

.logo-first-line {
  padding: 0;
  margin: 0;
  display: block;
}

.logo-second-line {
  box-sizing: content-box;
  display: block;
  padding-left: 6.2rem;
}

.header-navigation {
  padding: 0 6rem 0 6rem;
}

.header-navigation .mod_navigation {
  max-width: 68rem;
  margin: 0 auto 3rem auto;

  @media (min-width: 1000px) {
    max-width: 120rem;
    margin: 0 auto 6rem auto;
  }
}

.header-navigation ul {
  margin: 0;
  padding: 0 0 1.2rem 0;

  @media (min-width: 1000px) {
    display: flex;
    justify-content: flex-end;
    gap: 3.2rem;
    padding: 0;
  }
}

.header-navigation li {
  margin: 0;
  border-top: 0.1rem solid rgba(250, 250, 250, 0.2);

  @media (min-width: 1000px) {
    font-size: 2.2rem;
    line-height: 2.6rem;
    border-top: 0;
    margin: 0;
    position: relative;
  }
}

.header-navigation li > a:hover,
.header-navigation li > a:focus,
.header-navigation li > a:active,
.header-navigation li > strong,
.header-navigation li.trail > a {
  color: #FFF;
  text-decoration: underline;

  @media (min-width: 1000px) {
    text-decoration: none;
    border-bottom: 0.2rem solid #f57a00;
    margin-bottom: -0.2rem;
  }
}

.header-navigation li > a ,
.header-navigation li > strong {
  display: flex;
  white-space: nowrap;
  font-weight: 400;
  text-decoration: none;
  padding: 1rem 2rem 1.2rem 0;

  @media (min-width: 1000px) {
    padding: 1.4rem 0 1.8rem 0;
  }
}

.header-navigation .active strong {
  font-weight: 600;
  color: rgb(255, 255, 255);
}
/* <<< Header */

/* Internal navigation >>> */
.internal-navigation {
  background-color: rgb(225, 226, 227);
  color: rgb(255, 255, 255);
}

.internal-navigation a {
  font-weight: 600;
}

/* <<< Internal navigation */

