:root {
  --top-nav-height: 51px;
  --border-color: #dce6e9;
}

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

body {
  font-family: ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont,
    'Segoe UI', Roboto, 'Helvetica Neue', Arial, 'Noto Sans', sans-serif,
    'Apple Color Emoji', 'Segoe UI Emoji', 'Segoe UI Symbol', 'Noto Color Emoji';
  color: rgba(60, 66, 87, 1);
  margin: 0;
}

p {
  line-height: 1.5em;
}


h1 {
  font-size: 40px;
}

h2 {
  margin: 1.5em 0;
}

a {
  color: rgba(75, 85, 99, 1);
}

/* 
  Callout
*/

.callout {
  display: flex;
  flex-direction: column;
  padding: 12px 16px;
  background: #f6f9fc;
  border: 1px solid #dce6e9;
  border-radius: 4px;
}
.callout :global(p) {
  margin: 0;
}

/*
  Code
*/

.code {
  position: relative;
}
/* Override Prism styles */
.code :global(pre[class*="language-"]) {
  text-shadow: none;
  border-radius: 4px;
}

/*
  Sidenav
*/

nav.sidenav {
  position: sticky;
  top: var(--top-nav-height);
  height: calc(100vh - var(--top-nav-height));
  flex: 0 0 auto;
  overflow-y: auto;
  padding: 2.5rem 2rem 2rem;
  border-right: 1px solid var(--border-color);
}
.sidenav span {
  font-size: larger;
  font-weight: 500;
  padding: 0.5rem 0 0.5rem;
}
.sidenav ul {
  padding: 0;
}
.sidenav li {
  list-style: none;
  margin: 0;
}
.sidenav li a {
  text-decoration: none;
}
.sidenav li a:hover,
.sidenav li.active > a {
  text-decoration: underline;
}

/*
  Top Nav
*/

nav.topnav {
  top: 0;
  position: fixed;
  width: 100%;
  z-index: 100;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1rem 2rem;
  background: white;
  border-bottom: 1px solid var(--border-color);
}
nav.topnav :global(a) {
  text-decoration: none;
}

.topnav section {
  display: flex;
  gap: 1rem;
  padding: 0;
}