@import url('https://fonts.googleapis.com/css2?family=Hanken+Grotesk:ital,wght@0,200;0,300;0,400;0,700;1,300&display=swap');

:root {
  --body-bg: #383b3c;
  --body-color: #999999;
  --link-color: #3291ba;
  --link-color-hover: #c5b85b;
  --link-color-visited: #89a97d;
  --sep: 0.5rem;
  --nav-sep: 3rem;
  --nav-left-margin: 2rem;
  --main-left-margin: 1.5rem;
  --nav-top-margin: 3rem;
  --nav-width: 2rem;
}

.logo-white {
  fill: white;
}

@media (prefers-color-scheme: light) {
  :root {
    --body-bg: #f8f9f9;
    --body-color: #383b3c;
  }

  .logo-white {
    fill: #383b3c;
  }
}

html {
  background: var(--body-bg);
}

body {
  background: var(--body-bg);
  color: var(--body-color);
  --element-color: var(--body-color);
  font-family: 'Hanken Grotesk', sans-serif;
  font-weight: 300;
}

body i {
  font-style: italic;
}

::selection {
  background: var(--element-color);
  color: var(--body-bg);
}

nav {
  position: fixed;
  top: 0;
  left: 0;
  margin-left: calc(var(--nav-left-margin) - var(--nav-sep) / 8);
  margin-top: calc(3 * var(--nav-sep) / 4);
  display: inline-flex;
  z-index: 999;
}

nav ul li {
  margin-top: calc(var(--nav-sep) / 4);
  margin-bottom: calc(var(--nav-sep) / 4);
}

nav ul li a {
  height: 100%;
  display: inline-block;

  padding-top: calc(var(--nav-sep) / 8);
  padding-bottom: calc(var(--nav-sep) / 8);

  padding-left: calc(var(--nav-sep) / 8);
  padding-right: calc(var(--nav-sep) / 8);
}

nav ul li a {
  color: #ca656c70;
  --element-color: #ca656c70;
}

nav ul li svg {
  height: 2rem;
  padding: 0;
  vertical-align: middle;
  margin-right: 0.5rem;
}

nav ul li svg:not(.strokeit) {
  fill: #ca656c70;
}

nav ul li svg.strokeit {
  stroke: #ca656c70;
}

nav ul li a span {
  display: none;
  vertical-align: middle;
  font-weight: 200;
  background: var(--body-bg);
  height: 100%;
  padding-right: calc(var(--nav-sep) / 8);
  align-items: center;
}

nav ul li.selected svg:not(.strokeit) {
  fill: #ca656c;
}

nav ul li.selected svg.strokeit {
  stroke: #ca656c;
}

nav ul li.selected a {
  color: #ca656c;
  --element-color: #ca656c;
}

nav ul li a:visited {
  color: inherit;
  text-decoration: inherit;
}

nav ul li a:hover {
  color: #ff6c87;
  --element-color: #ff6c87;
  text-decoration: inherit;

  box-shadow: 0rem 0rem 0.5rem 0.2rem #282828;
  background: var(--body-bg);
}

nav ul li a:hover svg:not(.strokeit) {
  fill: #ff6c87;
}

nav ul li a:hover svg.strokeit {
  stroke: #ff6c87;
}

nav ul li a:hover span {
  display: inline-flex;
}

nav:hover ~ main:not(:hover) {
  filter: blur(0.1rem);
}

main {
  margin-left: calc(var(--nav-left-margin) + var(--nav-width) + var(--main-left-margin));
  transition: 0.1s filter linear;
}

main a {
  color: var(--link-color);
  --element-color: var(--link-color);
  text-decoration: none;
  font-style: italic;
}

main a:visited {
  color: var(--link-color-visited);
  --element-color: var(--link-color-visited);
}

main a:visited::selection {
  /* weird bug */
  background: var(--link-color-visited);
}

main a:hover {
  color: var(--link-color-hover);
  /*--element-color: var(--link-color-hover);*/
  font-style: normal;
}

main section h1 {
  position: -webkit-sticky;
  position: sticky;
  top: 0px;
  margin: 0;
  font-size: 2rem;
  padding-bottom: 0.414em;
  font-weight: bold;
  padding-top: var(--sep);
  margin-top: var(--sep);
  margin-bottom: var(--sep) / 2;
  background: var(--body-bg);
  background: linear-gradient(180deg, var(--body-bg) 0%, var(--body-bg) 70%, rgba(0,0,0,0) 100%);
  color: #51b4a9;
  --element-color: #51b4a9;
}

main section h1 b {
  color: #60d4c8;
  --element-color: #60d4c8;
}

main section h1 svg {
  height: 2rem;
}

#spotify h1 svg, #snap h1 svg {
  height: 2.75rem;
}

main {
  z-index: 1;
}

main p {
  margin-bottom: 1rem;
}

main p {
  line-height: 1.2em;
}

main h2 {
  font-size: 1.5rem;
  padding-bottom: 0.414em;
  font-style: bold;
}

.role:first-child h1 {
  margin-top: 0;
}

main section .desc {
  margin-left: calc(3 * var(--sep));
}

@media (max-width: 430px) {
  nav {
    top: 0;
    position: relative;
    width: 100vw;
    margin: 0;
    display: block;
  }

  nav ul {
    position: relative;
    text-align: center;
    display: block;
  }

  nav ul li {
    display: inline-block;
    width: auto;
    vertical-align: top;
  }

  nav ul li a span {
    align-items: unset;
    padding-right: 0;
  }

  nav ul li svg {
    margin-right: 0;
  }

  nav ul li a:hover span {
    display: none;
  }

  nav:hover ~ main:not(:hover) {
    filter: unset;
  }

  main {
    margin-left: 1rem;
    margin-right: 1rem;
  }
}
