:root {
  --max-content-width: 1300px;
  --top-space: 5rem;
  --border-radius: 5px;
  --tag-border-radius: 5px;
  --title-spacing: 0.5rem;
  --avatar-size: 200px;

  --content-padding: 1rem;
  --text-padding: 0.5rem;
  --tag-padding: 0.35rem;

  --color-bg: #fdfffb;
  --color-fg: #1B263B;

  --color-title:  #de493e;
  --color-tag-bg: #585b64;
  --color-tag-fg: #fdfffb;
  --color-link:   #de493e;
  --color-entry-hover: #f5f7f3;

  --color-company: gray;
  --color-branch: lightgray;
  --color-tenure: gray;

  --color-bg-avatar: #585b64;

  --color-light-icon: orange;
  --color-dark-icon: #F0F0F0;

  --left-col-width: 0.35;
  --right-col-width: 0.65;

  --avatar-bg-filter: brightness(200%);

  --font-title: 'Atkinson Hyperlegible', 'Roboto', Tahoma, Geneva, Verdana, sans-serif;
  --font-body: 'Atkinson Hyperlegible', 'Open Sans', sans-serif;
  --font-code: 'Inconsolata', 'Ubuntu Mono', monospace;

}

[data-theme="dark"] {
  --color-bg: #31343c;
  --color-fg: #fdfffb;
  --color-entry-hover: #292c34;
  --color-bg-avatar: #de493e;
  --avatar-bg-filter: brightness(75%);
}


@font-face {
  font-family: 'Atkinson Hyperlegible';
  src: url("../fonts/atkinson.ttf") format("truetype"); 
}

@font-face {
  font-family: 'Atkinson Hyperlegible Mono';
  src: url("../fonts/atkinson_mono.ttf") format("truetype"); 
}

body {
  margin: 0;
  padding: 0;
  height: 100vh;
  font-family: var(--font-body);

  background-color: var(--color-bg);
  color: var(--color-fg);
  transition: background-color 0.3s ease, color 0.3s ease;
}

body * {
  box-sizing: border-box;
}

p {
  margin-top: 0;
  margin-bottom: var(--title-spacing);
}

ul {
  margin: 0;
}

h1 {
  font-size: 4em;
  margin-top: 0;
  margin-bottom: var(--title-spacing);
}

h1.centered {
  text-align: center;
}

h1.primary-title {
  position: relative;
  z-index: 2;
}

h1.secondary-title {
  position: absolute;
  user-select: none;
  top: 0;
  width: 100%;
  color: var(--color-link);
  z-index: 1;
}

.titles {
  position: relative;
}

h2 {
  margin-top: var(--title-spacing);
  font-size: 1.5em;
}

h2.centered {
  text-align: center;
}


h3 {
  font-size: 1.2em;
  color: var(--color-title);
  margin-top: var(--title-spacing);
  margin-bottom: var(--title-spacing);
}

a {
  text-decoration: none;
  color: var(--color-link);
}

.theme {
  position: absolute;
  top: 1.5rem;
  right: 1rem;
  background: none;
  border: 0;
  cursor: pointer;
  z-index: 99;
}

.theme svg {
  position: relative;
  scale: 0.75;
}

#dark-icon {
  stroke: var(--color-dark-icon);
  color: var(--color-dark-icon);
}

#light-icon {
  stroke: var(--color-light-icon);
  color: var(--color-light-icon);
}

.container {
  position: relative;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  width: 100%;
  min-height: 100vh; 
  margin-bottom: 2rem;
}

.content {
  position: relative;
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  max-width: var(--max-content-width);
  width: 100%;
  height: 100%; 
}

.avatar-container {
  display: flex;
  width: 100%;
  justify-content: center;
}

.avatar {
  position: relative;
  width: var(--avatar-size);
  display: block;
  clip-path: circle(45%);
  z-index:2;
  background-color: var(--color-bg-avatar);
}

.avatar img {
  width: 100%;
  heigth: 100%;
  aspect-ratio: 1;
  object-fit: cover;
}

.avatar::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0; bottom: 0;
  background-color: inherit; 
  z-index: -1;
  transition: filter 0.2s;
}

.avatar:hover::before {
  filter: var(--avatar-bg-filter);
}

.introduction {
  position: sticky;
  top: 1px;
  padding: var(--content-padding);
  padding-top: var(--top-space);
  align-self: flex-start;
  flex-basis: calc(var(--max-content-width) * var(--left-col-width));
}


.introduction .intro {
  font-size: 1rem;
}

.resume {
  padding: var(--content-padding);
  padding-top: var(--top-space);
  flex-basis: calc(var(--max-content-width) * var(--right-col-width));
}

.resume .intro {
  padding: var(--text-padding);
  padding-top: 0;
}

.history {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  margin-bottom: 0.5rem;
}

.skill-entry {
  display: flex;
}

.entry {
  display: flex;
  flex-direction: row;
  align-items: baseline;
  justify-content: flex-start;
  padding: var(--text-padding);
  padding-top: calc(2 * var(--text-padding));
  padding-bottom: calc(2 * var(--text-padding));
  width: 100%;
  height: 100%;
  transition: background ease-in 200ms;
  border-radius: var(--border-radius);
}

.entry:hover {
  background: var(--color-entry-hover);
}

.entry .dates {
  flex-basis: 15%;
  font-size: 0.75rem;
  text-align: right;
  padding-right: 0.75rem;
  padding-top: -0.25rem;
  font-family: 'Atkinson Hyperlegible Mono';
}

.entry .information {
  flex-basis: 85%;
}

.tenure {
  font-size: 0.65rem;
  color: var(--color-tenure);
}

.tenure.small {
  font-size: 1rem;
  display: none;
}

.skill-entry {
  margin-left: var(--text-padding);
  align-items: baseline;
}

.skill-entry + .skill-entry {
  margin-top: var(--title-spacing);
}


.skill-type + .stack {
  margin-left: 0.5rem;
}

.position {
  font-weight: bold;
}

.company {
  color: var(--color-company);
}

.branch {
  color: var(--color-branch);
}


.position + .company::before {
  content: ' @ ';
  color: var(--color-fg);
}

.stack {
  position: relative;
  display: block;
}

.tag {
  display: inline-block;
  padding: var(--tag-padding); 
  background: var(--color-tag-bg);
  color: var(--color-tag-fg);
  border-radius: var(--border-radius);
  font-size: 0.85rem;
  margin-top: 0.25rem;
  margin-bottom: 0.25rem;
}

.icon {
  width: 24px;
  heigth: 24px;
  fill: var(--color-link);
}

.icon:hover, a:hover {
  filter: brightness(125%);
}
a:hover img {
  filter: brightness(80%);
}

.gallery {
  display: flex;
  width: 100%;
  justify-content: flex-start;
  margin-top: 1rem;
}

.thumbnails {
  display: flex;
  flex-direction: column;
  flex-basis: 20%;
  padding-left: 2rem;
}

.thumbnails > .screenshot {
  margin-bottom: 0.25rem;
}

.screenshot {
  max-width: 400px;
  max-height: 500px;
  border-radius: var(--border-radius);
}

.screenshot.small {
  max-width: 100px;
  max-height: 150px;
}

.code-link {
  display: flex;
  align-items: center;
  margin-top: 0.5rem;
}

.code-link svg {
  width: 1rem;
}

.code-link > *+* {
  margin-left: 0.25rem;
}

@media only screen and (max-width: 1100px) {
  .content {
    flex-direction: column;
  }

  .introduction {
    position: relative;
  }

  .resume {
    padding-top: 0rem;
  }

}

@media only screen and (max-width: 700px) {

  .content {
    max-width: 100vw;
    box-sizing: border-box;
  }

  .entry .dates {
    display: none;
  }

  .entry .information {
    flex-basis: 100%;
  }

  .tenure.small {
    display: inline;
  }

  .skill-type {
    width: min-content;
  }

  .gallery {
    flex-direction: column;
  }

  .screenshot {
    max-width: 100%;
    max-height: 400px;
  }

  .thumbnails {
    display: none;
    flex-direction: row;
    padding: 0;
    padding-top: 1rem;
  }

  .thumbnails .screenshot {
    margin: 0;
    margin-right: 0.25rem;
  }

}


