/* Syntax highlighting */
.highlight {
  background: var(--neutral-1);
  border-radius: var(--border-radius);
  padding: calc(var(--baseline) * 6);
  /* Comment */
  /* Keyword */
  /* Operator */
  /* Comment.Multiline */
  /* Comment.Preproc */
  /* Comment.Single */
  /* Comment.Special */
  /* Generic.Deleted */
  /* Generic.Emph */
  /* Generic.Error */
  /* Generic.Heading */
  /* Generic.Inserted */
  /* Generic.Output */
  /* Generic.Prompt */
  /* Generic.Strong */
  /* Generic.Subheading */
  /* Generic.Traceback */
  /* Keyword.Constant */
  /* Keyword.Declaration */
  /* Keyword.Namespace */
  /* Keyword.Pseudo */
  /* Keyword.Reserved */
  /* Keyword.Type */
  /* Literal.Number */
  /* Literal.String */
  /* Name.Attribute */
  /* Name.Builtin */
  /* Name.Class */
  /* Name.Constant */
  /* Name.Decorator */
  /* Name.Entity */
  /* Name.Exception */
  /* Name.Function */
  /* Name.Label */
  /* Name.Namespace */
  /* Name.Tag */
  /* Name.Variable */
  /* Operator.Word */
  /* Text.Whitespace */
  /* Literal.Number.Bin */
  /* Literal.Number.Float */
  /* Literal.Number.Hex */
  /* Literal.Number.Integer */
  /* Literal.Number.Oct */
  /* Literal.String.Affix */
  /* Literal.String.Backtick */
  /* Literal.String.Char */
  /* Literal.String.Delimiter */
  /* Literal.String.Doc */
  /* Literal.String.Double */
  /* Literal.String.Escape */
  /* Literal.String.Heredoc */
  /* Literal.String.Interpol */
  /* Literal.String.Other */
  /* Literal.String.Regex */
  /* Literal.String.Single */
  /* Literal.String.Symbol */
  /* Name.Builtin.Pseudo */
  /* Name.Function.Magic */
  /* Name.Variable.Class */
  /* Name.Variable.Global */
  /* Name.Variable.Instance */
  /* Name.Variable.Magic */
  /* Literal.Number.Integer.Long */
}
.highlight pre {
  background: transparent;
  padding: 0;
  margin: 0;
  border-radius: 0;
  font-size: 1rem;
  line-height: 1.4;
}
.highlight .c {
  color: var(--neutral-6);
  font-style: italic;
}
.highlight .k {
  color: var(--primary-8);
  font-weight: bold;
}
.highlight .o {
  color: var(--neutral-7);
}
.highlight .cm {
  color: var(--neutral-6);
  font-style: italic;
}
.highlight .cp {
  color: var(--secondary-6);
}
.highlight .c1 {
  color: var(--neutral-6);
  font-style: italic;
}
.highlight .cs {
  color: var(--neutral-6);
  font-style: italic;
}
.highlight .gd {
  color: var(--red);
}
.highlight .ge {
  font-style: italic;
}
.highlight .gr {
  color: var(--red);
}
.highlight .gh {
  color: var(--primary-8);
  font-weight: bold;
}
.highlight .gi {
  color: var(--tertiary-6);
}
.highlight .go {
  color: var(--neutral-5);
}
.highlight .gp {
  color: var(--primary-8);
  font-weight: bold;
}
.highlight .gs {
  font-weight: bold;
}
.highlight .gu {
  color: var(--secondary-6);
  font-weight: bold;
}
.highlight .gt {
  color: var(--blue);
}
.highlight .kc {
  color: var(--primary-8);
  font-weight: bold;
}
.highlight .kd {
  color: var(--primary-8);
  font-weight: bold;
}
.highlight .kn {
  color: var(--primary-8);
  font-weight: bold;
}
.highlight .kp {
  color: var(--primary-8);
}
.highlight .kr {
  color: var(--primary-8);
  font-weight: bold;
}
.highlight .kt {
  color: var(--tertiary-8);
}
.highlight .m {
  color: var(--secondary-8);
}
.highlight .s {
  color: var(--secondary-6);
}
.highlight .na {
  color: var(--tertiary-6);
}
.highlight .nb {
  color: var(--primary-6);
}
.highlight .nc {
  color: var(--primary-8);
  font-weight: bold;
}
.highlight .no {
  color: var(--secondary-6);
}
.highlight .nd {
  color: var(--secondary-6);
}
.highlight .ni {
  color: var(--neutral-6);
  font-weight: bold;
}
.highlight .ne {
  color: var(--red);
  font-weight: bold;
}
.highlight .nf {
  color: var(--primary-8);
}
.highlight .nl {
  color: var(--yellow);
}
.highlight .nn {
  color: var(--primary-8);
  font-weight: bold;
}
.highlight .nt {
  color: var(--primary-6);
  font-weight: bold;
}
.highlight .nv {
  color: var(--neutral-8);
}
.highlight .ow {
  color: var(--secondary-6);
  font-weight: bold;
}
.highlight .w {
  color: var(--neutral-4);
}
.highlight .mb {
  color: var(--secondary-8);
}
.highlight .mf {
  color: var(--secondary-8);
}
.highlight .mh {
  color: var(--secondary-8);
}
.highlight .mi {
  color: var(--secondary-8);
}
.highlight .mo {
  color: var(--secondary-8);
}
.highlight .sa {
  color: var(--secondary-6);
}
.highlight .sb {
  color: var(--secondary-6);
}
.highlight .sc {
  color: var(--secondary-6);
}
.highlight .dl {
  color: var(--secondary-6);
}
.highlight .sd {
  color: var(--secondary-6);
}
.highlight .s2 {
  color: var(--secondary-6);
}
.highlight .se {
  color: var(--secondary-6);
}
.highlight .sh {
  color: var(--secondary-6);
}
.highlight .si {
  color: var(--secondary-6);
}
.highlight .sx {
  color: var(--secondary-6);
}
.highlight .sr {
  color: var(--secondary-6);
}
.highlight .s1 {
  color: var(--secondary-6);
}
.highlight .ss {
  color: var(--secondary-6);
}
.highlight .bp {
  color: var(--primary-6);
}
.highlight .fm {
  color: var(--primary-8);
}
.highlight .vc {
  color: var(--neutral-8);
}
.highlight .vg {
  color: var(--neutral-8);
}
.highlight .vi {
  color: var(--neutral-8);
}
.highlight .vm {
  color: var(--neutral-8);
}
.highlight .il {
  color: var(--secondary-8);
}
@view-transition {
  navigation: auto;
}
/* palette */
:root {
  --primary-base: #3167cd;
  --primary-1: #E6EAF2;
  --primary-2: #D9E3F3;
  --primary-3: #C9DBF8;
  --primary-4: #B7D0FA;
  --primary-5: #A2C1F7;
  --primary-6: #1A3D7E;
  --primary-7: #2B4F92;
  --primary-8: #2F5EB6;
  --primary-9: #0D2F6F;
  --secondary-base: #94651e;
  --secondary-1: #FFD6A1;
  --secondary-2: #FDC987;
  --secondary-3: #ECBC7E;
  --secondary-4: #D9AC74;
  --secondary-5: #C69453;
  --secondary-6: #94651E;
  --secondary-7: #865808;
  --secondary-8: #8A5C11;
  --secondary-9: #473928;
  --tertiary-base: #1a7e2f;
  --tertiary-1: #C8E1C9;
  --tertiary-2: #B5D8B6;
  --tertiary-3: #9DCDA0;
  --tertiary-4: #7DBD82;
  --tertiary-5: #4BA857;
  --tertiary-6: #1A7E2F;
  --tertiary-7: #006F20;
  --tertiary-8: #006E1E;
  --tertiary-9: #1E3D21;
  --neutral-base: #F5F2ED;
  --neutral-1: #ECEAE8;
  --neutral-2: #E3E0DB;
  --neutral-3: #DBD7CF;
  --neutral-4: #D2CEC7;
  --neutral-5: #C8C4BD;
  --neutral-6: #7C7972;
  --neutral-7: #706C65;
  --neutral-8: #57534D;
  --neutral-9: #141210;
  --white: #FFFFFF;
  --black: #000000;
  --green: #00C899;
  --blue: #3DBFE2;
  --red: #EB7F9B;
  --yellow: #FFC76B;
}
.dark-mode {
  --social-icon-filter: invert(1) brightness(0.8);
  --primary-base: #669cff;
  --primary-1: #151C29;
  --primary-2: #161F2F;
  --primary-3: #162B52;
  --primary-4: #15336C;
  --primary-5: #1A3D7E;
  --primary-6: #030303;
  --primary-7: #3768C5;
  --primary-8: #84B5FF;
  --primary-9: #CFE2FF;
  --secondary-base: #94651e;
  --secondary-1: #1E170F;
  --secondary-2: #311F06;
  --secondary-3: #432500;
  --secondary-4: #512E00;
  --secondary-5: #5F3C00;
  --secondary-6: #94651E;
  --secondary-7: #865808;
  --secondary-8: #FECA87;
  --secondary-9: #FFE2B1;
  --tertiary-base: #1a7e2f;
  --tertiary-1: #0B140B;
  --tertiary-2: #162B18;
  --tertiary-3: #123D18;
  --tertiary-4: #154B1E;
  --tertiary-5: #195B24;
  --tertiary-6: #1A7E2F;
  --tertiary-7: #1D6D2C;
  --tertiary-8: #74D07D;
  --tertiary-9: #AEF7B3;
  --neutral-base: #1C1C1A;
  --neutral-1: #232321;
  --neutral-2: #2C2C28;
  --neutral-3: #32322F;
  --neutral-4: #383835;
  --neutral-5: #40403D;
  --neutral-6: #5a5a57;
  --neutral-7: #50504d;
  --neutral-8: #B4B4B0;
  --neutral-9: #EDEDE9;
  --white: #FFFFFF;
  --black: #000000;
  --page-bg: var(--neutral-base);
  --text-color: var(--neutral-9);
  --link-color: var(--primary-base);
}
:root {
  --bg: url('../../media/backgrounds/futuristic-city.webp');
  --page-margin: 8vmin;
  --page-width: 1440px;
  --entry-width: 95ch;
  --navbar-height: 36px;
  --navbar-hover-bg: linear-gradient(to bottom, rgba(255, 255, 255, 0.3), transparent);
  --border-radius: 3px;
  --cards-gap: 1rem;
  --featured-image-height: 40vmin;
  --gallery-gap: 0.5rem;
  --magic-number: 4rem;
  --baseline: 0.25rem;
  --font-body: 'Instrument Sans', sans-serif;
  --font-heading: 'Bricolage Grotesque', serif;
  --font-monospace: 'Cascadia Code', monospace;
  --font-logo: var(--font-body);
  --font-menu: var(--font-body);
  --font-size: clamp(1rem, 1rem + 0.15vw, 1.15rem);
  --font-weight-normal: 400;
  --font-weight-bold: 700;
  --line-height: 1.6;
  --letter-spacing: 0em;
  --headings-weight: 700;
  --headings-transform: none;
  --headings-style: normal;
  --headings-letter-spacing: -0.03em;
  --headings-line-height: 1.2;
  --card-image-height: calc(12rem + 13vmin);
  --page-bg: var(--neutral-base);
  --text-color: var(--neutral-9);
  --link-color: var(--primary-base);
  --monospace: var(--font-monospace);
  --box-shadow: 0px 4.4px 4.5px -100px oklch(from #000 l c h / 0.174), 0px 12.3px 12.5px -100px oklch(from #000 l c h / 0.25), 0px 29.5px 30.1px -100px oklch(from #000 l c h / 0.326), 0px 98px 100px -100px oklch(from #000 l c h / 0.5);
  --box-shadow-hover: 0px 5.4px 4.5px -100px oklch(from #000 l c h / 0.174), 0px 15px 12.5px -100px oklch(from #000 l c h / 0.25), 0px 36.2px 30.1px -100px oklch(from #000 l c h / 0.326), 0px 120px 100px -100px oklch(from #000 l c h / 0.5);
}
@media screen and (max-width: 800px) {
  :root {
    --navbar-height: 40px;
  }
}
@media all and (min-width: 56.25em) {
  :root {
    --magic-number: 6rem;
  }
}
@media all and (min-width: 80.0625em) and (min-height: 50em) {
  :root {
    --cards-gap: 1.8rem;
    --magic-number: 8rem;
  }
}
*,
:after,
:before {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}
article,
aside,
footer,
header,
hgroup,
main,
nav,
section {
  display: block;
}
li {
  list-style: none;
}
img {
  height: auto;
  max-width: 100%;
  vertical-align: top;
}
button,
input,
select,
textarea {
  font: inherit;
}
address {
  font-style: normal;
}
::-moz-selection {
  background: var(--link-color);
  color: var(--white);
}
::selection {
  background: var(--link-color);
  color: var(--white);
}
::placeholder {
  color: var(--text-color);
}
html {
  font-size: var(--font-size);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  scroll-behavior: smooth;
}
html.no-scroll {
  overflow: hidden;
}
body {
  background: var(--page-bg);
  color: var(--text-color);
  font-family: var(--font-body);
  font-variation-settings: "wght" var(--font-weight-normal);
  letter-spacing: var(--letter-spacing);
  line-height: var(--line-height);
  /* min-height: 100vh; */
  padding: 0;
  overscroll-behavior: none;
  transition: 0.3s ease-out background;
}
body::before {
  content: '';
  position: absolute;
  inset: 0;
  background: var(--bg);
  background-size: cover;
  z-index: -2;
}
body.error-template::before {
  background: url('../../media/backgrounds/ohnoes.jpg');
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  background-color: #000;
  mask-image: unset!important;
  filter: unset!important;
  position: fixed;
}
body.home-template::before {
  mask-image: linear-gradient(to bottom, rgba(0, 0, 0, 0.4) 25%, transparent);
}
.dark-mode body.home-template::before {
  mask-image: linear-gradient(to bottom, rgba(0, 0, 0, 0.4), transparent) !important;
}
body:not(.home-template)::before {
  mask-image: linear-gradient(to bottom, rgba(0, 0, 0, 0.2) 75%, transparent);
  filter: blur(5px);
}
body::after {
  content: '';
  position: absolute;
  z-index: -1;
  /* frosted glass texture found the website you'd least expect; thank you https://www.microsoft.com/en-us/edge/welcome ! */
  background: url('../../media/backgrounds/frosted-texture.png');
  background-repeat: repeat;
  background-size: 200px 200px;
  inset: 0;
  opacity: 0.1;
  mask-image: linear-gradient(to bottom, black 75%, transparent);
}
a {
  color: var(--link-color);
  text-decoration: none;
  transition: all 0.12s linear;
}
.img-invert {
  filter: invert(1);
}
.dark-mode .img-invert {
  filter: unset;
}
.dark-mode .img-invert-dark {
  filter: invert(1);
}
dl,
ol,
p,
pre,
ul {
  margin-top: calc(var(--baseline) * 7);
}
blockquote,
figure,
hr,
pre,
table {
  margin-top: calc(var(--baseline) * 9);
  margin-bottom: calc(var(--baseline) * 9);
}
h1,
h2,
h3,
h4,
h5,
h6 {
  color: var(--text-color);
  font-family: var(--font-heading);
  font-variation-settings: "wght" var(--headings-weight);
  font-style: var(--headings-style);
  hyphens: manual;
  letter-spacing: var(--headings-letter-spacing);
  line-height: var(--headings-line-height);
  margin-top: calc(var(--baseline) * 11);
  text-transform: var(--headings-transform);
  scroll-margin-top: 60px;
}
.h1,
h1 {
  font-size: clamp(1.80203247rem, calc(1.80203247rem + 0.76375204 * (100vw - 20rem) / 80), 2.56578451rem);
}
.h2,
h2 {
  font-size: clamp(1.42382813rem, calc(1.42382813rem + 0.6034584 * (100vw - 20rem) / 80), 2.02728653rem);
}
.h3,
h3 {
  font-size: clamp(1.265625rem, calc(1.265625rem + 0.53640747 * (100vw - 20rem) / 80), 1.80203247rem);
}
.h4,
h4 {
  font-size: clamp(1.125rem, calc(1.125rem + 0.29882813 * (100vw - 20rem) / 80), 1.42382813rem);
}
.h5,
h5 {
  font-size: clamp(1rem, calc(1rem + 0.265625 * (100vw - 20rem) / 80), 1.265625rem);
}
.h6,
h6 {
  font-size: clamp(1rem, calc(1rem + 0.125 * (100vw - 20rem) / 80), 1.125rem);
}
h1 + *,
h2 + *,
h3 + *,
h4 + *,
h5 + *,
h6 + * {
  margin-top: calc(var(--baseline) * 4);
}
b,
strong {
  font-variation-settings: "wght" var(--font-weight-bold);
}
blockquote {
  box-sizing: content-box;
  margin-left: auto;
  margin-right: auto;
  max-width: 80%;
  padding: calc(var(--baseline) * 22) 0 calc(var(--baseline) * 12);
  position: relative;
  font-size: clamp(1.265625rem, calc(1.265625rem + 0.15820313 * (100vw - 20rem) / 80), 1.42382813rem);
}
@media all and (min-width: 37.5em) {
  blockquote {
    max-width: 60%;
  }
}
blockquote::before {
  color: var(--primary-base);
  content: "“";
  font: var(--font-weight-normal) 720%/0.9 Georgia, Times, Times New Roman, serif;
  left: -15%;
  position: absolute;
  top: calc(var(--baseline) * 11);
}
@media all and (min-width: 37.5em) {
  blockquote::before {
    left: -20%;
  }
}
blockquote > :first-child {
  margin-top: 0;
}
ol,
ul {
  margin-left: 3ch;
}
ol > li,
ul > li {
  list-style: inherit;
  padding: 0 0 calc(var(--baseline) * 2) 1ch;
}
ol ol,
ul ol,
ol ul,
ul ul {
  margin-bottom: calc(var(--baseline) * 2);
  margin-top: calc(var(--baseline) * 2);
}
dl dt {
  font-variation-settings: "wght" var(--font-weight-bold);
}
code {
  background-color: oklch(from var(--primary-base) l c h / 0.1);
  border-radius: 3px;
  color: var(--primary-8);
  font-size: 1rem;
  font-family: var(--monospace);
  padding: 0.25rem 0.5rem;
}
pre {
  background-color: var(--neutral-1);
  border-radius: var(--border-radius);
  font-size: 1rem;
  max-height: var(--pre-height);
  padding: calc(var(--baseline) * 6);
  white-space: pre-wrap !important;
  word-wrap: break-word;
  width: 100%;
}
pre code {
  background-color: transparent;
  color: inherit !important;
  font-size: inherit;
  padding: 0;
}
table {
  border: 1px solid var(--neutral-2);
  border-left: none;
  border-collapse: collapse;
  border-spacing: 0;
  vertical-align: top;
  text-align: left;
  width: 100%;
  overflow-wrap: normal;
}
table th {
  font-variation-settings: "wght" var(--font-weight-bold);
  padding: calc(var(--baseline) * 2.5) calc(var(--baseline) * 4);
}
table td {
  border-top: 1px solid var(--black);
  border-left: 1px solid var(--black);
  padding: calc(var(--baseline) * 2.5) calc(var(--baseline) * 4);
}
figcaption {
  color: var(--neutral-6);
  font-family: var(--font-body);
  font-variation-settings: "wght" var(--font-weight-normal);
  font-size: 0.79012346rem;
  margin-top: calc(var(--baseline) * 4);
  text-align: center;
}
kbd {
  background: var(--neutral-9);
  border-radius: 3px;
  color: var(--white);
  font-family: var(--monospace);
  font-size: 0.8888em;
  padding: 0.125rem 0.375rem;
}
sub,
sup {
  font-size: 65%;
}
small {
  font-size: 0.79012346rem;
}
.separator,
hr {
  background: 0 0;
  border: none;
  height: auto;
  line-height: 1;
  max-width: none;
  text-align: center;
}
.separator::before,
hr::before {
  content: "***";
  color: var(--neutral-9);
  font-size: 1.265625rem;
  font-variation-settings: "wght" var(--font-weight-bold);
  letter-spacing: 1.265625rem;
  padding-left: 1.265625rem;
}
.separator--dot::before,
hr.separator--dot::before {
  content: "*";
  color: var(--neutral-9);
  font-size: 1.265625rem;
  font-variation-settings: "wght" var(--font-weight-bold);
  letter-spacing: 1.265625rem;
  padding-left: 1.265625rem;
}
.separator--long-line {
  position: relative;
}
.separator--long-line::before {
  content: "";
  height: 1.265625rem;
}
.separator--long-line::after {
  border-top: 1px solid var(--neutral-2);
  content: "";
  height: 1px;
  position: absolute;
  width: 100%;
  top: 50%;
  left: 0;
}
.btn,
[type=button],
[type=submit],
button {
  background: linear-gradient(to bottom, oklch(0.6653 0.2227 260), oklch(0.4724 0.1604 260));
  box-shadow: 0 8px 20px -3px oklch(from #000 l c h / 0.12);
  border: 1px solid oklch(0.4724 0.1604 260);
  color: #fff;
  cursor: pointer;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  gap: 5px;
  font: normal 600 0.88888889rem var(--font-body);
  padding: 0.5rem 0.75rem;
  vertical-align: top;
  text-align: center;
  transition: all 0.2s ease-out;
  will-change: transform;
  width: 100%;
  word-break: normal;
}
@media all and (min-width: 20em) {
  .btn,
  [type=button],
  [type=submit],
  button {
    width: auto;
  }
}
.btn:hover,
[type=button]:hover,
[type=submit]:hover,
button:hover {
  color: #fff;
  background: linear-gradient(to bottom, oklch(0.8198 0.2429 260), oklch(0.6172 0.2099 260));
  box-shadow: 0 12px 20px 0 oklch(from #000 l c h / 0.12);
  text-decoration: none;
}
.btn:focus-visible,
[type=button]:focus-visible,
[type=submit]:focus-visible,
button:focus-visible {
  outline: 2px solid currentColor;
  outline-offset: 2px;
}
.btn:disabled,
[type=button]:disabled,
[type=submit]:disabled,
button:disabled {
  background: var(--neutral-2);
  color: var(--neutral-9);
  cursor: not-allowed;
}
.btn-external {
  background: linear-gradient(to bottom, oklch(0.6653 0.2227 142.5), oklch(0.4724 0.1604 142.5));
  box-shadow: 0 8px 20px -3px oklch(from #000 l c h / 0.12);
  border: 1px solid oklch(0.4724 0.1604 142.5);
  color: #fff;
  cursor: pointer;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  gap: 5px;
  font: normal 600 0.88888889rem var(--font-body);
  padding: 0.5rem 0.75rem;
  vertical-align: top;
  text-align: center;
  transition: all 0.2s ease-out;
  will-change: transform;
  width: 100%;
  word-break: normal;
}
@media all and (min-width: 20em) {
  .btn-external {
    width: auto;
  }
}
.btn-external:hover {
  color: #fff;
  background: linear-gradient(to bottom, oklch(0.8198 0.2429 142.5), oklch(0.6172 0.2099 142.5));
  box-shadow: 0 12px 20px 0 oklch(from #000 l c h / 0.12);
  text-decoration: none;
}
.btn-external:focus-visible {
  outline: 2px solid currentColor;
  outline-offset: 2px;
}
.btn-external:disabled {
  background: var(--neutral-2);
  color: var(--neutral-9);
  cursor: not-allowed;
}
@media all and (max-width: 19.9375em) {
  .btn + .btn,
  .btn + [type=button],
  .btn + [type=submit],
  .btn + button,
  [type=button] + .btn,
  [type=button] + [type=button],
  [type=button] + [type=submit],
  [type=button] + button,
  [type=submit] + .btn,
  [type=submit] + [type=button],
  [type=submit] + [type=submit],
  [type=submit] + button,
  button + .btn,
  button + [type=button],
  button + [type=submit],
  button + button {
    margin-top: calc(var(--baseline) * 2);
  }
}
[type=button],
[type=submit],
button {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
}
::placeholder {
  color: var(--neutral-4);
  opacity: 1;
}
fieldset {
  border: 1px solid var(--neutral-2);
  border-radius: 4px;
  margin: 0 0 calc(var(--baseline) * 6);
  padding: 1.5rem;
}
fieldset > legend {
  margin-left: -1rem;
  padding: 0 1rem;
}
legend {
  font-variation-settings: "wght" var(--headings-weight);
}
label {
  font-variation-settings: "wght" var(--headings-weight);
  margin: 0 1rem calc(var(--baseline) * 3) 0;
}
option {
  font-variation-settings: "wght" var(--font-weight-normal);
}
[type=email],
[type=number],
[type=search],
[type=tel],
[type=text],
[type=url],
select,
textarea {
  background-color: var(--white);
  border: 1px solid var(--neutral-2);
  border-radius: var(--border-radius);
  color: var(--text-color);
  font-size: 1rem;
  padding: 0.5rem 0.74rem;
  width: 100%;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
}
@media all and (min-width: 37.5em) {
  [type=email],
  [type=number],
  [type=search],
  [type=tel],
  [type=text],
  [type=url],
  select,
  textarea {
    width: auto;
  }
}
[type=email]:focus,
[type=number]:focus,
[type=search]:focus,
[type=tel]:focus,
[type=text]:focus,
[type=url]:focus,
select:focus,
textarea:focus {
  border-color: var(--link-color);
}
input[type=checkbox],
input[type=radio] {
  color: var(--text-color);
  opacity: 0;
  position: absolute;
}
input[type=checkbox] + label,
input[type=radio] + label {
  display: block;
  font-variation-settings: "wght" var(--font-weight-normal);
  position: relative;
  margin-left: -1px;
  cursor: pointer;
  padding: 0 0 0 calc(var(--baseline) * 9);
}
input[type=checkbox] + label::before,
input[type=radio] + label::before {
  background-color: var(--white);
  border: 1px solid var(--neutral-2);
  border-radius: 2px;
  content: "";
  display: block;
  height: calc(var(--baseline) * 5);
  left: 0;
  line-height: calc(var(--baseline) * 5);
  margin-right: calc(var(--baseline) * 5);
  position: absolute;
  text-align: center;
  top: var(--baseline);
  width: calc(var(--baseline) * 5);
}
input[type=checkbox]:checked + label::before,
input[type=radio]:checked + label::before {
  background-image: none !important;
  content: "";
  border-color: var(--link-color);
}
input[type=checkbox]:checked + label::after,
input[type=radio]:checked + label::after {
  content: "";
  display: block;
  width: 6px;
  height: 9px;
  border: solid var(--link-color);
  border-width: 0 2px 2px 0;
  left: calc(var(--baseline) * 1.1);
  position: absolute;
  top: calc(var(--baseline) * 3);
  transform: rotate(45deg) translate(0, -50%);
}
input[type=radio] + label::before {
  border-radius: 50%;
}
[type=file] {
  margin-bottom: calc(var(--baseline) * 6);
  width: 100%;
}
select {
  border-radius: var(--border-radius);
  max-width: 100%;
  width: auto;
  position: relative;
}
select:not([multiple]) {
  background: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 6 6"><polygon points="3 6 3 6 0 0 6 0 3 6" fill="%238a8b8c"/></svg>') no-repeat 90% 50%;
  background-size: 8px;
  padding-right: calc(var(--baseline) * 12);
}
select[multiple] {
  border: 1px solid var(--neutral-2);
  padding: calc(var(--baseline) * 6);
  width: 100%;
}
select[multiple]:hover {
  border-color: var(--neutral-2);
}
select[multiple]:focus {
  border-color: var(--link-color);
}
select[multiple]:disabled {
  background-color: var(--neutral-2);
  cursor: not-allowed;
}
select[multiple]:disabled:hover {
  border-color: var(--neutral-2);
}
textarea {
  display: block;
  overflow: auto;
  resize: vertical;
  max-width: 100%;
}
.site-header {
  align-items: center;
  display: flex;
  height: var(--navbar-height);
  position: fixed;
  top: 0px;
  background: linear-gradient(to bottom, #1952a6, #123f83);
  border-bottom: 0.5px solid #0a2246;
  width: 100%;
  z-index: 999;
}
.logo {
  order: 1;
  color: var(--neutral-9) !important;
  font-family: var(--font-logo);
  font-variation-settings: "wght" var(--font-weight-bold);
  font-size: 1.42382813rem;
  line-height: 1;
  margin-right: auto;
  white-space: nowrap;
  padding: 2px 8px;
  height: 100%;
}
@media all and (max-width: 74.9375em) {
  .logo {
    text-align: center;
  }
}
.logo > img {
  height: 100%;
  object-fit: contain;
  /* padding: calc(var(--baseline) * 2) 0; */
  width: auto;
}
.logo:hover {
  background: var(--navbar-hover-bg);
}
.search {
  margin-right: 1.5rem;
  order: 2;
  text-align: right;
  z-index: 99;
}
@media all and (min-width: 56.25em) {
  .search {
    margin: 0 0 0 1.5rem;
    order: 3;
  }
}
.search .search__btn {
  border: none;
  background: 0 0 !important;
  box-shadow: none !important;
  margin-bottom: 0;
  padding-right: 0;
  padding-left: 0;
  width: auto;
}
.search .search__btn:focus,
.search .search__btn:hover {
  transform: translateY(0);
}
.search .search__btn:focus > svg,
.search .search__btn:hover > svg {
  fill: var(--link-color);
}
.search .search__btn > svg {
  display: inline-block;
  fill: var(--neutral-6);
  transition: all 0.24s ease;
  vertical-align: middle;
}
.search .search__input {
  background: 0 0;
  border: none;
  font-size: 0.88888889rem;
  padding: 0 1rem 0 0;
  width: 100%;
}
@media all and (min-width: 37.5em) {
  .search .search__input {
    min-width: 18rem;
  }
}
.search .search__input:focus {
  color: var(--neutral-9);
}
.search .search__input:focus::placeholder {
  color: var(--neutral-4) !important;
  opacity: 0.66;
}
.search .search__form {
  align-items: center;
  display: flex;
  justify-content: space-between;
}
.search .search__button {
  box-shadow: unset;
  width: auto !important;
}
.search .search__button:focus,
.search .search__button:hover {
  transform: translateY(0);
}
.search .search__overlay {
  background: var(--neutral-1);
  border-radius: var(--border-radius);
  border: 2px solid var(--neutral-2);
  left: 0;
  opacity: 0;
  padding: calc(var(--baseline) * 1.5) calc(var(--baseline) * 1.5) calc(var(--baseline) * 1.5) calc(var(--baseline) * 4);
  position: absolute;
  right: 0;
  top: 0;
  transition: all 0.24s ease-out;
  visibility: hidden;
  z-index: 100;
}
@media all and (min-width: 56.25em) {
  .search .search__overlay {
    background: var(--neutral-1);
    border: none;
    left: auto;
    top: var(--navbar-height);
    transform: translateY(calc(var(--baseline) * -3));
  }
}
.search .search__overlay.expanded {
  transform: translateY(0);
  opacity: 1;
  display: block;
  visibility: visible;
}
.navbar {
  order: 3;
  position: relative;
  height: 100%;
}
@media all and (min-width: 56.25em) {
  .navbar {
    order: 2;
  }
}
.navbar .navbar__menu {
  display: flex;
  list-style: none;
  margin: 0;
  padding: 0;
}
@media all and (max-width: 56.1875em) {
  .navbar .navbar__menu {
    display: none;
  }
}
.navbar .navbar__menu li {
  display: block;
  font-size: 13px;
  font-weight: bold;
  font-family: var(--font-menu);
  line-height: var(--line-height);
  padding: 0;
  position: relative;
  white-space: nowrap;
}
.navbar .navbar__menu li a,
.navbar .navbar__menu li span[aria-haspopup=true] {
  color: #fff;
  display: block;
  padding: 0px 8px 0 8px;
  transition: all 0.24s ease-out;
}
.navbar .navbar__menu li a:hover,
.navbar .navbar__menu li span[aria-haspopup=true]:hover,
.navbar .navbar__menu li a:focus-within,
.navbar .navbar__menu li span[aria-haspopup=true]:focus-within {
  color: #fff;
  background: var(--navbar-hover-bg);
}
.navbar .navbar__menu li span {
  color: var(--neutral-9);
  cursor: default;
  display: block;
  padding: 0 0.5rem;
}
.navbar .navbar__menu li.has-submenu {
  position: relative;
}
.navbar .navbar__menu li.has-submenu:active > .navbar__submenu,
.navbar .navbar__menu li.has-submenu:focus > .navbar__submenu,
.navbar .navbar__menu li.has-submenu:focus-within > .navbar__submenu,
.navbar .navbar__menu li.has-submenu:hover > .navbar__submenu {
  left: 0;
  opacity: 1;
  transform: scale(1);
  visibility: visible;
  margin-top: 0;
}
.navbar .navbar__menu li.has-submenu:active > .navbar__submenu.is-right-submenu,
.navbar .navbar__menu li.has-submenu:focus > .navbar__submenu.is-right-submenu,
.navbar .navbar__menu li.has-submenu:focus-within > .navbar__submenu.is-right-submenu,
.navbar .navbar__menu li.has-submenu:hover > .navbar__submenu.is-right-submenu {
  left: auto;
  right: 0;
  transform-origin: right top;
}
.navbar .navbar__menu li.has-submenu .has-submenu:active > .navbar__submenu,
.navbar .navbar__menu li.has-submenu .has-submenu:focus > .navbar__submenu,
.navbar .navbar__menu li.has-submenu .has-submenu:focus-within > .navbar__submenu,
.navbar .navbar__menu li.has-submenu .has-submenu:hover > .navbar__submenu {
  top: 0;
  margin-top: 0;
}
.navbar .navbar__menu > li {
  line-height: var(--navbar-height);
}
.navbar .navbar__menu > li:hover {
  /* &>a,
				&>span[aria-haspopup=true] {
					color: var(--link-color)
				} */
}
.navbar .navbar__menu > li:hover > [aria-haspopup=true] {
  box-shadow: none;
}
.navbar .navbar__menu > li:hover.has-submenu::after {
  content: "";
  border-color: var(--link-color);
}
.navbar .navbar__submenu {
  background: var(--neutral-1);
  border-radius: var(--border-radius);
  left: -9999px;
  list-style-type: none;
  margin: 0 0 0.75rem;
  padding: 0.75rem 1.5rem;
  position: absolute;
  text-align: left;
  visibility: hidden;
  white-space: nowrap;
  z-index: 1;
  opacity: 0;
  transform: scale(0.8);
  transform-origin: 0 top;
  transition: opacity 0.15s, transform 0.3s cubic-bezier(0.275, 1.375, 0.8, 1);
  will-change: transform;
}
.navbar .navbar__submenu .navbar__submenu__submenu {
  z-index: 2;
}
.navbar .navbar__submenu li {
  line-height: 1.5;
  font-variation-settings: "wght" var(--font-weight-normal);
  padding: 0 0.25rem;
  text-transform: none;
}
.navbar .navbar__submenu li:last-child {
  border: none;
}
.navbar .navbar__submenu li a,
.navbar .navbar__submenu li span[aria-haspopup=true] {
  padding: 0.5rem 0;
  transition: all 0.24s ease;
}
.navbar .navbar__submenu li span {
  padding: 0.5rem 1.25rem;
}
.navbar .navbar__toggle {
  background: transparent;
  border: none;
  box-shadow: none;
  color: #fff;
  cursor: pointer;
  display: block;
  font-family: var(--font-menu);
  font-variation-settings: "wght" var(--font-weight-bold);
  line-height: 1;
  overflow: visible;
  text-transform: none;
  z-index: 2004;
  height: 100%;
}
@media all and (min-width: 56.25em) {
  .navbar .navbar__toggle {
    display: none;
  }
}
.navbar .navbar__toggle:focus,
.navbar .navbar__toggle:hover {
  box-shadow: none;
  transform: none;
  background: var(--navbar-hover-bg);
}
.navbar_mobile_sidebar {
  background: oklch(from var(--page-bg) l c h / 80%);
  backdrop-filter: blur(15px);
  box-shadow: 0 0 5px oklch(from var(--black) l c h / 0.25);
  height: 100vh;
  left: 0;
  max-width: 400px;
  overflow: auto;
  position: fixed;
  top: 0;
  transition: all 0.3s cubic-bezier(0, 0, 0.3, 1);
  width: 80%;
  z-index: 1001;
}
.navbar_mobile_sidebar.is-hidden {
  left: -400px;
  visibility: hidden;
}
.navbar_mobile_sidebar .navbar__menu {
  margin: 24px;
}
.navbar_mobile_sidebar .navbar__menu li {
  font-family: var(--font-heading);
  font-size: 16px;
  list-style: none;
  line-height: 1.3;
  margin: 0;
  padding: 0;
}
.navbar_mobile_sidebar .navbar__menu li .is-separator,
.navbar_mobile_sidebar .navbar__menu li a {
  color: var(--neutral-9);
  display: block;
  padding: 10px 20px 10px 0;
  position: relative;
}
.navbar_mobile_sidebar .navbar__menu li .is-separator:active,
.navbar_mobile_sidebar .navbar__menu li a:active,
.navbar_mobile_sidebar .navbar__menu li .is-separator:focus,
.navbar_mobile_sidebar .navbar__menu li a:focus,
.navbar_mobile_sidebar .navbar__menu li .is-separator:hover,
.navbar_mobile_sidebar .navbar__menu li a:hover {
  color: var(--link-color);
}
.navbar_mobile_sidebar .navbar__menu li .is-separator[aria-haspopup=true]::after,
.navbar_mobile_sidebar .navbar__menu li a[aria-haspopup=true]::after {
  border-right: 1px solid var(--link-color);
  border-top: 1px solid var(--link-color);
  content: "";
  height: 6px;
  position: absolute;
  right: 6%;
  top: 47%;
  transform: translate(0, -47%) rotate(135deg);
  width: 6px;
}
.navbar_mobile_sidebar .navbar__submenu {
  margin: 0 0 0 24px;
  padding: 0;
  visibility: hidden;
}
.navbar_mobile_sidebar .navbar__submenu[aria-hidden=false] {
  visibility: visible;
}
.navbar_mobile_sidebar .navbar__submenu_wrapper {
  height: 0;
  opacity: 0;
  overflow: hidden;
  transition: all 0.3s cubic-bezier(0.275, 1.375, 0.8, 1);
}
.navbar_mobile_sidebar .navbar__submenu_wrapper.is-active {
  height: auto;
  opacity: 1;
}
.navbar_mobile_sidebar__overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: oklch(from #000 l c h / 0.6);
  backdrop-filter: blur(5px);
  transition: all 0.3s cubic-bezier(0, 0, 0.3, 1);
  @starting-style {
    backdrop-filter: blur(0px);
  }
  z-index: 1000;
  opacity: 1;
  pointer-events: auto;
}
.navbar_mobile_sidebar__overlay.is-hidden {
  opacity: 0;
  pointer-events: none;
}
.container {
  box-sizing: content-box;
  overflow-wrap: break-word;
}
.home-template .container {
  overflow-x: hidden;
}
.container > * {
  padding-left: var(--page-margin);
  padding-right: var(--page-margin);
}
.container--narrow {
  max-width: var(--entry-width);
}
.home-template .landing {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  height: 100vh;
  max-width: 75ch;
  margin: auto;
}
.home-template .landing > table {
  margin-bottom: unset;
}
.home-template .landing-blockquote {
  padding: unset;
  margin-left: unset;
  margin-right: unset;
  margin-bottom: calc(var(--baseline) * 35);
  max-width: unset;
  text-align: center;
}
.home-template .landing-blockquote strong {
  color: var(--primary-7);
}
.home-template .landing-blockquote::before {
  display: none;
}
body:not(.home-template) .main {
  margin-top: calc(var(--magic-number) * 0.7);
}
@media screen and (max-width: 800px) {
  body:not(.home-template) .main {
    margin-top: var(--magic-number);
  }
}
@media screen and (min-width: 1119px) {
  body:not(.home-template) .main {
    padding-left: 0!important;
    padding-right: 0!important;
  }
}
.error-template .main.page--error {
  min-height: calc(100vh - var(--magic-number) * 3);
}
.error-template .footer {
  background: transparent;
  border-top: unset;
  position: relative;
}
.error-template .footer::before {
  backdrop-filter: blur(16px);
  background: rgba(0, 0, 0, 0.4);
  mask-image: linear-gradient(to bottom, transparent, black 15%);
  position: absolute;
  content: "";
  inset: 0;
  z-index: -1;
}
.error-template .footer .footer__nav li a {
  color: #fff !important;
}
.hero {
  opacity: 0.75;
  font-size: clamp(1rem, calc(1rem + 0.125 * (100vw - 20rem) / 80), 1.125rem);
  padding-bottom: var(--magic-number);
  max-width: var(--entry-width);
}
.hero h1 {
  margin-top: 0;
}
.hero h1 sup {
  font-variation-settings: "wght" var(--font-weight-normal);
  font-size: 1.125rem;
  vertical-align: top;
}
.hero p {
  margin-top: calc(var(--baseline) * 2);
}
.error-template .hero {
  color: white!important;
}
.hero--centered {
  margin-left: auto;
  margin-right: auto;
  text-align: center;
}
.hero--centered p {
  margin: calc(var(--baseline) * 4) auto 0;
}
.l-options {
  align-items: flex-start;
  display: flex;
  gap: 2rem;
  justify-content: space-between;
  margin-bottom: calc(var(--baseline) * 7);
}
@media all and (min-width: 80.0625em) and (min-height: 50em) {
  .l-options {
    margin-bottom: calc(var(--baseline) * 10);
  }
}
@media all and (max-width: 37.4375em) {
  .l-options.nomobile {
    display: none;
  }
}
.filter {
  margin: 0 -0.5rem;
  line-height: 1.4;
}
.filter .filter__item {
  background: 0 0;
  box-shadow: none;
  cursor: pointer;
  display: inline-block;
  font-family: var(--font-body);
  font-variation-settings: "wght" var(--font-weight-normal);
  font-size: 0.88888889rem;
  margin: 0;
  padding: 0 0.5rem;
  text-transform: none;
}
.filter .filter__item:focus,
.filter .filter__item:hover {
  box-shadow: none;
  transform: none;
}
.filter .filter__item.is-active {
  color: var(--link-color);
  -webkit-text-stroke: 0.5px var(--link-color);
  pointer-events: none;
}
.switchers {
  align-items: center;
  display: flex;
  margin-left: auto;
}
@media all and (max-width: 37.4375em) {
  .switchers {
    display: none;
  }
}
.switchers .switchers__item {
  background: 0 0;
  box-shadow: none;
  color: var(--neutral-4);
  padding: 0 0.5rem;
}
.switchers .switchers__item:focus,
.switchers .switchers__item:hover {
  background: inherit;
  box-shadow: inherit;
  color: var(--link-color);
  transform: translateY(0);
}
.switchers .switchers__item.is-active {
  color: var(--neutral-6);
  cursor: default;
}
.l-grid {
  box-sizing: content-box;
  display: flex;
  flex-wrap: wrap;
  margin: calc(-1 * var(--cards-gap)) calc(-0.5 * var(--cards-gap));
  position: relative;
}
.l-grid .c-card {
  width: 100%;
}
.l-grid .c-card .c-card__wrapper {
  margin: var(--cards-gap) calc(var(--cards-gap)/2);
}
@media all and (min-width: 37.5em) {
  .l-grid--2 .c-card {
    width: 49.999%;
  }
}
@media all and (min-width: 37.5em) {
  .l-grid--3 .c-card {
    width: 49.999%;
  }
}
@media all and (min-width: 75em) {
  .l-grid--3 .c-card {
    width: 33.333%;
  }
}
@media all and (min-width: 37.5em) {
  .l-grid--4 .c-card {
    width: 49.999%;
  }
}
@media all and (min-width: 75em) {
  .l-grid--4 .c-card {
    width: 33.333%;
  }
}
@media all and (min-width: 85em) {
  .l-grid--4 .c-card {
    width: 24.999%;
  }
}
@media all and (min-width: 37.5em) {
  .l-grid--1 .c-card {
    width: 100%;
  }
}
.c-card {
  list-style: none;
  padding: 0;
}
@media all and (min-width: 37.5em) {
  .c-card--rows .c-card__wrapper {
    display: flex;
    justify-content: space-between;
  }
  .c-card--rows .c-card__image {
    flex: 0 1 70%;
  }
  .c-card--rows .c-card__content {
    flex: 0 1 20%;
  }
}
.c-card__wrapper {
  height: 100%;
  position: relative;
}
.c-card__wrapper:hover .c-card__image {
  box-shadow: var(--box-shadow-hover);
  transform: scale(1.02);
}
.c-card__image {
  background-color: var(--neutral-1);
  border-radius: var(--border-radius);
  box-shadow: var(--box-shadow);
  display: block;
  height: var(--card-image-height);
  margin: 0;
  overflow: hidden;
  transition: all 0.12s linear;
  will-change: transform;
  width: 100%;
}
.c-card__image > img {
  object-fit: cover;
  object-position: center;
  height: inherit;
  display: block;
  width: inherit;
}
.c-card__image--up > img {
  object-position: top;
}
.c-card__image--down > img {
  object-position: bottom;
}
.c-card__content {
  padding: calc(var(--baseline) * 7) 0;
}
.c-card__title {
  font-size: 1rem;
  margin: 0;
}
.c-card__title > a:after {
  background: 0 0;
  content: "";
  cursor: pointer;
  left: 0;
  height: 100%;
  position: absolute;
  top: 0;
  width: 100%;
  z-index: 0;
}
.c-card__text {
  color: var(--neutral-6);
  font-size: 0.88888889rem;
  line-height: 1.4;
  margin: calc(var(--baseline) * 3) 0;
}
.c-card__meta {
  color: var(--neutral-6);
  display: flex;
  font-size: 0.79012346rem;
  margin-top: 0;
  position: relative;
  z-index: 1;
}
.c-card__meta a {
  color: var(--neutral-6);
  text-decoration: none;
  transition: all 0.12s linear;
}
.c-card__meta a:hover,
.c-card__meta a:active,
.c-card__meta a:focus {
  color: var(--link-color);
}
.c-card__meta a + a {
  margin-left: var(--baseline);
}
.content {
  position: relative;
}
@media screen and (min-width: 1119px) {
  .content {
    padding-left: calc(var(--magic-number) * 2);
    padding-right: calc(var(--magic-number) * 2);
  }
  body.toc-enabled .content {
    display: grid;
    gap: var(--magic-number);
    grid-template-areas: "content toc";
    grid-template-columns: minmax(0, 1300px) 240px;
  }
}
.content__inner {
  grid-area: content;
}
body:not(.toc-enabled) .content__inner {
  max-width: var(--entry-width);
  margin: auto;
}
.content__header {
  padding-bottom: calc(var(--magic-number)/2);
}
.content__header + .content__featured-image {
  margin-top: calc(var(--magic-number)/3.5);
}
.toc-wrapper {
  grid-area: toc;
}
.content__featured-image {
  margin-top: 0;
  margin-bottom: calc(var(--magic-number)/1.5);
}
.content__featured-image .content__featured-image__inner {
  background-color: var(--neutral-1);
  border-radius: var(--border-radius);
  box-shadow: var(--box-shadow);
  height: var(--featured-image-height);
}
.content__featured-image img {
  display: block;
  height: inherit;
  object-fit: cover;
  max-width: var(--page-width);
  width: 100%;
}
.content__featured-image--full {
  margin-left: calc(-50vw + 50% + var(--page-margin));
  margin-right: calc(-50vw + 50% + var(--page-margin));
  padding: 0;
  text-align: center;
}
.content__featured-image--full img {
  max-width: 100%;
}
.content__title {
  margin-top: 0;
  display: none;
}
.content__meta {
  color: var(--neutral-6);
  font-size: 0.88888889rem;
  margin-top: calc(var(--baseline) * 5);
}
@media all and (min-width: 48em) {
  .content__meta .content__meta__left,
  .content__meta .content__meta__right {
    display: inline-block;
  }
}
@media all and (min-width: 31.25em) {
  .content__meta .content__meta__left * + ::before,
  .content__meta .content__meta__right * + ::before {
    content: "•";
    padding-right: 0.5rem;
  }
}
@media all and (min-width: 48em) {
  .content__meta .content__meta__left + .content__meta__left::before,
  .content__meta .content__meta__left + .content__meta__right::before,
  .content__meta .content__meta__right + .content__meta__left::before,
  .content__meta .content__meta__right + .content__meta__right::before {
    content: "•";
    padding-right: 0.5rem;
  }
}
.content__entry > :first-child {
  margin-top: 0;
}
.content__entry a:not(.btn):not([type=button]):not([type=submit]):not(button):hover {
  text-decoration: underline;
  text-decoration-skip: ink;
}
.content__author {
  font-variation-settings: "wght" var(--font-weight-bold);
  margin-right: 0.75rem;
}
.content__author > img {
  display: none;
}
@media all and (min-width: 48em) {
  .content__author > img {
    border-radius: 50%;
    display: inline-block;
    height: calc(var(--baseline) * 6);
    margin-right: var(--baseline);
    width: calc(var(--baseline) * 6);
  }
}
.content__date,
.content__updated {
  display: inline-block;
  margin: 0 0.5rem 0 0;
}
.content__tag-share {
  display: flex;
  gap: 1rem;
  justify-content: space-between;
}
.content__tag {
  font-size: 0.88888889rem;
}
.content__tag .content__tag__title {
  font-size: inherit;
  display: inline-block;
  margin: 0 0.5rem 0 0;
}
.content__tag .content__tag__list {
  display: inline;
  margin: 0;
}
.content__tag .content__tag__list li {
  color: var(--neutral-6);
  display: inline-block;
  list-style: none;
  margin-right: 0.5rem;
  padding: 0;
}
.content__share {
  flex: 0 0 auto;
  font-size: 1rem;
  margin-left: -1rem;
  position: relative;
}
.content__share > a {
  display: inline-block;
  margin: 0 0 0 1rem;
}
.content__share > a:hover {
  text-decoration: none;
}
.content__share > a svg {
  fill: var(--neutral-6);
  height: 1rem;
  pointer-events: none;
  transition: all 0.12s linear;
  width: 1rem;
}
.content__footer {
  margin-top: calc(var(--magic-number)/2);
}
.content__related {
  margin-top: var(--magic-number);
}
.content__related .content__related__title {
  font-size: 1rem;
  border-top: 1px solid var(--neutral-2);
  padding: 2rem 0 calc(2rem + 2vmin);
}
.post__image--left {
  float: left;
  margin-bottom: calc(var(--baseline) * 6);
  margin-right: calc(var(--baseline) * 6);
  max-width: 50%;
}
.post__image--right {
  float: right;
  margin-bottom: calc(var(--baseline) * 6);
  margin-left: calc(var(--baseline) * 6);
  max-width: 50%;
}
.post__image--center {
  display: block;
  margin-left: auto;
  margin-right: auto;
  text-align: center;
}
.post__image--center img {
  max-height: 150px;
  width: auto;
}
.post__image--wide {
  display: block;
  margin-left: calc(-50vw + 50%);
  margin-right: calc(-50vw + 50%);
  padding: 0 var(--page-margin);
  text-align: center;
}
.post__image--wide a,
.post__image--wide img {
  display: block;
  height: auto;
  margin: auto;
  max-width: var(--page-width);
  width: 100%;
}
.post__image--full {
  display: block;
  margin-left: calc(-50vw + 50%);
  margin-right: calc(-50vw + 50%);
  padding: 0 var(--page-margin);
  text-align: center;
}
.post__image--full a,
.post__image--full img {
  display: block;
  height: auto;
  width: 100%;
}
.post__image figcaption a {
  color: var(--neutral-4);
  text-decoration: none;
  transition: all 0.12s linear;
}
.post__image figcaption a:hover,
.post__image figcaption a:active,
.post__image figcaption a:focus {
  color: var(--neutral-9);
}
.post__iframe,
.post__video {
  position: relative;
  display: block;
  margin-top: calc(var(--baseline) * 9);
  margin-bottom: calc(var(--baseline) * 9);
  overflow: hidden;
  padding: 0;
  width: 100%;
}
.post__iframe::before,
.post__video::before {
  display: block;
  content: "";
  padding-top: var(--embed-aspect-ratio);
}
.post__iframe iframe,
.post__video iframe,
.post__iframe video,
.post__video video {
  border: none;
  height: 100%;
  left: 0;
  position: absolute;
  top: 0;
  bottom: 0;
  width: 100%;
}
.post__toc {
  border: 2px solid var(--neutral-2);
  border-radius: var(--border-radius);
  font-size: 0.88888889rem;
  color: var(--link-color);
  margin-bottom: calc(var(--baseline) * 9);
  padding: 2rem;
}
.post__toc h3 {
  color: var(--link-color);
  font-size: 1rem;
  margin: 0 0 calc(var(--baseline) * 3);
}
.post__toc ul {
  counter-reset: item;
  list-style: decimal;
  margin: 0;
  padding: 0 0 0 2ch;
}
.post__toc ul li {
  counter-increment: item;
  padding: 0 0 0 calc(var(--baseline) * 2);
}
.post__toc ul ul {
  margin-top: 0;
  padding: 0 0 0 calc(var(--baseline) * 2);
}
.post__toc ul ul li {
  display: block;
}
.post__toc ul ul li:before {
  content: counters(item, ".") ". ";
  margin-left: -1rem;
  margin-right: var(--baseline);
}
.banner--before-content {
  margin-bottom: var(--magic-number);
}
.banner--after-content {
  margin-top: var(--magic-number);
}
.page--author__avatar {
  box-shadow: 1px 16px 18px -6px oklch(from var(--black) l c h / 0.2);
  border-radius: 50%;
  height: 5rem;
  margin: 0 0 calc(var(--baseline) * 6);
  width: 5rem;
}
@media all and (min-width: 37.5em) {
  .page--author__avatar {
    height: 6rem;
    width: 6rem;
  }
}
.page--author__details {
  align-items: center;
  border-top: 1px solid var(--neutral-2);
  font-size: 0.88888889rem;
  display: inline-flex;
  margin-top: calc(var(--baseline) * 6);
  padding: calc(var(--baseline) * 4) 3rem 0;
}
@media all and (max-width: 37.4375em) {
  .page--author__details {
    flex-wrap: wrap;
    justify-content: center;
    padding: calc(var(--baseline) * 4) 0 0;
  }
}
.page--author__details span {
  flex-basis: 100%;
}
@media all and (min-width: 37.5em) {
  .page--author__details span {
    flex-basis: auto;
    margin-right: 2rem;
  }
}
.page--author__details a {
  margin-left: 0.3rem;
}
.page--error__title {
  font-size: clamp(6.58325017rem, calc(6.58325017rem + 8.43115102 * (100vw - 20rem) / 80), 15.01440119rem);
}
.page--error__btn {
  margin-top: calc(var(--baseline) * 2) !important;
}
.page--search form {
  align-items: flex-start;
  display: flex;
  flex-wrap: wrap;
}
@media all and (max-width: 37.4375em) {
  .page--search form input {
    margin-bottom: calc(var(--baseline) * 2);
  }
}
@media all and (min-width: 20em) {
  .page--search form input {
    flex: 1 0 auto;
    margin-right: calc(var(--baseline) * 2);
  }
}
@media all and (max-width: 37.4375em) {
  .page--search form button {
    width: 100%;
  }
}
.subpages {
  border-top: 1px solid var(--neutral-2);
  margin-top: var(--magic-number);
}
.subpages .subpages__list {
  list-style: initial;
  margin-left: 2ch;
}
.subpages .subpages__list ul {
  list-style: initial;
  margin: 0 0 0 2ch;
}
.subpages .subpages__list li {
  padding: 0 0 0 1ch;
}
.align-left {
  text-align: left;
}
.align-right {
  text-align: right;
}
.align-center {
  text-align: center;
}
.align-justify {
  text-align: justify;
}
.msg {
  background: linear-gradient(to bottom, var(--primary-5), var(--primary-1));
  border: 1px solid var(--primary-5);
  font-size: 0.88888889rem;
  padding: calc(var(--baseline) * 5) calc(var(--baseline) * 5);
}
/* .msg--highlight {
	border-color: var(--yellow)
}

.msg--info {
	border-color: var(--blue)
}

.msg--success {
	border-color: var(--green)
}

.msg--warning {
	border-color: var(--red)
} */
.dropcap:first-letter {
  float: left;
  font-family: var(--font-heading);
  font-size: 4.10989067rem;
  line-height: 0.7;
  margin-right: calc(var(--baseline) * 2);
  padding: calc(var(--baseline) * 2) calc(var(--baseline) * 2) calc(var(--baseline) * 2) 0;
}
.pec-wrapper {
  height: 100%;
  left: 0;
  position: absolute;
  top: 0;
  width: 100%;
}
.pec-overlay {
  align-items: center;
  background-color: var(--neutral-2);
  font-size: 14px;
  display: none;
  height: inherit;
  justify-content: center;
  line-height: 1.4;
  padding: 1rem;
  position: relative;
  text-align: center;
}
@media all and (min-width: 37.5em) {
  .pec-overlay {
    font-size: 16px;
    line-height: var(--line-height);
    padding: 1rem 2rem;
  }
}
.pec-overlay.is-active {
  display: flex;
}
.pec-overlay-inner p {
  margin: 0 0 1rem;
}
.is-img-loading {
  overflow: hidden;
  position: relative;
}
.is-img-loading::after,
.is-img-loading::before {
  content: "";
  display: block;
  position: absolute;
  height: 100%;
  width: 2px;
  top: -100%;
  left: 20%;
  background: linear-gradient(to bottom, oklch(from var(--black) l c h / 0) 0, oklch(from var(--primary-base) l c h / 0.15) 75%, oklch(from var(--black) l c h / 0) 100%);
  animation: preloader 2s cubic-bezier(0.4, 0.26, 0, 0.97) 0s infinite;
}
.is-img-loading::before {
  animation-delay: 0.2s;
  left: 80%;
}
@keyframes preloader {
  0% {
    top: -100%;
  }
  100% {
    top: 100%;
  }
}
.facebook:hover svg {
  fill: #0866FF;
}
.twitter:hover svg {
  fill: var(--black);
}
.mix:hover svg {
  fill: #fd8235;
}
.instagram:hover svg {
  fill: var(--black);
}
.vimeo:hover svg {
  fill: #1ab7ea;
}
.pinterest:hover svg {
  fill: #bd081c;
}
.youtube:hover svg {
  fill: #cd201f;
}
.linkedin:hover svg {
  fill: #007bb6;
}
.buffer:hover svg {
  fill: var(--neutral-8);
}
.whatsapp:hover svg {
  fill: #25D366;
}
.pocket:hover svg {
  fill: #ED4255;
}
.pagination {
  clear: both;
  display: flex;
  flex-wrap: wrap;
  font-size: 0.88888889rem;
  justify-content: center;
  margin-top: calc(2rem + 2vmin);
}
.pagination a {
  border: 2px solid transparent;
  border-radius: var(--border-radius);
  display: inline-block;
  color: var(--neutral-6);
  margin: 0 0.25rem;
  padding: 0.5rem 1rem;
  text-align: center;
}
.pagination a:hover {
  background-color: var(--neutral-1);
  color: var(--neutral-6);
}
.pagination-active {
  background-color: var(--neutral-1);
  color: var(--link-color) !important;
  font-variation-settings: "wght" var(--font-weight-bold);
  pointer-events: none;
}
.pagination-inactive {
  border: 2px solid transparent;
  color: var(--neutral-4) !important;
  margin: 0 0.25rem;
  pointer-events: none;
  padding: 0.5rem 1rem;
  opacity: 0.6;
}
.pagination-first,
.pagination-last {
  display: none;
}
@media all and (min-width: 56.25em) {
  .pagination-first,
  .pagination-last {
    display: block;
  }
}
.view-more {
  display: flex;
  margin: 0.5rem auto 0;
}
.newsletter {
  background-color: var(--neutral-1);
  margin: var(--magic-number) 0;
  padding: calc(var(--magic-number)/1.5) var(--page-margin);
}
.newsletter .newsletter__title {
  margin-top: 0;
}
.newsletter .newsletter__desc {
  color: var(--neutral-6);
  font-size: 0.88888889rem;
}
@media all and (min-width: 56.25em) {
  .newsletter .newsletter__desc {
    max-width: 85%;
  }
}
.newsletter form {
  display: flex;
  flex-wrap: wrap;
  flex-direction: column;
  gap: 1rem;
  margin-top: calc(var(--baseline) * 5);
}
@media all and (min-width: 37.5em) {
  .newsletter form {
    flex-direction: row;
  }
}
.newsletter input[type=email],
.newsletter input[type=text] {
  flex: 1;
}
@media all and (max-width: 37.4375em) {
  .newsletter input[type=submit] {
    width: 100%;
  }
}
.footer {
  color: var(--neutral-6);
  margin-top: var(--magic-number);
}
@media all and (max-width: 56.1875em) {
  .footer {
    text-align: center;
  }
  .footer__left {
    display: none;
  }
}
@media all and (min-width: 56.25em) {
  .footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 2rem 12rem;
  }
  .footer__right {
    flex-grow: 1;
    max-width: 35ch;
  }
}
.footer h3 {
  margin: 0 0 calc(var(--baseline) * 5);
}
.footer .footer__copy {
  font-size: 0.79012346rem;
}
.footer .footer__left {
  max-width: 20ch;
  font-size: xx-large;
  font-variation-settings: "wght" 800;
  line-height: 2.3rem;
}
.footer .footer__nav {
  display: flex;
  flex-wrap: wrap;
  font-size: 0.88888889rem;
  margin: 0 0 calc(var(--baseline) * 2);
}
@media all and (min-width: 56.25em) {
  .footer .footer__nav {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(10rem, 1fr));
    font-size: 0.79012346rem;
    margin: 0;
  }
}
.footer .footer__nav li {
  display: inline-block;
  padding: 0;
  position: relative;
  flex: 1;
}
@media all and (min-width: 56.25em) {
  .footer .footer__nav li {
    margin: 0 0.4rem 0 0;
  }
}
.footer .footer__nav li:last-child {
  margin-right: unset;
}
.footer .footer__nav li a {
  display: block;
  padding: 0.5rem 1rem;
  border-radius: 4px;
  color: var(--text-color);
  font-variation-settings: "wght" 600;
}
.footer .footer__nav li a:hover {
  background-color: rgba(255, 255, 255, 0.03);
}
@media all and (max-width: 56.1875em) {
  .footer .footer__left + .footer__right {
    margin: calc(var(--baseline) * 8) 0;
  }
}
@media all and (min-width: 56.25em) {
  .footer .footer__right {
    margin-left: auto;
  }
}
.footer .footer__social a {
  display: inline-block;
  padding: 0 0.75rem;
  vertical-align: middle;
}
@media all and (min-width: 56.25em) {
  .footer .footer__social a {
    padding: 0 0 0 1.5rem;
  }
}
.footer .footer__social a > svg {
  display: inline-block;
  fill: var(--neutral-6);
  height: 0.875rem;
  pointer-events: none;
  transition: all 0.12s linear 0s;
  width: 0.875rem;
}
.footer .footer__social a:hover > svg {
  opacity: 1;
}
.footer .footer__bttop {
  background: var(--link-color);
  border: 2px solid var(--white) !important;
  bottom: calc(var(--baseline) * 5);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 44px;
  line-height: 1;
  opacity: 0;
  padding: 0;
  position: fixed;
  right: 2rem;
  text-align: center;
  width: 44px !important;
  visibility: hidden;
  z-index: 999;
  transform: translateY(1rem);
}
@media all and (min-width: 56.25em) {
  .footer .footer__bttop {
    bottom: calc(var(--baseline) * 10);
  }
}
.footer .footer__bttop:hover {
  opacity: 1;
  transform: translateY(-3px);
}
.footer .footer__bttop > svg {
  fill: var(--white);
  height: 24px;
  margin: 0;
  width: 24px;
}
.footer .footer__bttop.is-visible {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}
.gallery {
  margin: calc(var(--baseline) * 9) calc(var(--gallery-gap) * -1) calc(var(--baseline) * 2);
}
@media all and (min-width: 20em) {
  .gallery {
    display: flex;
    flex-wrap: wrap;
  }
}
@media all and (min-width: 20em) {
  .gallery[data-columns="1"] .gallery__item {
    flex: 1 0 100%;
  }
}
@media all and (min-width: 30em) {
  .gallery[data-columns="2"] .gallery__item {
    flex: 1 0 50%;
  }
}
@media all and (min-width: 37.5em) {
  .gallery[data-columns="3"] .gallery__item {
    flex: 1 0 33.333%;
  }
}
@media all and (min-width: 56.25em) {
  .gallery[data-columns="4"] .gallery__item {
    flex: 0 1 25%;
  }
}
@media all and (min-width: 56.25em) {
  .gallery[data-columns="5"] .gallery__item {
    flex: 0 1 20%;
  }
}
@media all and (min-width: 56.25em) {
  .gallery[data-columns="6"] .gallery__item {
    flex: 0 1 16.666%;
  }
}
@media all and (min-width: 56.25em) {
  .gallery[data-columns="7"] .gallery__item {
    flex: 1 0 14.285%;
  }
}
@media all and (min-width: 56.25em) {
  .gallery[data-columns="8"] .gallery__item {
    flex: 1 0 12.5%;
  }
}
@media all and (min-width: 56.25em) {
  .gallery-wrapper--wide {
    display: flex;
    justify-content: center;
    margin-left: calc(-50vw + 50%);
    margin-right: calc(-50vw + 50%);
    padding: 0 var(--page-margin);
  }
  .gallery-wrapper--wide .gallery {
    max-width: calc(var(--page-width) + var(--gallery-gap) * 2);
    width: calc(100% + var(--gallery-gap) * 2);
  }
}
.gallery-wrapper--full {
  margin-left: calc(-50vw + 50%);
  margin-right: calc(-50vw + 50%);
  padding: 0 var(--page-margin);
}
.gallery__item {
  margin: 0;
  padding: var(--gallery-gap);
  position: relative;
}
@media all and (min-width: 20em) {
  .gallery__item {
    flex: 1 0 50%;
  }
}
@media all and (min-width: 30em) {
  .gallery__item {
    flex: 1 0 33.333%;
  }
}
@media all and (min-width: 37.5em) {
  .gallery__item {
    flex: 1 0 25%;
  }
}
.gallery__item a {
  background-color: var(--neutral-1);
  display: block;
  height: 100%;
  width: 100%;
}
.gallery__item a::after {
  background: linear-gradient(to top, oklch(from var(--black) l c h / 0.4) 0, oklch(from var(--black) l c h / 0) 100%);
  bottom: var(--gallery-gap);
  content: "";
  display: block;
  opacity: 0;
  left: var(--gallery-gap);
  height: calc(100% - var(--gallery-gap) * 2);
  position: absolute;
  right: var(--gallery-gap);
  top: var(--gallery-gap);
  transition: all 0.24s ease-out;
  width: calc(100% - var(--gallery-gap) * 2);
}
.gallery__item a:hover::after {
  opacity: 1;
}
.gallery__item img {
  display: block;
  height: 100%;
  object-fit: cover;
  width: 100%;
}
.gallery__item figcaption {
  bottom: 1.2rem;
  color: var(--white);
  left: 50%;
  opacity: 0;
  position: absolute;
  text-align: center;
  transform: translate(-50%, 1.2rem);
  transition: all 0.24s ease-out;
}
.gallery__item:hover figcaption {
  opacity: 1;
  transform: translate(-50%, 0);
}
.pswp--dark .pswp__bg {
  background: var(--black);
}
.pswp--dark .pswp__button,
.pswp--dark .pswp__button--arrow--left:before,
.pswp--dark .pswp__button--arrow--right:before {
  background-image: url(../svg/gallery-icons-light.svg);
}
.pswp--light .pswp__bg {
  background: var(--white);
}
.pswp--light .pswp__counter {
  color: var(--neutral-9);
}
.pswp--light .pswp__caption__center {
  color: var(--text-color);
}
.pswp--light .pswp__button,
.pswp--light .pswp__button--arrow--left:before,
.pswp--light .pswp__button--arrow--right:before {
  background-image: url(../svg/gallery-icons-dark.svg);
}
.pswp .pswp__button {
  box-shadow: none;
}
.pswp--zoom-allowed .pswp__img {
  cursor: default !important;
}
img[loading] {
  opacity: 0;
}
img.is-loaded {
  opacity: 1;
  transition: opacity 1s cubic-bezier(0.215, 0.61, 0.355, 1);
}
.btn {
  margin: 2px;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  gap: 5px;
}
.btn-light {
  background: var(--primary-2) !important;
  color: var(--text-color) !important;
}
.body {
  font-weight: 400;
  font-style: normal;
}
.mp-header {
  font-size: clamp(2.5rem, 8vw, 60px);
  text-align: center;
}
.content__inner.content__header {
  display: none;
}
.logo-carousel {
  mask-image: linear-gradient(to right, oklch(from var(--black) l c h / 0), var(--black) 20%, var(--black) 80%, oklch(from var(--black) l c h / 0));
  position: relative;
  --logo-slide-width: 150px;
}
.logo-track {
  display: flex;
  animation: scroll 23s linear infinite;
  width: calc(var(--logo-slide-width) * 10);
}
.logo-track:hover {
  animation-play-state: paused;
}
.logo-slide {
  width: var(--logo-slide-width);
  padding: 0 30px;
  flex-shrink: 0;
  display: flex;
  justify-content: center;
  align-items: center;
}
.logo-slide img {
  width: 100%;
  height: auto;
  opacity: 0.8;
  transition: opacity 0.3s ease;
}
.logo-slide a:hover img {
  opacity: 1;
}
@keyframes scroll {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(calc(var(--logo-slide-width) * -10));
  }
}
.flex-container {
  display: flex;
  flex-wrap: wrap;
  gap: 60px;
  width: 100%;
}
.flex-container > div {
  flex: 1;
  font-size: medium;
}
.flex-container.plain-simple-divs {
  margin-top: calc(var(--baseline) * 4);
}
.flex-container.plain-simple-divs > div {
  background: oklch(from var(--neutral-2) l c h / 60%);
  padding: 2rem;
  border-radius: 20px;
  min-width: 35%;
}
.flex-container.plain-simple-divs > div > h5 {
  margin-top: 0;
}
@media screen and (max-width: 800px) {
  .flex-container.plain-simple-divs > div {
    min-width: 100%;
  }
}
.glass-section {
  --lightness: 255;
  background: rgba(var(--lightness), var(--lightness), var(--lightness), 0.4);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-radius: 20px;
  border: 1px solid rgba(var(--lightness), var(--lightness), var(--lightness), 0.3);
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.1), inset 0 1px 0 rgba(var(--lightness), var(--lightness), var(--lightness), 0.5), inset 0 -1px 0 rgba(var(--lightness), var(--lightness), var(--lightness), 0.1), inset 0 0 36px 18px rgba(var(--lightness), var(--lightness), var(--lightness), 1.8);
  position: relative;
  overflow: hidden;
  padding: 2rem;
}
.glass-section::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(var(--lightness), var(--lightness), var(--lightness), 0.8), transparent);
}
.glass-section::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 1px;
  height: 100%;
  background: linear-gradient(180deg, rgba(var(--lightness), var(--lightness), var(--lightness), 0.8), transparent, rgba(var(--lightness), var(--lightness), var(--lightness), 0.3));
}
.glass-section h1,
.glass-section h2,
.glass-section h3,
.glass-section h4,
.glass-section h5,
.glass-section h6 {
  margin-top: unset;
}
.dark-mode .glass-section {
  --lightness: 0;
}
.glass-button {
  --fg: oklch(15% calc(var(--sat) * 0.5) var(--hue));
  --bg: oklch(75% var(--sat) var(--hue) / 0.8);
  --bg-dark: oklch(45% var(--sat) var(--hue) / 0.75);
  --bottom-glow: radial-gradient(farthest-corner at bottom center, rgba(255, 255, 255, var(--glow-intensity)), transparent);
  background-color: var(--bg);
  background: var(--bottom-glow), linear-gradient(to bottom, var(--bg-dark), var(--bg));
  border: 1px solid var(--bg);
  border-radius: 9999px;
  box-shadow: 0 4px 4px rgba(0, 0, 0, 0.4);
  color: var(--fg);
  /* font-family: "Lucida Grande", "Lucida Sans Unicode", "Segoe UI", system-ui, sans-serif; */
  font-weight: 700;
  text-shadow: 0 2px 0.5em rgba(0, 0, 0, 0.2);
  cursor: pointer;
  position: relative;
  transition: all 300ms ease;
  user-select: none;
  -webkit-user-select: none;
  /* Top Highlight Effect */
  --hue: 236;
  --sat: 0.54;
  --glow-intensity: 0.8;
  margin: 0 2px;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  gap: 5px;
  /* Size Variations */
}
.glass-button::after {
  content: "";
  position: absolute;
  top: 4%;
  left: 0.75em;
  width: calc(100% - 1.5em);
  height: 40%;
  background: linear-gradient(to bottom, rgba(255, 255, 255, 0.8), rgba(255, 255, 255, 0.1));
  border-radius: inherit;
  transition: background 400ms ease;
  pointer-events: none;
}
.glass-button:hover,
.glass-button:focus {
  box-shadow: 0 6px 8px rgba(0, 0, 0, 0.4);
  transform: translateY(-1px);
}
.glass-button:active {
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.4);
  transform: translateY(1px);
}
.glass-button.small {
  padding: 0.5em 1.5em;
  font-size: 0.875rem;
}
.glass-button.medium {
  padding: 0.75em 2em;
  font-size: 1rem;
}
.glass-button.large {
  padding: 1em 3em;
  font-size: 1.125rem;
}
#themeToggle {
  padding: 2px 8px;
  background: transparent;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  height: 100%;
  box-shadow: unset;
  border-radius: unset;
  color: #fff;
}
#themeToggle > img {
  width: 100%;
  height: 20px;
  object-fit: contain;
}
#themeToggle:hover {
  background: var(--navbar-hover-bg);
}
#themeToggle:focus {
  background: transparent;
}
.theme-toggle-container {
  order: 2;
  margin-left: auto;
  height: 100%;
}
.subtitle-below-heading {
  display: flex;
  flex-wrap: wrap;
  gap: 5px 15px;
  margin-top: unset;
  font-size: medium;
  opacity: 0.75;
}
.material-symbols {
  height: 20px;
}
.text-highlight {
  background: var(--primary-5);
}
.landing-content h1 {
  margin-top: unset;
}
.secondary-container {
  border: 1px solid rgba(255, 255, 255, 0.3);
  background: linear-gradient(to bottom, oklch(from var(--primary-1) l c h / 60%), var(--primary-1));
  position: relative;
  overflow: hidden;
  padding: 2rem;
}
.dark-mode .secondary-container {
  --lightness: 0;
}
.secondary-container::before {
  content: "";
  position: absolute;
  inset: 0;
  background: url(../../media/backgrounds/day-sky.png);
  background-size: cover;
  background-position: center;
  border-radius: inherit;
  filter: blur(2px);
  transform: scale(1.1);
  z-index: -1;
}
.secondary-container > h2 {
  margin-top: 0;
  grid-area: title;
}
.secondary-container > p {
  grid-area: desc;
}
.secondary-container > p:last-child {
  grid-area: buttons;
}
.landing-project-showcase {
  display: flex;
  justify-content: space-between;
  gap: 2rem;
  flex-wrap: wrap;
  margin-top: calc(var(--baseline) * 35);
  margin-bottom: calc(var(--baseline) * 70);
  align-items: center;
}
@media screen and (min-width: 800px) {
  .landing-project-showcase > div:first-child {
    flex: 1;
  }
}
@media screen and (max-width: 800px) {
  .landing-project-showcase {
    flex-direction: column;
  }
}
.landing-project-showcase h1 {
  margin-top: unset;
}
.landing-project-showcase > div {
  display: inline-flex;
  flex-direction: column;
  align-items: start;
  gap: 0.5rem;
}
.landing-project-showcase > div:last-child {
  color: oklch(from var(--text-color) l c h / 0.6);
}
.project-container {
  background: oklch(from var(--neutral-2) l c h / 60%);
  backdrop-filter: blur(10px);
  padding: 2rem;
  border-radius: 20px;
  min-width: 35%;
  font-size: medium;
  margin: 2rem 1rem;
  display: grid;
  gap: calc(var(--baseline) * 6);
  grid-template-areas: "info image" "desc image";
}
.project-container h1,
.project-container h2,
.project-container h3,
.project-container h4,
.project-container h5 {
  margin-top: 0;
}
.project-container .post__image--right {
  margin-top: unset;
}
@media screen and (max-width: 800px) {
  .project-container {
    margin-left: unset;
    margin-right: unset;
    padding: 0 0 2rem 0;
    grid-template-areas: "image" "info" "desc";
    background: transparent;
    backdrop-filter: unset;
    border: 1px solid rgba(255, 255, 255, 0.03);
  }
  .project-container-info,
  .project-container-desc {
    padding: 0 1rem;
    z-index: 1;
  }
  .project-container-image {
    width: 100%!important;
    height: auto!important;
    margin-bottom: -25%;
    mask-image: linear-gradient(to bottom, black, rgba(0, 0, 0, 0.75) 55%, transparent);
    pointer-events: none;
  }
}
.project-container-image {
  grid-area: image;
}
.project-container-info {
  grid-area: info;
}
.project-container-desc {
  grid-area: desc;
}
.project-container-desc > p:first-child {
  margin-top: unset;
}
