@font-face {
  font-family: HKGrotesk;
  font-weight: 400;
  src: url("/fonts/HKGrotesk-Medium.woff2") format(woff2);
}
@font-face {
  font-family: HKGrotesk;
  font-weight: 500;
  src: url("/fonts/HKGrotesk-SemiBold.woff2") format(woff2);
}
@font-face {
  font-family: HKGrotesk;
  font-weight: 700;
  src: url("/fonts/HKGrotesk-Bold.woff2") format(woff2);
}
@font-face {
  font-family: HKGrotesk;
  font-weight: 800;
  src: url("/fonts/HKGrotesk-ExtraBold.woff2") format(woff2);
}
@font-face {
  font-family: IbarraRealNova;
  font-weight: 900;
  src: url("/fonts/IbarraRealNova-Bold.woff2") format(woff2);
}

@font-face {
  font-family: FrankRuhlLibre;
  font-weight: 400;
  src: url("/fonts/FrankRuhlLibre-Regular.woff2") format(woff2);
}
@font-face {
  font-family: FrankRuhlLibre;
  font-weight: 500;
  src: url("/fonts/FrankRuhlLibre-SemiBold.woff2") format(woff2);
}
@font-face {
  font-family: FrankRuhlLibre;
  font-weight: 700;
  src: url("/fonts/FrankRuhlLibre-Bold.woff2") format(woff2);
}

:root {
  --ff-primary-serif: FrankRuhlLibre;
  --ff-primary-sans: HKGrotesk, sans-serif;

  --fs-100: 0.625rem;
  --fs-200: 0.75rem;
  --fs-300: 0.8125rem;
  --fs-350: 0.9375rem;
  --fs-400: 1rem;
  --fs-500: 1.25rem;
  --fs-600: 1.5rem;
  --fs-700: 1.75rem;
  --fs-800: 2rem;
  --fs-900: 2.5rem;

  --fs-xx-small: var(--fs-100);
  --fs-x-small: var(--fs-200);
  --fs-small: var(--fs-300);
  --fs-normal: var(--fs-400);
  --fs-large: var(--fs-600);
  --fs-x-large: var(--fs-700);
  --fs-xx-large: var(--fs-800);

  --s-xx-small: 0.0625rem;
  --s-x-small: 0.25rem; 
  --s-small: 0.375rem; 
  --s-normal: 0.5rem;
  --s-large: 0.1rem;
  --s-x-large: 1.5rem;
  --s-xx-large: 2rem;
  --s-3x-large: 3rem;
  --s-350: 0.75rem;

  --fw-400: 400;
  --fw-600: 600;
  --fw-700: 700;
  --fw-800: 800;
  --fw-900: 900;

  --clr-primary-1: hsl(0 0% 22%);
  --clr-neutral-1: hsl(6 2% 61%);
  --clr-neutral-2: #EFECEF;

  --icon-width: 1rem;
  --icon-height: 1rem;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

ul[class],
ol[class] {
  padding: 0;
}

body,
h1,
h2,
h3,
h4,
p,
ul[class],
ol[class],
li,
figure,
figcaption,
blockquote,
dl,
dd {
  margin: 0;
}

body {
  min-height: 100vh;
  scroll-behavior: smooth;
  text-rendering: optimizeSpeed;
  line-height: 1.5;
  max-width: 8.5in;
}

ul[class],
ol[class] {
  list-style: none;
}

a:not([class]) {
  text-decoration-skip-ink: auto;
}

img {
  max-width: 100%;
  display: block;
}

article > * + * {
  margin-top: 1em;
}

input,
button,
textarea,
select {
  font: inherit;
}

@media (prefers-reduced-motion: reduce) {
  * {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}

/* end reset */

body {
  background: var(--clr-neutral-1);
  color: var(--clr-primary-1);
  display: grid;
  grid-template-columns: 1fr;
  font-family: var(--ff-primary-serif);
  font-weight: var(--fw-400);
  font-size: var(--fs-400);
}

ul {
  line-height: 1.3;
}

li:not(:last-child) {
  padding-bottom: var(--s-small);
}

li:last-child {
  padding-bottom: var(--s-normal);
}

main {
  width: 100%;
  background: var(--clr-neutral-2);
  min-width: 16rem;
  max-width: calc(100% - var(--s-xx-large));
  margin-inline: auto;
  padding: var(--s-3x-large);
  padding-top: var(--s-xx-large);
  margin-top: var(--s-xx-large);
  margin-bottom: var(--s-xx-large);
  border-radius: 0.375rem;
  display: grid;
  grid-template-columns: 1fr;
}

h1 {
  font-family: var(--ff-primary-sans);
  /*font-family: IbbaraRealNova;*/
  font-weight: var(--fw-900);
  font-size: var(--fs-700);
  margin-bottom: var(--v-pad);
  margin-right: auto;
  letter-spacing: -0.04rem;
}

.heading {
  display: flex;
  flex-direction: row;
  justify-content: flex-start;
}

.section-label {
  font-family: var(--ff-primary-sans);
  font-weight: var(--fw-600);
  font-size: var(--fs-500); 
  margin-block: 1rem;
  /*text-align: center;*/
}

.contact-info {
  display: grid;
  grid-template-columns: repeat(1.5rem 1fr);
  width: fit-content;
  margin-top: 0;
  padding-top: 0;
  --top-icon: 0.125rem;
  --icon-w: 1.25rem;
  --icon-h: 1.25rem;
}

.contact-element {
  position: relative;
}

.contact-element[data-contact-source="email"]::before {
  content: "";
  background-image: url("envelope-open-text-solid.svg");
  position: absolute;
  height: var(--icon-h);
  width: var(--icon-w);
  top: 0.25rem;
  left: -1.375rem;

}
.contact-element[data-contact-source="linkedin"]::before {
  content: "";
  background-image: url("linkedin-solid-fa.svg");
  position: absolute;
  /*height: 1.125rem;*/
  /*width: 1rem;*/
  height: var(--icon-h);
  width: var(--icon-w);
  top: 0.25rem;
  left: -1.375rem;
  background-size: cover;
}

.contact-element[data-contact-source="github"]::before {
  content: "";
  background-image: url("github-circle-outline.svg");
  position: absolute;
  height: var(--icon-h);
  width: var(--icon-w);
  top: 0.25rem;
  left: -1.375rem;
}
 
.contact-element[data-contact-source="exercism"]::before {
  content: "";
  background-image: url("logo-exercism.svg");
  position: absolute;
  /*height: 1.125rem;*/
  /*width: 1rem;*/
  height: var(--icon-h);
  width: 1.5rem;
  top: 0.25rem;
  left: -1.375rem;
  background-size: cover;
}
.contact-element[data-contact-source="frontendmentor"]::before,
.contact-element[data-contact-source="cssbattle"]::before {
  content: "";
  background-image: url("code.svg");
  position: absolute;
  /*height: 1.125rem;*/
  /*width: 1rem;*/
  height: var(--icon-h);
  width: 1.25rem;
  top: 0.25rem;
  left: -1.375rem;
  background-size: cover;
}

.contact-element[data-contact-source="tryhackme"]::before, 
.contact-element[data-contact-source="pentesterlabs"]::before {
  content: "";
  background-image: url("terminal.svg");
  position: absolute;
  /*height: 1.125rem;*/
  /*width: 1rem;*/
  height: var(--icon-h);
  width: 1.25rem;
  top: 0.25rem;
  left: -1.375rem;
  background-size: cover;
}

.contact-link {
  display: flex;
  align-content: center;
  font-size: var(--fs-extra-small);
  text-decoration: none;
  font-family: var(--ff-primary-sans);
  padding-top: 0.125rem;
  padding-bottom: 0.125rem;
}

.contact-element {
  /*display: flex;*/
  /*flex-direction: column;*/
  /*position: relative;*/
}

.contact-logo {
  width: 1.25rem;
  height: 1.25rem;
  display: inline;
}

.contact-display {
  display: inline;
  margin-left: 0.25rem;
}

.skills ul {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  /*width: calc(100% - var(--s-normal));*/
  margin-inline: auto;
  padding-inline: 0;
  /*display: flex;*/
  /*flex-direction: column;*/
  /*align-items: start;*/
  /*flex-wrap: wrap;*/
  /*max-height: 3em;*/
}

.skills li {
  padding: 0;
  margin-inline: auto;
}

.skills li::marker {
  content: '';
}

.position-header {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  padding-bottom: var(--s-350);
}

.position-list {
  display: grid;
  grid-template-columns: 1fr;
}

.company {
  font-family: var(--ff-primary-sans);
  font-weight: var(--fw-500);
}

.position-title {
  font-size: var(--fs-extra-small);
  grid-column-start: 1;
  grid-row-start: 2;
  grid-column-end: 3;
}

.time-period {
  font-size: var(--fs-extra-small);
  margin-inline-start: auto;
}

.location {
  font-style: italic;
  font-size: var(--fs-small);
  margin-inline: auto;
}

@media (max-width: 26.5rem) {
  a.contact-link {
    display: flex;
    flex-direction: row;
    flex-wrap: row; 
    font-size: var(--fs-xx-small);
  }

  .heading {
    flex-direction: column;
  }

  article {
    padding-inline: var(--s-normal);
  }

  main {
    width: unset;
  }
}

