@font-face {
  font-family: "Inter";
  src: local("Inter"), url("/css/fonts/Inter.ttf") format("truetype");
}

@font-face {
  font-family: "DM Serif Display";
  src: local("DM Serif Display"), url("/css/fonts/DMSerifDisplay-Regular.ttf") format("truetype");
}

@property --bg-light {
  syntax: '<color>';
  inherits: true;
  initial-value: #6B2261;
}

@property --bg-medium {
  syntax: '<color>';
  inherits: true;
  initial-value: #2B1331;
}

@property --bg-dark {
  syntax: '<color>';
  inherits: true;
  initial-value: #230B27;
}

@property --bg-light-transparent {
  syntax: '<color>';
  inherits: true;
  initial-value: #6B226100;
}

@property --bg-medium-transparent {
  syntax: '<color>';
  inherits: true;
  initial-value: #2B133100;
}

@property --bg-dark-transparent {
  syntax: '<color>';
  inherits: true;
  initial-value: #230B2700;
}

@property --translucid {
  syntax: '<color>';
  inherits: true;
  initial-value: #0004;
}

@property --text {
  syntax: '<color>';
  inherits: true;
  initial-value: #ddd;
}

@property --text-p {
  syntax: '<color>';
  inherits: true;
  initial-value: #988e9e;
}

@property --text-link {
  syntax: '<color>';
  inherits: true;
  initial-value: #889ebe;
}

@property --text-dark {
  syntax: '<color>';
  inherits: true;
  initial-value: #ccc;
}

html {
  font-size: 1rem;
}

:focus {
  outline-offset: 0.2em;
  outline: 1px dashed;
}

.skip-to-content {
  position: absolute;
  top: 0.5rem;
  height: 0.5rem;
  width: 1px;
  height: 1px;
  overflow: clip;
  z-index: 1;
  background: var(--bg-dark);
  color: var(--text);
  outline-offset: -2px;
  z-index: 9;
  box-sizing: border-box;
}

.skip-to-content:focus {
  outline: 1px dashed;
  outline-offset: -2px;
  overflow: auto;
  width: auto;
  height: auto;
  padding: 1rem;
}

body {
  --image-gradient: url(/images/000-gradient.webp);
  --image-arches: url(/images/000-arch.webp);
  --b: #ffffff0b;
  --v: radial-gradient(farthest-side at 50% 100%, #0000 calc(25% - 1px), var(--b) 25%, #0000 calc(25% + 1px) calc(50% - 1px), var(--b) 50%, #0000 calc(50% + 1px) calc(75% - 1px), var(--b) 75%, #0000 calc(75% + 1px) calc(100% - 1px), var(--b) 100%, #0000 calc(100% + 1px));
  --bg-light: #6B2261;
  --bg-medium: #2B1331;
  --bg-dark: #230B27;
  --bg-light-transparent: #6B226100;
  --bg-medium-transparent: #2B133100;
  --bg-dark-transparent: #230B2700;
  --translucid: #0004;
  --text: #ddd;
  --text-p: #a99eae; /* #988e9e; */
  --text-link: #889ebe;
  --text-dark: #ccc;
  --max: 990px;
  margin: 0;
  background:
    /* radial-gradient(max(80vh, 50vw) 80vh at 50% max(120vh, calc(100% + 15vh)), var(--bg-light) 10%, var(--bg-light-transparent)),
    linear-gradient(var(--bg-medium), var(--bg-medium-transparent) 25vh 90vh, var(--bg-medium) 155vh),
    radial-gradient(max(80vh, 50vw) 80vh at 50% 100vh, var(--bg-light) 10%, var(--bg-light-transparent)),
    var(--v) 0 0 / 100px 50px fixed,
    var(--v) 50px 25px / 100px 50px fixed, */
    var(--image-gradient) 50% 45vh / 100vw 80vw no-repeat,
    var(--image-gradient) 50% calc(100% + 40vw) / 100vw 80vw no-repeat,
    linear-gradient(var(--bg-medium), var(--bg-medium-transparent) 25vh 90vh, var(--bg-medium) 155vh),
    var(--image-arches) 50% 50% / 100px 50px,
    var(--bg-dark);
  font-family: Inter, Helvetica, sans-serif;
  color: var(--text);
  min-height: 100vh;
}

body:has(.dark-2:checked),
body.light {
  --b: #00000008;
  --bg-light: #fff;
  --bg-medium: #eee;
  --bg-dark: #ddd;
  --bg-light-transparent: #fff0;
  --bg-medium-transparent: #eee0;
  --bg-dark-transparent: #ddd0;
  --text: #222;
  --text-link: #345;
  --text-dark: #111;
  --translucid: #0001;
  --text-p: #786e7e;
  --image-gradient: url(/images/fff-gradient.webp);
  --image-arches: url(/images/fff-arch.webp);
}

body:has(.dark-2:checked) img[src*="logo-dark.svg"],
body.light img[src*="logo-dark.svg"] {
  filter: invert(1);
}

body:has(.dark-2:checked) .why img,
body.light .why img,
body:has(.dark-2:checked) .why svg,
body.light .why svg {
  filter: invert(1);
  background: #fff2;
  opacity: 0.8;
}

body:has(.dark-2:checked) b,
body.light b,
body:has(.dark-2:checked) strong,
body.light strong {
  color: color-mix(in srgb, currentcolor 80%, #000 20%);
}


a,
a:link,
a:visited {
  color: var(--text-link);
  font-weight: 400;
}

a:hover {
  text-decoration: none;
}

p {
  font-size: 1.25em;
  font-weight: 300;
  color: var(--text-p);
  line-height: 1.65;
  max-width: 65ch;
}

b,
strong {
  font-weight: 500;
  color: color-mix(in srgb, currentcolor 80%, #fff 20%);
}

.container {
  max-width: var(--max);
  margin: auto;
  padding: 1em;
  box-sizing: border-box;
}

:where(h1, h2, h3, h4, h5, h6) {
  margin: 0;
  height: 60%;
  font-family: "DM Serif Display", Inter, Helvetica, sans-serif;
  font-weight: 500;
}

h1 + h2 {
  font-family: Inter, Helvetica, sans-serif;
}

:where(h1, h2, h3, h4, h5, h6) img {
  height: 100%;
  max-width: 100%;
}

:where(h1, h2, h3, h4, h5, h6) span {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: clip;
}

header {
  position: sticky;
  top: 0;
  height: 4em;
  background: var(--bg-dark);
  box-shadow: 0 1em 2em 1em var(--bg-dark);
  z-index: 2;
}

header h2 {
  transition: 0.15s;
}

.home header h2 {
  display: none;
  opacity: 0;
}

header h2.visible {
  display: block;
  opacity: 1;
  transition: 0.5s;
}

header>div {
  display: flex;

  justify-content: space-between;
  align-items: center;
  max-width: var(--max);
  margin: auto;
  padding: 0 1em;
  height: 100%;
  flex-wrap: wrap;
}

.home header:has(h2:not(.visible))>div {
  justify-content: flex-end;
}

.menu-options {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 1rem;
}

.menu-options nav {
  display: inline-block;
}

nav ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  gap: 0.75em;
  font-size: 0.95em;

  @media (width > 500px) {
    gap: 1.5em;
  }
}

nav ul a {
  text-decoration: none;
}

nav ul a:hover {
  text-decoration: underline;
}


.hero {
  margin: auto auto;
  max-width: var(--max);
  text-align: center;
  box-sizing: border-box;
  margin-top: 8em;
  padding: 25px;
  box-sizing: border-box;
}

.hero h1 {
  margin-bottom: 1em;
}

.hero h1 img {
  width: 100%;
  max-width: 450px;
}


.hero h2 {
  font-size: 3.25em;
  font-weight: 600;
  color: var(--text-dark);
  text-wrap: balance;
  text-transform: capitalize;
}

.hero p {
  font-size: 1.66em;
  color: var(--text-p);
  text-wrap: balance;
}

@keyframes shake {
  0%, 100% {
    transform: translate(0, 0)
  }
  25% {
    transform: translate(-15%, 0);
  }
  75% {
    transform: translate(15%, 0);
  }
}

body:not(.light) input[type="submit"],
body:not(.light) .hero a.btn {
  filter: invert(1);
}

input[type="submit"],
.hero a.btn {
  font-size: 1.25em;
  padding: 0.75em 1.5em;
  background: #000;
  color: #eee;
  text-decoration: none;
  border-radius: 0.35em;
  transition: background 0.5s, color 0.5s;
  white-space: nowrap;
  display: inline-flex;
  align-items: center;
}

input[type="submit"]::after,
.hero a.btn::after {
  content: "";
  display: inline-block;
  margin-inline-start: 0.75em;
  width: 0.7em;
  height: 0.7em;
  background: #eee;
  clip-path: polygon(0 0, 45% 45%, 45% 0, 100% 50%, 45% 100%, 45% 55%, 0 100%);
  transition: translate 0.25s;
  translate: 0;
  animation: shake 4s linear infinite;
}

input[type="submit"]:hover::after,
.hero a.btn:hover::after {
  translate: 0.125em;
  transition: translate 0.25s cubic-bezier(0.68, -0.6, 0.32, 3.6);
}

input[type="submit"]:hover,
.hero a.btn:hover {
  background: #181818;
  color: #fff;
}

main {
  padding-top: 8em;
  overflow: hidden;
}

main .container,
main section {
  margin-top: 4em;
  margin-bottom: 6em;
}

main .container h1,
main section h1 {
  text-align: center;
  font-size: 3.25em;
  padding: 0.25em 1em;
  text-wrap: balance;
  margin-bottom: 1em;
}

main .container h2,
main section h2 {
  text-align: center;
  font-size: 2.75em;
  padding: 0.25em 1em;
  text-wrap: balance;
}

main .container h3,
main section h3 {
  font-size: 2.25em;
}

main .container h4,
main section h4 {
  font-size: 2em;
}

main .container h5,
main section h5 {
  font-size: 1.9em;
}

.what {
  text-align: center;
  margin-bottom: 16em;
}

.what img {
  max-width: 614px;
  object-fit: contain;
  object-position: bottom center;
  aspect-ratio: 614 / 410;
  width: 100%;
  height: auto;
}

.what p {
  text-wrap: balance;
  max-width: 600px;
  margin: 1rem auto;
  line-height: 1.65;
}


.why {
  display: flex;
  flex-wrap: wrap;
  list-style: none;
  margin: 0;
  padding: 0;
  gap: 1em;
  margin-top: 3em;
  max-width: calc(var(--max) * 1.2);
  margin: auto auto;
  margin-top: 4em;
  padding: 1em;
  box-sizing: border-box;
}

.why li {
  background: var(--translucid);
  border-radius: 1em;
  flex: 1 1 calc(330px - 2em);
  display: grid;
  grid-template-columns: auto 1fr;
  padding: 1.25em;
  box-sizing: border-box;
  gap: 0.75em 1em;
}

.why img,
.why svg {
  width: 2em;
  height: 2em;
  /* object-fit: cover;
  align-self: center; */
  grid-row: 1/3;
  background: var(--translucid);
  border-radius: 0.5em;
  padding: 1em;
}

.why h3 {
  margin: 0 0 0.25em 0;
  align-self: flex-end;
  font-size: 1.25em !important;
  font-family: Inter, Helvetica, sans-serif;
}

.why span {
  grid-column: 2;
  color: var(--text-p);
  align-self: flex-start;
  text-wrap: balance;
  font-size: 0.95em;
  font-weight: 300;
  line-height: 1.5;
}

.clients {
  text-align: center;
  margin-bottom: 16em;
  max-width: calc(var(--max) * 1.2);
  margin-inline: auto;
    margin-block: 8em 6em;
}

.clients blockquote {
  margin: 1em auto;
}

.clients p {
  text-align: center;
  margin: 3rem auto;
  text-wrap: balance;
}

.testimonials {
  list-style: "";
  display: grid;
  grid-template-columns: 1fr;
  gap: 3rem;
  margin: 1rem;
  padding: 0;

  @media (width > 750px) {
    grid-template-columns: 1fr 1fr;
  }
}

.testimonials p {
  font-size: 1em;
  text-align: center;
  margin: 1rem auto;
  text-wrap: balance;
  text-wrap: pretty;
}

.testimonials blockquote {
  position: relative;
margin-block-start: 0;
}

.testimonials blockquote p:first-child {
  margin-block-start: 0;
}

.testimonials blockquote p:last-child {
  margin-block-end: 0;
}

.testimonials li {
  padding: 1rem;
  background: #00000008;
  background: linear-gradient(#0000, #00000008);
  border: 1px solid #0001;
  border-radius: 1em;
  position: relative;
  display: grid;
  place-content: center;
}

.testimonials li blockquote::before {
  content: '“';
  font-family: "DM Serif Display", Inter, Helvetica, sans-serif;
  position: absolute;
  display: block;
  z-index: -1;
  font-size: 15em;
  opacity: 0.07;
  left: 20%;
  top: 0.5em;
  line-height: 0;
  translate: -50% 0%;
}
.testimonials li blockquote::after {
  content: '”';
  font-family: "DM Serif Display", Inter, Helvetica, sans-serif;
  position: absolute;
  display: block;
  z-index: -1;
  font-size: 15em;
  opacity: 0.07;
  left: 80%;
  bottom: 0.175em;
  line-height: 0;
  translate: -50% 0%;
}

.testimonials figcaption {
  font-size: 1.125em;
}




footer {
  max-width: var(--max);
  margin: auto auto;
  margin-top: 8em;
  margin-bottom: 2em;
  padding: 1em;
  box-sizing: border-box;
}

footer>div {
  display: flex;
  justify-content: space-between;
}

footer nav ul {
  flex-direction: column;
  gap: 0.5em;

}

footer nav ul a {
  display: flex;
  align-items: center;
  gap: 0.25em;
}

footer nav img {
  width: 1em;
  height: 1em;
}


footer img {
  width: 100px;
  height: auto;
}

footer div {
  color: var(--text-p);
}

footer h2 {
  height: auto;
  text-align: right;
}


details {
  border-radius: 1rem;
  border: 1px solid var(--translucid);
  overflow: hidden;
  margin-bottom: 1rem;
  background: linear-gradient(#0000, #0001);
}

summary {
  font-size: 1.5rem;
  background: linear-gradient(#00000018, #00000008);;
  padding: 1rem 1.5rem;
  border-radius: 1rem;
  font-family: "DM Serif Display", Inter, Helvetica, sans-serif;
}

summary::marker {
  content: none;
}

details[open] summary {
  border-radius: 1rem 1rem 0 0;
}

summary:focus {
  outline-offset: -0.25rem;
}

details>div {
  padding: 0 1rem;

}

.privacy-policy main li,
.terms-of-service main li {
  font-size: 1.25em;
  color: var(--text-p);
  line-height: 1.5;
  max-width: 65ch;
}

form label {
  font-size: 0.9em;
}

form input,
form textarea {
  color: var(--text);
  background: var(--translucid);
  border: 1px solid var(--translucid);
  border-radius: 0.4rem;
  padding: 0.5em;
  height: 3em;
  font-size: 1em;
  width: 100%;
  /* width: calc(100% - 2em); */
  box-sizing: border-box;
  font-family: Inter, Arial, Helvetica, sans-serif;
}

form input::placeholder,
form textarea::placeholder {
  font-weight: 300;
  opacity: 0.75;
}

form textarea {
  height: 6em;
  resize: vertical;
}
/* 
form input[type="submit"] {
  background: var(--bg-dark);
  font-size: 1em;
  min-height: 2em;
  box-sizing: content-box;
  border-top-color: #fff2;
} */

form input[type="submit"] {
  font-size: 1em;
  cursor: pointer;
}

#contact-form {
  display: grid;
  grid-template-columns: 1fr;
  gap: 3rem;
  align-items: start;

  @media (width >= 750px) {
    grid-template-columns: 1fr 1fr;
  }
}

#contact-form section {
  margin: 0;
}

.alert {
  padding: 1em;
  box-sizing: border-box;
  background: #3a3a;
  color: #fff;
  border-radius: 0.4em;
}

.alert.error {
  background: #a33a;
}

.container.download ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  gap: 1em;
  justify-content: center;
}

.container.download img {
  max-width: 100%;
}

ul.projects {
  margin: 0 auto;
  padding: 0;
  list-style: none;
}

li.project {
  display: grid;
  grid-template-rows: 1fr minmax(33%, auto);
  grid-template-columns: 2fr 1fr;
  gap: 2rem;
  min-height: 66vh;
  margin-bottom: 10vh;
  position: relative;
  padding: 1rem;
}



li.project::before {
  content: "";
  grid-row: 2/3;
  grid-column: 1/3;
  /* background: linear-gradient(#0000, #0001); */
  background-color: #0001;
  display: block;
  width: 110%;
  height: 105%;
  inset: 0;
  position: relative;
  position: absolute;
  z-index: -1;
  transform: translate(-5%);
  border-radius: 0.5rem 0.5rem 1rem 1rem;
}

.project-desc,
.project-image {
  grid-row: 1/3;
  display: flex;
  flex-direction: column;
  align-self: end;
}

li.project img {
  max-height: 100%;
  max-width: 100%;
  object-fit: contain;
  object-position: bottom center;
  image-rendering: pixelated;
}

@media (max-width: 600px) {
  html {
    font-size: 0.8rem;
  }

  header {
    font-size: 1.333rem;
    height: 6rem;
    padding: 1rem 0;
  }

  footer nav ul {
    font-size: 1.25em;
  }

  .why {
    font-size: 1.1em;
  }

  .why span {
    font-size: 1em;
  }

  li.project {
    display: flex;
    flex-direction: column;
  }
}




/* DARK TOGGLE */
@property --x {
  syntax: '<percentage>';
  inherits: true;
  initial-value: 35%;
}

@property --c1 {
  syntax: '<color>';
  inherits: true;
  initial-value: #00002e;
}

@property --c2 {
  syntax: '<color>';
  inherits: true;
  initial-value: #593d92;
}

@property --c3 {
  syntax: '<color>';
  inherits: true;
  initial-value: #ddf;
}

@property --c4 {
  syntax: '<color>';
  inherits: true;
  initial-value: #593d92;
}

@property --x1 {
  syntax: '<length>';
  inherits: true;
  initial-value: 0px;
}

@property --x2 {
  syntax: '<length>';
  inherits: true;
  initial-value: 0px;
}

@property --x3 {
  syntax: '<length>';
  inherits: true;
  initial-value: 0px;
}

@property --x4 {
  syntax: '<length>';
  inherits: true;
  initial-value: 0px;
}

@keyframes moveStar1 {
  0% {
    --x1: 0em;
  }

  100% {
    --x1: 2em;
  }
}

@keyframes moveStar2 {
  0% {
    --x2: 0em;
  }

  100% {
    --x2: 2em;
  }
}

@keyframes moveStar3 {
  0% {
    --x3: 0em;
  }

  100% {
    --x3: 2em;
  }
}

@keyframes moveStar4 {
  0% {
    --x4: 0em;
  }

  100% {
    --x4: 2em;
  }
}

.dark-2~span {
  width: 1px;
  height: 1px;
  position: absolute;
  clip-path: polygon(0 0, 1px 1px);
  overflow: clip;
  display: none;
}

.dark-2+span {
  display: block;
}

.dark-2:checked+span {
  display: none;
}

.dark-2:checked+span+span {
  display: block;
}

.dark-2 {
  --c1: var(--bg-dark); /* #00002e; */
  --c2: #4e1b4b88; /* #593d92; */
  --c3: #ddfd;
  --c4: #593d9255;
  --x: 35%;
  --x1: 1.5em;
  --x2: 1.5em;
  --x3: 1.5em;
  --x4: 1.5em;
  appearance: none;
  position: relative;
  font-size: 2em;
  height: 1em;
  width: 2em;
  box-sizing: content-box;
  outline: 1px solid #fff4;
  border-radius: 1em;
  background-image: linear-gradient(var(--c1), #0000 85%);
  background-clip: border-box;
  background-color: var(--c2);
  overflow: hidden;
  color: inherit;
  transition:
    background-color 0.3s,
    --x 0.3s,
    --c1 0.3s,
    --c2 0.3s,
    --c3 0.2s,
    --c4 0.2s;
}

.dark-2::before {
  content: "";
  inset: 0;
  position: absolute;
  background:
    conic-gradient(at 96% calc(100% - 0.1em), #0000 150deg, #dde 0 210deg, #0000 0) var(--x1) 0.5em / 100% 100%,
    conic-gradient(at 96% 0.1em, #dde 30deg, #0000 0 330deg, #dde 0) var(--x1) 0.43em / 100% 100%,
    conic-gradient(at 96% calc(100% - 0.06em), #0000 150deg, #dde 0 210deg, #0000 0) var(--x2) 0.25em / 100% 100%,
    conic-gradient(at 96% 0.06em, #dde 30deg, #0000 0 330deg, #dde 0) var(--x2) 0.21em / 100% 100%,
    conic-gradient(at 96% calc(100% - 0.06em), #0000 150deg, #dde 0 210deg, #0000 0) var(--x3) 0.85em / 100% 100%,
    conic-gradient(at 96% 0.06em, #dde 30deg, #0000 0 330deg, #dde 0) var(--x3) 0.81em / 100% 100%,
    conic-gradient(at 96% calc(100% - 0.075em), #0000 150deg, #dde 0 210deg, #0000 0) var(--x4) 0.65em / 100% 100%,
    conic-gradient(at 96% 0.075em, #dde 30deg, #0000 0 330deg, #dde 0) var(--x4) 0.6em / 100% 100%;
  animation:
    moveStar1 4.75s -3s linear infinite,
    moveStar2 5.5s -1.75s linear infinite,
    moveStar3 5s -4.17s linear infinite,
    moveStar4 5.25s -2.5s linear infinite;
  filter: drop-shadow(0 0 0.05em #fff);
  pointer-events: none;
}

.dark-2::after {
  content: "";
  position: absolute;
  height: 80%;
  aspect-ratio: 1;
  border-radius: 50%;
  border: 1px solid #0000;
  left: 0.5em;
  top: 50%;
  transform: translate(-50%, -50%);
  background-image:
    radial-gradient(circle at 25% 45%, var(--c3) 0.05em, #0000 0),
    radial-gradient(circle at 24% 44%, var(--c4) 0.05em, #0000 0),
    radial-gradient(circle at 55% 25%, var(--c3) 0.075em, #0000 0),
    radial-gradient(circle at 54% 24%, var(--c4) 0.075em, #0000 0),
    radial-gradient(circle at 65% 85%, var(--c4) 0.065em, #0000 0),
    radial-gradient(circle at 64% 84%, var(--c4) 0.063em, #0000 0),
    radial-gradient(circle at 75% 75%, var(--c4) 0.025em, #0000 0),
    radial-gradient(circle at 74% 74%, var(--c4) 0.023em, #0000 0),
    radial-gradient(circle at 97% 51%, var(--c4) 0.075em, #0000 0),
    radial-gradient(circle at 96% 50%, var(--c4) 0.073em, #0000 0),
    radial-gradient(at var(--x) 30%, #0000 10%, var(--c2) 80%);
  background-clip: padding-box;
  background-repeat: no-repeat;
  background-color: #ddf;
  z-index: 1;
  box-shadow: 0 0 0.2em 0.0125em #fff8;
  transition:
    box-shadow 0.5s,
    background-color 0.3s,
    left 0.3s;
  pointer-events: none;
}

.dark-2:focus {
  outline: 1px dashed;
  outline-offset: 2px;
}

.dark-2:checked {
  --c1: #ff3300;
  --c2: #ffcea1;
  --c3: #ddf0;
  --c4: #593d9200;
  --x: 65%;
  background-color: #ff993c;
}

.dark-2:checked::after {
  background-color: #fee;
  left: calc(100% - 0.5em);
  box-shadow: 0 0 0.2em 0.0125em #fffc;
}

.dark-2:checked::before {
  background:
    radial-gradient(at calc(100% - 0.2em) 100%, #fff 0.2em, #0000 0) var(--x1) 0.5em / 100% 100%,
    radial-gradient(20% 60% at calc(100% - 0.15em) 100%, #fff 30%, #0000 0) var(--x1) 0.5em / 100% 100%,
    radial-gradient(at calc(100% - 0.2em) 100%, #fff 0.2em, #0000 0) var(--x2) 0.21em / 100% 100%,
    radial-gradient(20% 60% at calc(100% - 0.15em) 100%, #fff 30%, #0000 0) var(--x2) 0.21em / 100% 100%,
    radial-gradient(20% 50% at calc(100% - 0.22em) 100%, #fff 30%, #0000 0) var(--x2) 0.21em / 100% 100%,
    radial-gradient(at calc(100% - 0.3em) 100%, #fff 0.2em, #0000 0) var(--x3) 0.81em / 100% 100%,
    radial-gradient(20% 60% at calc(100% - 0.25em) 100%, #fff 30%, #0000 0) var(--x3) 0.81em / 100% 100%,
    radial-gradient(20% 45% at calc(100% - 0.2em) 100%, #fff 30%, #0000 0) var(--x3) 0.81em / 100% 100%,
    radial-gradient(at calc(100% - 0.2em) 100%, #fff 0.2em, #0000 0) var(--x4) 0.6em / 100% 100%,
    radial-gradient(20% 60% at calc(100% - 0.15em) 100%, #fff 30%, #0000 0) var(--x4) 0.6em / 100% 100%;
  opacity: 0.8;
  z-index: 2;
}


.dark-2[disabled] {
  opacity: 0.5;
  animation-play-state: paused !important;
  transition-duration: 0s !important;
}

.dark-2[disabled]::before,
.dark-2[disabled]::after {
  animation-play-state: paused !important;
  transition-duration: 0s !important;
}



@media (prefers-reduced-motion) {
  .dark-2,
  .dark-2::before,
  .dark-2::after {
    animation-play-state: paused !important;
    transition-duration: 0s !important;
  }
}

@media print {
  .dark-2,
  .dark-2::before,
  .dark-2::after {
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
  }
}





/* ICON ANIMATIONS ON HOME */
#meter-needle {
  rotate: -10deg;
  transform-origin: 45% 75%;
  transition: rotate 0.5s;
}

#performance-and-speed:hover #meter-needle {
  rotate: 18deg;
}

#meter-bg {
  fill: #fff0;
  transition: fill 0.35s;
}

#performance-and-speed:hover #meter-bg {
  fill: #fff3;
}

#accessibility-in-mind [fill] {
  fill: #fff0;
  transition: fill 0.35s, rotate 0.5s cubic-bezier(0.68, -0.6, 0.32, 1.6), translate 0.5s cubic-bezier(0.68, -0.6, 0.32, 1.6);
  translate: 0 0;
  rotate: 0;
  transform-origin: 50% 30%;
}

#accessibility-in-mind:hover [fill] {
  fill: #fff3;
  rotate: 10deg;
}

#accessibility-in-mind:hover circle {
  translate: 0 0.5em;
}

#security-and-compliance #lock-fill {
  fill: #fff0;
  transition: fill 0.35s;
}

#security-and-compliance:hover #lock-fill {
  fill: #fff3;
}

#security-and-compliance #lock-line {
  rotate: 0deg;
  transition: rotate 0.5s;
  transform-origin: 50% 30%;
}

#security-and-compliance:hover #lock-line {
  rotate: -25deg;
}

#scalability-and-flexibility #arrow {
  rotate: 0;
  transform-origin: 50% 30%;
  translate: 0 0;
  transition: 
    translate 0.5s, 
    rotate 0.5s;
}

#scalability-and-flexibility:hover #arrow {
  rotate: -10deg;
  translate: -0.1rem 0.1rem;
  transition: 
    translate 0.5s cubic-bezier(0.68, -0.6, 0.32, 2.6), 
    rotate 0.5s;
}

#seo-integration circle {
  fill: #fff0;
  transition: fill 0.35s;
}

#seo-integration g {
  rotate: 0deg;
  transition: rotate 0.5s;
  transform-origin: 60% 30%;
}

#seo-integration:hover circle {
  fill: #fff3;
}

#seo-integration:hover g {
  rotate: -10deg;
}

#focus-driven-engineering path {
  fill: #fff0;
  transform-origin: 50% 30%;
  transition: fill 0.35s, translate 0.5s, scale 0.4s;
}

#focus-driven-engineering:hover #rocket-ship {
  fill: #fff3;
  translate: 0.5rem -0.5rem;
}

#focus-driven-engineering:hover #rocket-fire {
  translate: -0.6rem 0.5rem;
  scale: 1.1 1.0;
}