@font-face {
  font-family: 'Electrolize';
  src: url('fonts/electrolize.woff2') format('woff2');
  font-display: swap;
}

@font-face {
  font-family: 'Roboto';
  src: url('fonts/roboto.woff2') format('woff2');
  font-display: swap;
}

:root {
  color-scheme: light dark;

  --background-color: light-dark(#f1f1f1, #2c2c2c);
  --page-color: light-dark(#ffffff, #1a1a1a);

  --h1-color: light-dark(#000000, #ffffff);
  --h2-color: light-dark(#184f6e, #dbdbdb);
  --h3-color: light-dark(#303236, #ffffff);
  --divider-color: light-dark(#cccccc, #404040);

  --link-color: light-dark(#0b5796, #78bbff);
  --email-color: light-dark(#ce2b2b, #ff6b6b);
  --discord-color: light-dark(#7289da, #747ccf);
  --github-color: light-dark(#333333, #ffffff);
  --linkedin-color: light-dark(#0077b5, #0077b5);

  --link-secondary-color: light-dark(#ffffff, #1a1a1a);
  --github-secondary-color: light-dark(#ffffff, #1a1a1a);

  --body-padding: 3rem;
  --body-gap: 2rem;

  --main-gap: 2rem;

  --project-article-gap: 2rem;

  --project-image-size: 8rem;
  --project-image-radius: 2rem;
}

@media (width <= 600px) {
  :root {
    --body-padding: 2rem;
    --project-image-size: 6rem;
    --project-article-gap: 1rem;
  }
}

@media (width <= 500px) {
  :root {
    --body-padding: 1rem;
    --project-image-size: 6rem;
  }
}

@media (width <= 400px) {
  :root {
    --project-image-size: 4rem;
    --project-image-radius: 1rem;
  }
}

* {
  margin: 0;
  padding: 0;
  transition: all 0.2s ease-in-out;
  transition-property: padding, max-width, border-radius, gap, opacity;
}

html {
  height: 100%;
  background-color: var(--background-color);
  font-size: 100%;
}

body {
  min-height: 100%;
  display: flex;
  flex-direction: column;
  gap: var(--body-gap);
  max-width: 800px;
  margin: auto;
  padding: var(--body-padding);
  font-family: 'Roboto', sans-serif;
  font-size: 1rem;
  background-color: var(--page-color);
  box-sizing: border-box;
}

h1 {
  color: var(--h1-color);
  font-family: 'Electrolize', sans-serif;
  font-size: 2.5rem;
}

h2 {
  color: var(--h2-color);
  font-family: 'Electrolize', sans-serif;
  font-size: 2rem;
}

h3 {
  color: var(--h3-color);
  font-family: 'Electrolize', sans-serif;
  font-size: 1.5rem;
}

a {
  text-decoration: none;
}

p {
  line-height: 1.5;
}

.filler {
  flex: 1;
}

.divider {
  width: 100%;
  height: 0;
  border-bottom: thin solid var(--divider-color);
}

header {
  display: flex;
  flex-direction: row;
  gap: 2rem;
}

#header-details {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.contact-links {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  background: var(--background-color);
  padding: 1rem;
  border-radius: 1rem;
}

.contact-link {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 0.5rem;
}

.contact-link a {
  color: var(--link-color);
}

.contact-link a:hover {
  border-bottom: thin solid var(--link-color);
}

.icon {
  display: inline-block;
  width: 1.2rem;
  height: 1.2rem;
  mask-size: contain;
  mask-repeat: no-repeat;
  mask-position: center;
}

.icon.link {
  background-color: var(--link-color);
  mask-image: url('icons/solid/link.svg');
}

.icon.link.secondary {
  background-color: var(--link-secondary-color);
}

.icon.email {
  background-color: var(--email-color);
  mask-image: url('icons/solid/at.svg');
}

.icon.discord {
  background-color: var(--discord-color);
  mask-image: url('icons/brands/discord.svg');
}

.icon.github {
  background-color: var(--github-color);
  mask-image: url('icons/brands/github.svg');
}

.icon.github.secondary {
  background-color: var(--github-secondary-color);
}

.icon.linkedin {
  background-color: var(--linkedin-color);
  mask-image: url('icons/brands/linkedin.svg');
}

#profile-picture {
  width: 100%;
  max-width: 12rem;
  object-fit: cover;
}

#profile-picture img {
  width: 100%;
  height: 100%;
  border-radius: 6rem;
}

main {
  display: flex;
  flex-direction: column;
  gap: var(--main-gap);
}

main section {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.projects {
  display: flex;
  flex-direction: column;
  gap: 2rem;
}

.project-article {
  display: flex;
  flex-direction: row;
  gap: var(--project-article-gap);
}

.project-image {
  width: var(--project-image-size);
  height: var(--project-image-size);
  border-radius: var(--project-image-radius);
}

.project-details {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.project-links {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.project-link {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 0.5rem;
  padding: 0.8rem;
  border-radius: 0.8rem;
}

.project-link:hover {
  opacity: 0.9;
}

.project-link.github {
  background-color: var(--github-color);
  color: var(--github-secondary-color);
}

.project-link.link {
  background-color: var(--link-color);
  color: var(--link-secondary-color);
}
