:root {
  font-size: 16px;
  /*colors*/

  --background-color-one: #f1f1f1;
  --background-color-one-muted: hsl(0, 0%, 98%);
  --background-color-two: #7595ff;
  --background-color-two-muted: hsl(226, 94%, 81%);
  /*blue*/
  --primary-color-one: #7595ff;
  --primary-color-one-mid: hsl(226, 98%, 82%);
  --primary-color-one-light: hsl(226, 90%, 88%);
  --primary-color-one-muted: hsl(226, 94%, 81%);
  /*pink*/
  --primary-color-two-strong: #ffc0b3;
  --primary-color-two: #ffc0b3;
  --primary-color-two-light: #ffd6ce;
  --primary-color-two-muted: #fcf6f5;
  /*dark grey*/
  --primary-color-three: #1d1d1b;
  --primary-color-three-muted: hsla(60, 4%, 11%, 0.574);
  --primary-color-three-light: hsla(60, 4%, 11%, 0.071);
  /*green*/
  --primary-color-four: rgb(149, 203, 186);
  --primary-color-four-muted: hsl(162, 28%, 72%);
  --primary-color-four-light: hsl(163, 11%, 76%);

  --secondary-color-one: #f1f1f1;
  --secondary-color-one-muted: #f1f1f1;
  --secondary-color-two: #f1f1f1;
  --secondary-color-two-muted: #f1f1f1;

  --pre-color-one: rgba(223, 223, 223);
  --pre-font-color-one: #1d1d1b;

  --font-color-one: #1d1d1b;
  --font-color-one-muted: #1d1d1b;
  --font-color-one--inverted: #f1f1f1;
  --font-color-two: rgba(150, 150, 150);
  --font-color-two-muted: rgba(255, 255, 255);
  --font-link-color-one: #1d1d1b;
  --font-link-color-one-muted: #1d1d1b;
  --font-link-color-two: rgba(255, 255, 255);
  --font-link-color-two-muted: #1d1d1b;

  --white: rgb(255, 255, 255);
  --white-off: rgb(242, 242, 242);
  --black: rgb(0, 0, 0);
  --grey-dark: rgb(45, 47, 44);
  --grey: rgb(90 94, 88);
  --grey-medium: rgb(112, 116, 108);
  --grey-regular: rgb(148, 153, 141);
  --grey-light: rgb(195, 197, 192);
  --grey-ultra-light: rgb(230, 230, 230);
  --grey-ultra-light--transparent: rgba(230, 230, 230, 0.3);
  /*
    --green: rgb(61,214,11);
    --green-dark: rgb(0,73,52);
    --green-acid: rgb(0, 255, 65);

    --purple: rgb(132,100,249);
    --pink: rgb(255,21,154);
    --grey-gradient: linear-gradient(122deg, rgba(90,94,88,1) 0%, rgba(150,155,142,1) 100%);
    */

  --green: var(--primary-color-one);
  --purple: var(--primary-color-two);
  --pink: var(--primary-color-three);
  --grey-gradient: var(--background-color-one);

  /*homepage fonts*/
  --hp-super-title-font-size: 6.875rem;
  --hp-super-title-line-height: 7.175rem;
  --hp-super-title-two-font-size: 5rem;
  --hp-super-title-two-line-height: 5.375rem;
  --hp-number-font-size: 3.75rem;
  --hp-title-serif-font-size: 2.75rem;
  --hp-title-serif-line-height: 4rem;
  --hp-title-sans-font-size: 1.66rem;
  --hp-title-sans-line-height: 1.825rem;
  --hp-mobile-display-title-serif-font-size: 3.8rem;
  --hp-mobile-display-title-serif-line-height: 4.3rem;
  --hp-mobile-title-serif-font-size: 3.75rem;
  --hp-mobile-title-serif-line-height: 4.525rem;
  --hp-mobile-title-sans-font-size: 1.75rem;
  --hp-mobile-title-sans-line-height: 2.562rem;
  --hp-mobile-number-font-size: 2.875rem;
  --hp-body-font-size: 1rem;
  --hp-body-line-height: 1.562rem;
  --hp-label-font-size: 0.875rem;
  --hp-caption-font-size: 0.75rem;
  --hp-caption-two-font-size: 0.875rem;
  --hp-uppercase-letter-spacing: 0.05rem;
  --hp-uppercase-font-weight: 400;

  /*knowlegde guide*/
  --kn-para-line-height: 1.5;
  --kn-mobile-title-serif-font-size: 2.187rem;
  --kn-mobile-title-serif-line-height: 2.75rem;

  /*phase out cmt-base-measure in favour of this*/
  /*
    --base-measure: 0.4375rem;
    */
  /*paragraph*/
  --paragraph-spacing: 2rem;

  /*padding units*/
  --padding-unit: 0.2rem;
  /*margin units*/
  --margin-unit: 0.2rem;
  /*base measure*/
  --base-measure: 0.2rem;

  /*bezier curves*/
  --slide-curve: cubic-bezier(0.2, 0.35, 0.62, 0.82);
}

@font-face {
  font-family: "Montserrat";
  font-style: normal;
  font-optical-sizing: auto;
  font-weight: 400;
  font-stretch: 150%;
  font-smooth: always;
  -webkit-font-smoothing: antialiased;
  font-display: swap;
  unicode-range: U+000-5FF;
  src:
    local("Montserrat"),
    url("https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,100..900;1,100..900&display=swap")
      format("woff2");
}

/*animations*/

*,
::after,
::before {
  font-family: "Montserrat", sans-serif;
  font-size: 16px;
  font-weight: 400;
  box-sizing: border-box;
}

*::-webkit-resizer {
  display: none;
}

/*scrollbar stuff for chrome and safari
*::-webkit-scrollbar {
  width: 1em;
}
scrollbar-width: thick;
    scrollbar-color: var(--greenDark) var(--white);

*::-webkit-scrollbar-track {
  background: var(--white);
}

*::-webkit-scrollbar-thumb {
  background-color: var(--greenDark);
  border-radius: 0.3em;
  border: 2px solid transparent;
  margin: 0.1em;
  background-clip: padding-box;
}
*/

*:focus {
  /* background-color: var(--grey-ultra-light);*/
  outline: 1px var(--green);
}

html {
  font-size: 16px;
  background: var(--background-color-one);
}

body {
  font-size: 16px;
  font-weight: 400;
  background: var(--background-color-one);
  color: var(--font-color-one);
  margin: 0em;
  overflow-x: hidden;
}

strong {
  font-weight: 600;
  font-size: inherit;
  font-family: inherit;
}

article {
  display: block;
}
section {
  display: block;
}

details {
  border: none;
  cursor: pointer;
}

summary::marker {
  content: "";
}

summary::-webkit-details-marker {
  display: none;
}

blockquote {
  padding: 0rem;
  margin: 0rem;
}

/* headers and text */
/*
h1 {
    font-family: daVinci, serif;
    font-size: var(--hp-title-serif-font-size);
    line-height: var(--hp-title-serif-line-height);
    margin: 0em;
    font-weight: 400;
}

h2,
h3,
h4,
h5,
h6 {
    font-family: neutoSans, sans-serif;
    font-size: var(--hp-title-sans-font-size);
    line-height: var(--hp-title-sans-line-height);
    margin: 0em;
    font-weight: 400;
}
*/
h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: Montserrat, serif;
  font-size: var(--hp-title-sans-font-size);
  line-height: 1;
  margin: 0em;
  font-weight: 400;
}

@media only screen and (min-width: 80rem) {
}

/*docs related styles*/
.docs-content-container h2 {
  font-family: Montserrat, serif;
  font-weight: 300;
  font-size: var(--kn-mobile-title-serif-font-size);
  line-height: var(--kn-mobile-title-serif-line-height);
  margin: calc(var(--cmt-base-measure) * 1) 0rem
    calc(var(--cmt-base-measure) * 5) 0rem;
}
.docs-content-container h3 {
  font-family: Montserrat, sans-serif;
  font-weight: 400;
  font-size: var(--hp-title-sans-font-size);

  margin: calc(var(--cmt-base-measure) * 5) 0rem
    calc(var(--cmt-base-measure) * 0) 0rem;
}
.docs-content-container h4 {
  font-family: Montserrat, sans-serif;
  font-weight: 400;
  font-size: 1.2rem;
  margin: calc(var(--cmt-base-measure) * 2) 0rem
    calc(var(--cmt-base-measure) * 0) 0rem;
}
.docs-content-container h5 {
  font-family: Montserrat, sans-serif;
  font-weight: 400;
  font-size: var(--cmt-bode-one-font-size);
  text-transform: uppercase;
  margin: calc(var(--cmt-base-measure) * 12) 0rem
    calc(var(--cmt-base-measure) * 0) 0rem;
}
.docs-content-container code {
  background-color: var(--grey-dark);
  color: var(--white-off);
  padding: calc(var(--cmt-base-measure) * 0.5);
}
.docs-content-container pre {
  background-color: var(--grey-dark);
  color: var(--white-off);
  padding: calc(var(--cmt-base-measure) * 2);
  overflow-x: scroll;
  max-width: calc(100vw - (var(--cmt-base-measure) * 2));
}
.docs-content-container p a,
.docs-content-container li a {
  text-decoration: underline;
}
.docs-content-container li {
  margin: var(--cmt-base-measure) 0rem;
}
.docs-content-container p {
  line-height: var(--kn-para-line-height);
  margin-bottom: calc(var(--cmt-base-measure) * 2);
  margin-top: var(--cmt-base-measure);
}

/* cmt related styles */
.dashboard-layout-container h1,
.dashboard-layout-container h2,
.dashboard-layout-container h3,
.dashboard-layout-container h4,
.dashboard-layout-container h5,
.dashboard-layout-container h6 {
  font-family: Montserrat, sans-serif;
  font-weight: 400;
  /*margin: 0rem 0rem var(--cmt-full-padding) 0rem;*/
}

/* re-think this */

h1 {
  font-size: 6rem;
  letter-spacing: -1.5;
}

h2 {
  font-size: 2.4rem;
  letter-spacing: -0.5;
}

h3 {
  font-size: 2.4rem;
  letter-spacing: 0;
}

h4 {
  font-size: 1.8rem;
  letter-spacing: 0.25;
}

h5 {
  font-size: 1.5rem;
  letter-spacing: 0;
}

h6 {
  font-size: 1.22rem;
  letter-spacing: 0.15;
}

a,
div {
  font-family: inherit;
  font-size: inherit;
  font-weight: inherit;
  color: inherit;
  text-decoration: none;
}
a:hover {
  text-decoration: underline;
  color: var(--primary-color-one);
}

p {
  margin: var(--cmt-base-measure) 0em;
  line-height: 1.5;
  cursor: default;
  font-size: var(--hp-body-font-size);
}

p a {
  text-decoration: underline;
}

sub,
sup {
  font-size: 0.7em;
  color: inherit;
}
pre {
  margin: 0em;
  font-style: italic;
}

pre {
  background-color: var(--grey-dark);
  color: var(--white-off);
  padding: calc(var(--cmt-base-measure) * 2);
  overflow-x: scroll;
  max-width: calc(100vw - (var(--cmt-base-measure) * 2));
  margin: var(--base-measure) auto;
}

.error {
  color: var(--font-color-one);
  font-size: var(--hp-label-font-size);
  text-align: left;
  font-weight: 600;
  letter-spacing: 0.0045rem;
  margin: 0em 0em 0em 0em;
  padding-bottom: var(--base-measure);
}
.error a {
  text-decoration: underline;
}

*:hover > .tooltip-wrapper > .tooltip {
  opacity: 1 !important;
  visibility: initial !important;
}

/* form components*/
label {
  display: block;
  margin: calc(var(--cmt-base-measure) * 2) 0em var(--cmt-base-measure) 0em;
  font-size: var(--cmt-label-one-font-size);
  letter-spacing: var(--hp-uppercase-letter-spacing);
  font-weight: var(--hp-uppercase-weight);
  color: var(--black);
  padding: calc(var(--cmt-base-measure) * 1) var(--cmt-base-measure)
    calc(var(--cmt-base-measure) * 0) calc(var(--cmt-base-measure) * 0);
  text-align: left;
}

input,
textarea {
  width: 100%;
  background-color: transparent;
  border: none;
  border-bottom: 1px solid var(--background-color-one);
  font-weight: 300;
  font-size: var(--hp-body-font-size);
  letter-spacing: 0.031rem;
  text-align: left;
  color: var(--grey-dark);
  padding: calc(var(--cmt-base-measure) * 1) var(--cmt-base-measure)
    calc(var(--cmt-base-measure) * 1) calc(var(--cmt-base-measure) * 1);
}
input:focus,
textarea:focus {
  background-color: var(--background-color-one);
}
input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:active,
input:-webkit-autofill:focus {
  background-color: #ffffff !important;
  color: #555 !important;
  -webkit-box-shadow: 0 0 0 1000px white inset !important;
  -webkit-text-fill-color: #555555 !important;
}

input::placeholder,
textarea::placeholder {
  color: var(--grey-dark);
}

input[type="checkbox"],
label input[type="checkbox"] {
  display: inline;
  width: max-content;
}
label input[type="checkbox"] {
  padding-bottom: 0.01rem;
  margin-bottom: calc(var(--cmt-base-measure) * 2);
  margin-left: calc(var(--cmt-base-measure) * 1);
}

button,
input[type="submit"] {
  display: block;
  font-family: inherit;
  font-size: inherit;
  letter-spacing: inherit;
  background-color: var(--primary-color-one);
  border: 2px solid var(--primary-color-one);
  border-radius: 2.4rem;
  /*
	width: max-content;
  */
  width: 100%;
  color: var(--font-color-one);
  text-transform: inherit;
  cursor: pointer;
  line-height: inherit;
  margin: calc(var(--margin-unit) * 4) calc(var(--margin-unit) * 0);
  padding: calc(var(--padding-unit) * 3) calc(var(--padding-unit) * 6);
}

button:hover {
  background-color: var(--primary-color-three);
  border: 2px solid var(--primary-color-three);
}
button.button-big {
  padding: calc(var(--base-measure) * 9);
  width: 100%;
  margin-bottom: 0rem;
}
button.button-used {
  border-color: var(--primary-color-one-light);
}
button.button-used:hover,
button.button-used--dark:hover {
  border-color: var(--primary-color-one);
}
button.button-used--dark {
  border-color: var(--primary-color-one);
}
button.button--dark-bg:hover {
  background-color: var(--grey-regular);
}

button:focus,
button.button-with-icon:focus {
}

/*secondary buttons*/
.button--secondary {
}
.button--secondary:hover {
}

/* checkbox */
input[type="checkbox"] {
  transform: scale(1.2);
  padding: var(--base-measure);
}

/*public hompage section buttons*/
.public-container .button {
  padding: calc(var(--cmt-base-measure) * 4);
}
button.button--invert {
  font-weight: 300;
  font-size: var(--baseFontSize);
  letter-spacing: 0.078;
  line-height: 1;
  text-align: center;
  text-transform: uppercase;
  color: var(--black);
  background-color: var(--white);
  border: 1px solid var(--black);
  border-radius: 1.7em;
  padding: 0.7rem 2em;
  margin: var(--cmt-base-measure) 0rem 0rem 0rem;
  width: max-content;
  cursor: pointer;
}

button.button--invert-selected {
  color: var(--light-green);
  background-color: var(--green);
}

button.button--invert:hover {
  color: var(--grey-regular);
  border-color: var(--grey-regular);
}
button.button--disabled {
  color: var(--grey-light);
  background: var(--grey-ultra-light);
  cursor: not-allowed;
}

button.link-button {
  border: none;
  color: var(--black);
  background-color: transparent;
  font-size: 0.925em;
  font-weight: 500;
  border-radius: 0em;
  text-transform: none;
  width: 100%;
  padding: 0.4em;
}
button.link-button:hover > button {
  text-decoration: underline;
}

.dot {
  clip-path: polygon(0 4%, 78% 1%, 100% 100%, 0 100%);
  height: calc(var(--cmt-base-measure) * 6);
  width: calc(var(--cmt-base-measure) * 6);
  background-color: var(--black);
}

/*accent boxes*/
@keyframes accentClipOne {
  from {
    clip-path: polygon(0 0, 100% 0%, 100% 100%, 0 100%);
  }

  to {
    clip-path: polygon(0 5%, 100% 0%, 94% 84%, 13% 100%);
  }
}

@keyframes accentClipTwo {
  from {
    clip-path: polygon(0 0, 100% 0%, 100% 100%, 0 100%);
  }

  to {
    clip-path: polygon(0 4%, 78% 1%, 100% 100%, 0 100%);
  }
}

@keyframes accentClipThree {
  from {
    clip-path: polygon(0 0, 100% 0%, 100% 100%, 0 100%);
  }

  to {
    clip-path: polygon(0 8%, 100% 0%, 100% 78%, 10% 100%);
  }
}
/*accent-boxes*/
@keyframes accentSkewOne {
  from {
    transform: skewY(0deg);
  }

  to {
    transform: skewY(5deg);
  }
}

@keyframes accentSkewOneBack {
  from {
    transform: skewY(0deg);
  }

  to {
    transform: skewY(-5deg);
  }
}

@keyframes accentSkewTwo {
  from {
    transform: skewY(0deg) skewX(0deg);
  }

  to {
    transform: skewY(-5deg);
  }
}

@keyframes accentSkewTwoBack {
  from {
    transform: skewY(0deg) skewX(0deg);
  }

  to {
    transform: skewY(5deg);
  }
}

/*functional css*/
.hide {
  display: none !important;
}

.relative {
  position: relative;
  width: 100%;
  height: 100%;
}

.show-mobile {
  display: block;
}

.hide-mobile {
  display: none;
}

.show-tablet {
  display: none;
}

.hide-tablet {
  display: none;
}

.show-desktop {
  display: none;
}

.hide-desktop {
  display: block;
}

@media only screen and (min-width: 32rem) {
  .show-tablet {
    display: block;
  }

  .hide-tablet {
    display: none;
  }
}

@media only screen and (min-width: 80rem) {
  .show-mobile {
    display: none;
  }

  .hide-mobile {
    display: block;
  }

  .show-desktop {
    display: block;
  }

  .hide-desktop {
    display: none !important;
  }
}

@media only screen and (min-width: 120rem) {
  .show-desktop {
    display: block;
  }
}
