[class^="modal-dialog-wrapper"]:hover {
    cursor: pointer;
}

[class^="modal-dialog-background"] {
    z-index: 19;
    position: fixed;
    width: 100vw;
    height: 100vh;
    top: 0;
    left: 0;
    background: rgba(0, 0, 0, 0.5);
    justify-content: center;
    align-items: center;
    display: none;
}

[class^="modal-dialog-popup"] {
    z-index: 20;
    position: relative;
    background-color: rgb(255, 255, 255);
    max-width: 90vw;
    max-height: 90vh;
}

#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;
}
/* <<< Defaults */

/* Text content >>> */
body {
  min-width: 28rem;
}

#main {
  font-size: 2rem;
  font-weight: 300;
  line-height: 1.6;
  color: rgba(38, 69, 95, 0.8);
}

.mod_article {
  margin-left: auto;
  margin-right: auto;

  padding-left: 2rem;
  padding-right: 2rem;
  max-width: 84rem;

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

.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;
}

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

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

.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;
}

p {
  padding-bottom: 0;
}
/* <<< Text content */

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

.widget > .text,
.widget > .textarea,
.widget > .captcha {
  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);
}

.widget > .captcha {
  width: 20rem;
}

.widget-captcha > p.error {
  border-left: 2px dotted rgb(245, 122, 0);
  padding-left: 1.6rem;
}

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

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

.internal-navigation  a.logout-button {
  padding: 0.6rem 2.0rem 0.8rem 2.0rem;
  background-color: rgb(38, 69, 95);
  color: rgb(255, 255, 255);
  text-decoration: none;
  border: 1px solid rgb(38, 69, 95);
  border-radius: 0.3rem;
}

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;
}

.password-reset {
  margin-top: 2rem;
}

.password-reset a {
  text-decoration: underline dotted;
  text-decoration-thickness: 2px;
  text-decoration-color: rgba(245, 122, 0, 0.8);
}
/* <<< Forms */

/* About-me image and text >>> */
.about-me figure {
  display: inline-block;
  width: 50%;
  margin-right: auto;
  margin-left: 0;
  margin-bottom: 2.2rem;

  padding-top: 0;
  margin-top: auto;
}

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

.about-me .rte {
  display: inline-block;
  vertical-align: top;
}

button.skill-logo:focus {
  outline: none;
}

button.skill-logo {
  cursor: pointer;
  padding: 0 0 0 0;
  background-color: transparent;
  border: none;
  float: left;
}

.mod_article > :not(.content-gallery) li:has(.skill-logo) {
  display: inline;
  background: none;
  padding: 0;
}

.skill-list-item {
  display: flex;
  flex-direction: row;
  align-items : flex-start;

  padding-top: 1.2rem;
  padding-bottom: 1.2rem;
}

.skill-description {
  display: block;
  float: inline-start;
}

.skill-logo {
  width: 4rem;
  padding-right: 6rem;
}

.skill-description-text {
  word-break: break-word;
}

.skill-logo::before {
  content: '';
  padding-top: 0.75rem;
  padding-bottom: 0.75rem;

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

  margin-left: 0;
  margin-right: 1rem;

  border: 1px solid rgba(38, 69, 95, 0.8);
  border-radius: 1.2rem;

  background-size: 80% auto;
  background-repeat: no-repeat;
  background-position: center;
}

.skill-logo.php-development::before {
  background-image: url("/files/contao-garage/system/images/icons/php-development.svg");
}

.skill-logo.frontend-development::before {
  background-image: url("/files/contao-garage/system/images/icons/frontend-development.svg");
}

.skill-logo.linux-systemadministration::before {
  background-image: url("/files/contao-garage/system/images/icons/linux-systemadministration.svg");
}

.skill-logo.database-administration::before {
  background-image: url("/files/contao-garage/system/images/icons/database-administration.svg");
}

.skill-logo.indexing-retrieval::before {
  background-image: url("/files/contao-garage/system/images/icons/indexing-retrieval.svg");
}

.skill-logo::before {
  background-color: rgba(38, 69, 95, 0.1);
}

td:nth-child(1) {
  width: 20rem;
  text-align: right;
  align-items: top;
  padding-right: 6rem;
  vertical-align: baseline;
}

td:nth-child(2) {
  padding-bottom: 0.5rem;
  vertical-align: baseline;
}

.content-gallery figure {
  padding: 0;
  margin: 0;
  display: inline;
}

.content-gallery img {
  height: auto;
  width: 100%;
}

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

.content-gallery ol > li {
  display: inline-block;
  margin: 0.1rem 0.1rem 0.1rem 0;
  font-weight: 400;
  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);
  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 */

/* Modal dialog >>> */
[class^="modal-dialog-wrapper"]:hover {
    cursor: zoom-in;
}

[class^="modal-dialog-background"] {
    background: rgba(0, 0, 0, 0.5);
}

[class^="modal-dialog-popup"] {
    background-color: rgb(255, 255, 255);
    padding: 2.8rem;
    border-radius: 1.2rem;
    border: 0.1rem solid rgb(38, 69, 95, 0.8);
}
/* <<< Modal dialog */

/* CV table >>> */
.cv-table-row {
  @media (min-width: 600px) {
    display: grid;
    grid-template-columns: 26rem auto;
    align-items: stretch;
  }
}

.cv-table-key {
  font-weight: 400;
  border-left: 2px dotted rgb(245, 122, 0);
  padding-left: 1.6rem;

  @media (min-width: 600px) {
    display: block;
    text-align: right;
    padding-bottom: 1rem;
    padding-right: 2rem;

    border-left: none;
    padding-left: 0;
  }
}

.cv-table-content {
  padding-bottom: 2rem;

  @media (min-width: 600px) {
    display: inline;
    text-align: left;
    vertical-align: top;;
    padding-bottom: 1rem;
    padding-right: 2rem;
  }
}

.cv-table p {
  padding: 0 0 0 2rem;
  margin: 0;

  @media (min-width: 600px) {
    padding: 0;
    vertical-align: top;
  }
}
/* <<< CV table */
/* 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-top: 2rem;
  padding-bottom: 2rem;
}

.mod_customnav.footer {
  display: block;
  margin-left: auto;
  margin-right: auto;
  padding-left: 2rem;
  padding-right: 2rem;
  max-width: 84rem;

  @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:not(:has(+ .internal-navigation)) {
  background-color: rgb(38, 69, 95);
  /*margin-bottom: 3rem;*/

  /*outline: 3px solid green;*/

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

.header-navigation:has(+ .internal-navigation) {
  background-color: rgb(38, 69, 95);
  /*margin-bottom: 3rem;*/

  /*outline: 3px solid red;*/

  @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;
}

.internal-navigation .mod_customnav,
.header-navigation .mod_navigation {
   max-width: 84rem;
   margin-left: auto;
   margin-right: auto;

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

.internal-navigation .mod_customnav,
.header-navigation .mod_navigation {
  @media (min-width: 1000px) {
    padding-right: 2rem;
  }
}

.header-navigation .header-logo {
  @media (min-width: 1000px) {
    padding-left: 2rem;
  }
}

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

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

  @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:nth-last-child(-n + 1) {
  border-bottom: 0.1rem solid rgba(250, 250, 250, 0.2);
  margin-bottom: 2rem;

  @media (min-width: 1000px) {
    border-bottom: unset;
    margin-bottom: unset;
  }
}

.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,
.header-navigation .trail a {
  font-weight: 600;
  color: rgb(255, 255, 255);
}
/* <<< Header */

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

.internal-navigation ul {
  margin: 0 auto 3rem auto;
  padding: 1.4rem 0 1.4rem 0;

  @media (min-width: 1000px) {
    display: flex;
    justify-content: flex-end;
    gap: 3.2rem;
    max-width: 120rem;
    margin: 0 auto 6rem auto;
  }
}

.internal-navigation ul {
  padding-left: 2rem;
  padding-right: 2rem;

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

.internal-navigation li {
  /*margin: 0;*/
  /*border-top: 0.1rem solid red;*/
  line-height: 2.6rem;
  padding-left: 2rem;

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

.internal-navigation a {
  font-weight: 400;
  color: rgb(38, 69, 95);
  white-space: nowrap;
  text-decoration: none;
  padding: 1rem 0 1.2rem 0;
}

.internal-navigation a:hover,
.internal-navigation a:active {
  /*text-decoration-color: #f57a00;*/
  text-decoration-line: underline;
}

.internal-navigation a:hover,
.internal-navigation a:active,
.internal-navigation strong {
  text-decoration-line: underline;
  /*text-decoration-color: #f57a00;*/
  /*text-decoration-line: underline;*/
  color: rgba(38, 69, 95, 1);
}

.internal-navigation strong {
   font-weight: 600;
   text-decoration-line: none;
}
/* <<< Internal navigation */

.mod_article {
  /*outline: 1px solid green;*/
}




