@charset "UTF-8";
@import url("https://fonts.googleapis.com/css?family=Inter:wght@100,200,300,400,500,600,700,800,900");
@import url("https://fonts.googleapis.com/css?family=Montserrat:wght@100,200,300,400,500,600,700,800,900");
/* ****************************************
 Helium 0.0.0 by Medusa Devs
 Sassy offiziersmesser for front-end development
 ****************************************/
label, :where(button, [type=button], [type=reset], [type=submit]), .no-select {
  user-select: none;
}

nav > :is(ol,
ul), .flex, body, form, :where(button, [type=button], [type=reset], [type=submit]) {
  display: flex;
}

:where(button, [type=button], [type=reset], [type=submit]) {
  justify-content: center;
  align-items: center;
}

body, form {
  flex-direction: column;
}

article ul li {
  width: -webkit-fill-available;
  width: -moz-available;
  width: stretch;
}

.no-scroll {
  overflow: hidden;
}

/* @atom font: serif */
/* @atom font: sans */
/* @atom font: mono */
code,
pre {
  font-family: var(--font-mono);
}

/* @atom font: title */
:where(h1, h2, h3, h4, h5, h6, .h1, .h2, .h3, .h4, .h5, .h6) {
  font-family: var(--font-title);
}

/* @atom font: text */
html, body, :where(input:where([type=text], [type=tel], [type=email], [type=password]), textarea, .select-wrapper), :where(button, [type=button], [type=reset], [type=submit]), p {
  font-family: var(--font-text);
}

:root {
  color-scheme: light dark;
  --container-width: 65ch;
  /* @portal tokens */
  --color-primary: var(--color-pink-4);
  --color-primary-lighter: var(--color-pink-3);
  --color-primary-darker: var(--color-pink-5);
  --body-background: var(--background);
  --font-serif: Garamond, ui-serif, serif;
  --font-sans: Inter, Noto Sans, Arial, ui-sans-serif, sans-serif;
  --font-mono: JetBrains Mono, ui-monospace, monospace;
  --font-title: var(--font-sans);
  --font-text: var(--font-sans);
  --space-1: 3px;
  --space-2: 6px;
  --space-3: 9px;
  --space-4: 12px;
  --space-5: 21px;
  --space-6: 33px;
  --space-7: 54px;
  --space-8: 87px;
  --space-9: 141px;
  --gutter: clamp(var(--space-4), 3vw, var(--space-5));
  --radius-1: 2px;
  --radius-2: 3px;
  --radius-3: 4px;
  --radius-4: 6px;
  --radius-5: 8px;
  --radius-6: 10px;
  --radius-7: 15px;
  --radius-8: 20px;
  --radius-9: 30px;
  --radius-rounded: 1618px;
  --z-logo: 100;
  --z-hamburger: 100;
  --z-menu: 90;
  --z-navbar: 10;
  --z-alert: 10;
  --z-modal: 10;
  /* @tokens sizes */
  --size-1: 0.69rem;
  --size-2: 0.83rem;
  --size-3: 1rem;
  --size-4: 1.2rem;
  --size-5: 1.44rem;
  --size-6: 1.73rem;
  --size-7: 2.07rem;
  --size-8: 2.49rem;
  --size-9: 2.99rem;
  /* @portal colors */
  /* @plugin Helium Colors */
  --color-gray-1: hsl(0deg, 0%, 96%);
  --color-gray-2: hsl(0deg, 0%, 92%);
  --color-gray-3: hsl(0deg, 0%, 87%);
  --color-gray-4: hsl(0deg, 0%, 80%);
  --color-gray-5: hsl(0deg, 0%, 70%);
  --color-gray-6: hsl(0deg, 0%, 25%);
  --color-gray-7: hsl(0deg, 0%, 15%);
  --color-gray-8: hsl(0deg, 0%, 9%);
  --color-gray-9: hsl(0deg, 0%, 3%);
  --color-gray: var(--color-gray-5);
  --color-red-1: hsl(5deg, 90%, 96%);
  --color-red-2: hsl(5deg, 85%, 90%);
  --color-red-3: hsl(5deg, 90%, 76%);
  --color-red-4: hsl(5deg, 90%, 68%);
  --color-red-5: hsl(5deg, 100%, 60%);
  --color-red-6: hsl(5deg, 90%, 50%);
  --color-red-7: hsl(5deg, 90%, 35%);
  --color-red-8: hsl(5deg, 90%, 15%);
  --color-red-9: hsl(5deg, 100%, 3%);
  --color-red: var(--color-red-5);
  --color-orange-1: hsl(24deg, 90%, 96%);
  --color-orange-2: hsl(24deg, 85%, 90%);
  --color-orange-3: hsl(24deg, 90%, 76%);
  --color-orange-4: hsl(24deg, 90%, 68%);
  --color-orange-5: hsl(24deg, 100%, 60%);
  --color-orange-6: hsl(24deg, 90%, 50%);
  --color-orange-7: hsl(24deg, 90%, 35%);
  --color-orange-8: hsl(24deg, 90%, 15%);
  --color-orange-9: hsl(24deg, 100%, 3%);
  --color-orange: var(--color-orange-5);
  --color-yellow-1: hsl(55deg, 90%, 96%);
  --color-yellow-2: hsl(55deg, 85%, 90%);
  --color-yellow-3: hsl(55deg, 90%, 76%);
  --color-yellow-4: hsl(55deg, 90%, 68%);
  --color-yellow-5: hsl(55deg, 100%, 60%);
  --color-yellow-6: hsl(55deg, 90%, 50%);
  --color-yellow-7: hsl(55deg, 90%, 35%);
  --color-yellow-8: hsl(55deg, 90%, 15%);
  --color-yellow-9: hsl(55deg, 100%, 3%);
  --color-yellow: var(--color-yellow-5);
  --color-green-1: hsl(90deg, 90%, 96%);
  --color-green-2: hsl(90deg, 85%, 90%);
  --color-green-3: hsl(90deg, 90%, 76%);
  --color-green-4: hsl(90deg, 90%, 68%);
  --color-green-5: hsl(90deg, 100%, 60%);
  --color-green-6: hsl(90deg, 90%, 50%);
  --color-green-7: hsl(90deg, 90%, 35%);
  --color-green-8: hsl(90deg, 90%, 15%);
  --color-green-9: hsl(90deg, 100%, 3%);
  --color-green: var(--color-green-5);
  --color-cyan-1: hsl(173deg, 90%, 96%);
  --color-cyan-2: hsl(173deg, 85%, 90%);
  --color-cyan-3: hsl(173deg, 90%, 76%);
  --color-cyan-4: hsl(173deg, 90%, 68%);
  --color-cyan-5: hsl(173deg, 100%, 60%);
  --color-cyan-6: hsl(173deg, 90%, 50%);
  --color-cyan-7: hsl(173deg, 90%, 35%);
  --color-cyan-8: hsl(173deg, 90%, 15%);
  --color-cyan-9: hsl(173deg, 100%, 3%);
  --color-cyan: var(--color-cyan-5);
  --color-blue-1: hsl(220deg, 90%, 96%);
  --color-blue-2: hsl(220deg, 85%, 90%);
  --color-blue-3: hsl(220deg, 90%, 76%);
  --color-blue-4: hsl(220deg, 90%, 68%);
  --color-blue-5: hsl(220deg, 100%, 60%);
  --color-blue-6: hsl(220deg, 90%, 50%);
  --color-blue-7: hsl(220deg, 90%, 35%);
  --color-blue-8: hsl(220deg, 90%, 15%);
  --color-blue-9: hsl(220deg, 100%, 3%);
  --color-blue: var(--color-blue-5);
  --color-purple-1: hsl(270deg, 90%, 96%);
  --color-purple-2: hsl(270deg, 85%, 90%);
  --color-purple-3: hsl(270deg, 90%, 76%);
  --color-purple-4: hsl(270deg, 90%, 68%);
  --color-purple-5: hsl(270deg, 100%, 60%);
  --color-purple-6: hsl(270deg, 90%, 50%);
  --color-purple-7: hsl(270deg, 90%, 35%);
  --color-purple-8: hsl(270deg, 90%, 15%);
  --color-purple-9: hsl(270deg, 100%, 3%);
  --color-purple: var(--color-purple-5);
  --color-pink-1: hsl(320deg, 90%, 96%);
  --color-pink-2: hsl(320deg, 85%, 90%);
  --color-pink-3: hsl(320deg, 90%, 76%);
  --color-pink-4: hsl(320deg, 90%, 68%);
  --color-pink-5: hsl(320deg, 100%, 60%);
  --color-pink-6: hsl(320deg, 90%, 50%);
  --color-pink-7: hsl(320deg, 90%, 35%);
  --color-pink-8: hsl(320deg, 90%, 15%);
  --color-pink-9: hsl(320deg, 100%, 3%);
  --color-pink: var(--color-pink-5);
}

/* Themes */
[data-theme=light] {
  --background: var(--color-gray-1);
  --h-color: var(--color-gray-7);
  --color-text: var(--color-gray-6);
  --color-text-strong: var(--color-gray-9);
  --color-shadow: hsla(0deg, 0%, 0%, 0.1);
  --color-border: var(--color-gray-3);
  --color-border-strong: var(--color-gray-5);
  --code-background: var(--color-gray-2);
  --mark-background: var(--color-yellow-3);
  --button-background: var(--color-gray-2);
  --button-color: var(--color-gray-7);
  --button-hover-background: var(--color-gray-3);
}

[data-theme=dark] {
  --background: var(--color-gray-9);
  --h-color: var(--color-gray-2);
  --color-text: var(--color-gray-4);
  --color-text-strong: var(--color-gray-1);
  --color-shadow: hsla(0deg, 0%, 0%, 0.3);
  --color-border: var(--color-gray-7);
  --color-border-strong: var(--color-gray-6);
  --code-background: var(--color-gray-8);
  --mark-background: var(--color-yellow-5);
  --button-background: var(--color-gray-8);
  --button-hover-background: var(--color-gray-7);
}

* {
  -webkit-tap-highlight-color: transparent;
  -webkit-overflow-scrolling: touch;
  box-sizing: border-box;
  touch-action: manipulation;
}
*:focus {
  outline: 0;
}

html {
  min-height: 100vh;
  scroll-behavior: smooth;
  -moz-osx-font-smoothing: grayscale;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  text-size-adjust: 100%;
  -moz-tab-size: 4;
  tab-size: 4;
  overflow-wrap: break-word;
  word-wrap: break-word;
  font-size: 18px;
}

body {
  min-height: 100vh;
  color: var(--color-text);
  background: var(--body-background);
  line-height: 1.618;
  font-size: clamp(16px, 3vw, 18px);
  font-weight: 400;
  margin: 0 auto;
  padding: var(--size-1);
  max-width: 65ch;
}
body::-webkit-scrollbar {
  width: 12px;
}
body::-webkit-scrollbar-track {
  background: var(--color-gray-9);
}
body::-webkit-scrollbar-thumb {
  border: 3px solid var(--color-gray-9);
  background-clip: padding-box;
  border-radius: 1618px;
  background: var(--color-gray-5);
}
body::-webkit-scrollbar-thumb:hover {
  background: var(--color-gray6);
}
body::-webkit-scrollbar-thumb:active {
  background: var(--color-gray7);
}

@media screen and (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
    text-rendering: optimizeSpeed;
  }
}
b {
  font-weight: bolder;
}

svg text {
  cursor: default;
}

:where(img, audio, video) {
  vertical-align: bottom;
  object-fit: cover;
  max-width: 100%;
}
article :where(img, audio, video) {
  height: auto;
  margin-bottom: var(--size-8);
}

svg:not([fill]) {
  fill: currentColor;
}

table {
  border-collapse: collapse;
}

blockquote {
  text-align: center;
  margin: var(--size-6) 0 var(--size-9);
  padding: var(--size-8) var(--size-9);
  font-weight: 500;
  font-size: var(--size-6);
}

mark {
  background-color: var(--mark-background, var(--color-yellow-4));
  padding: 0.1ch 0.4ch;
}

hr {
  border: 0;
  height: 1px;
  margin: 0 0 var(--size-5);
  background: var(--color-border);
}

:where(h1, .h1) {
  font-size: clamp(2.49rem, 2.5vw, calc(2.49rem + 0.3vw));
}

:where(h2, .h2) {
  font-size: clamp(2.07rem, 2.5vw, calc(2.07rem + 0.3vw));
}

:where(h3, .h3) {
  font-size: clamp(1.73rem, 2.5vw, calc(1.73rem + 0.3vw));
}

:where(h4, .h4) {
  font-size: clamp(1.44rem, 2.5vw, calc(1.44rem + 0.3vw));
}

:where(h5, .h5) {
  font-size: clamp(1.2rem, 2.5vw, calc(1.2rem + 0.3vw));
}

:where(h6, .h6) {
  font-size: clamp(1rem, 2.5vw, calc(1rem + 0.3vw));
}

:where(h1, h2, h3, h4, h5, h6, .h1, .h2, .h3, .h4, .h5, .h6) {
  line-height: calc(2px + 2ex + 2px);
  font-weight: 700;
  margin: 0 0 1ex;
  color: var(--h-color);
  letter-spacing: -0.01em;
}

a {
  display: inline-flex;
  color: var(--link-color);
  text-decoration: none;
}
a:hover {
  color: var(--link-color-hover, var(--color-text-strong));
}
a:focus, a:active {
  color: var(--link-color-hover, var(--color-text-strong));
}

nav > :is(ol,
ul) {
  list-style: none;
  padding: 0;
  margin: 0;
}
nav > :is(ol,
ul) a:not([role=button]) {
  color: var(--color-text);
}
:is(nav > :is(ol,
ul) a:not([role=button]):hover, nav > :is(ol,
ul) a:not([role=button]):focus, nav > :is(ol,
ul) a:not([role=button]):active) {
  color: var(--color-text-strong);
}

article ul {
  list-style: none;
  padding: 0 0 0 1ch;
  margin: 0 0 var(--size-5);
}
article ul li::before {
  content: "•";
  margin-inline-end: 0.6ch;
}
article ul ol li:before {
  content: "";
}
article ul li :where(ol, ul) {
  padding-inline-start: 4ch !important;
  margin: 0;
}

:not(nav, summary ~) ol {
  list-style: decimal inside;
}

p {
  margin: 0 0 1.618em;
}

small {
  font-size: var(--size-1);
}

abbr[title] {
  cursor: help;
}

:not(pre) > code {
  line-height: 1.2;
  font-size: clamp(var(--size-1), 3vw, var(--size-2));
  background: var(--code-background);
  border-radius: var(--radius-3);
  padding: 0.2em;
}

pre {
  line-height: 1.2;
  position: relative;
  padding: var(--space-5);
  background: var(--code-background);
  white-space: pre;
  margin: 0 0 var(--space-6);
  border: 1px solid var(--color-border);
  overflow: auto;
  max-height: 700px;
  width: fit-content;
  width: stretch;
  border-radius: var(--radius-6);
}
pre code {
  word-wrap: normal;
  font-size: clamp(var(--size-1), 3vw, var(--size-2));
}

:where(button, [type=button], [type=reset], [type=submit]) {
  text-decoration: none;
  -webkit-appearance: none;
  cursor: pointer;
  position: relative;
  overflow: hidden;
  background: var(--button-background);
  color: var(--button-color);
  font-size: var(--size-2);
  font-weight: 700;
  line-height: 1.1;
  border: 0;
  padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-3);
  gap: var(--space-1);
}
:where(button, [type=button], [type=reset], [type=submit]):hover {
  background: var(--button-hover-background);
}
@media screen and (min-width: 769px) {
  :where(button, [type=button], [type=reset], [type=submit]) {
    width: fit-content;
  }
}
:where(button, [type=button], [type=reset], [type=submit])::-moz-focus-inner {
  border: 0;
}
:where(button, [type=button], [type=reset], [type=submit])[disabled] {
  cursor: not-allowed;
  filter: grayscale(80%);
}

form {
  gap: var(--space-4);
}

textarea {
  resize: vertical;
}

select {
  border: 0;
  background: transparent;
  color: var(--input-color);
  -webkit-text-fill-color: var(--input-color);
  font-size: var(--size-2);
  width: stretch;
}
select:focus {
  outline: 0;
}

label {
  width: stretch;
  display: inline-block;
  font-weight: 500;
  font-size: var(--size-1);
  margin-bottom: 0.618rem;
  text-align: start;
}

:where(input:where([type=text], [type=tel], [type=email], [type=password]), textarea, .select-wrapper) {
  transition: all 0.5s ease;
  width: stretch;
  padding: 0.85rem;
  letter-spacing: 0.5px;
  border: var(--input-border);
  background-color: var(--input-background);
  color: var(--input-color);
  -webkit-text-fill-color: var(--input-color);
  font-size: var(--size-2);
  border-radius: var(--input-border-radius);
}
:where(input:where([type=text], [type=tel], [type=email], [type=password]), textarea, .select-wrapper):hover {
  transition: all 0.5s ease;
  background: var(--input-background-hover);
  border: var(--input-border-hover);
}
:where(input:where([type=text], [type=tel], [type=email], [type=password]), textarea, .select-wrapper):focus, :where(input:where([type=text], [type=tel], [type=email], [type=password]), textarea, .select-wrapper):active {
  transition: all 0.5s ease;
  background: var(--input-background-focus);
  border: var(--input-border-focus);
}
:where(input:where([type=text], [type=tel], [type=email], [type=password]), textarea, .select-wrapper)::placeholder {
  color: var(--input-color);
  opacity: 0.5;
}

input[type=checkbox] {
  margin-right: 1rem;
  clip-path: polygon(0 0);
}

input[disabled] {
  cursor: not-allowed;
}

html {
  border-radius: var(--radius-1);
}

/*# sourceMappingURL=helium.css.map */
