@charset "UTF-8";
:root {
  --font-body: "loew-variable", system-ui, sans-serif;
  --font-cond: "loew-variable", system-ui, sans-serif;
  --font-disp: "havelock-titling-variable", system-ui, sans-serif;
  --font-alt: "havelock-titling-variable", system-ui, sans-serif;
  --fs-300: clamp(0.94rem, calc(0.92rem + 0.08vw), 0.98rem);
  --fs-400: clamp(1.13rem, calc(1.06rem + 0.33vw), 1.31rem);
  --fs-500: clamp(1.35rem, calc(1.21rem + 0.69vw), 1.75rem);
  --fs-600: clamp(1.62rem, calc(1.37rem + 1.24vw), 2.33rem);
  --fs-700: clamp(1.94rem, calc(1.54rem + 2.03vw), 3.11rem);
  --fs-800: clamp(2.33rem, calc(1.7rem + 3.15vw), 4.14rem);
  --fs-900: clamp(2.8rem, calc(1.85rem + 4.74vw), 5.52rem);
  --fs-1000: clamp(5.2rem, calc(2.46rem + 6.5vw), 12rem);
  --clr-base--100: rgb(58, 69, 102);
  --clr-base-000: rgb(46, 52, 76);
  --clr-base-100: rgb(37, 40, 58);
  --clr-base-200: rgb(22, 20, 28);
  --clr-base-300: rgb(10, 9, 12);
  --clr-accent-000: rgb(255, 255, 255);
  --clr-accent-100: rgb(235, 245, 253);
  --clr-accent-200: rgb(208, 234, 255);
  --clr-accent-300: rgb(186, 215, 238);
  --clr-accent-400: rgb(146, 181, 204);
  --clr-accent-500: rgb(95, 131, 156);
  --clr-green-000: rgb(159, 214, 73);
  --clr-green-100: rgb(140, 198, 63);
  --clr-green-200: rgb(121, 182, 61);
  --clr-green-300: rgb(102, 167, 59);
  --clr-green-400: rgb(88, 154, 57);
  --clr-red-000: rgb(255, 74, 74);
  --clr-red-100: rgb(235, 39, 39);
  --clr-red-200: rgb(203, 36, 37);
  --clr-red-300: rgb(171, 33, 55);
  --clr-red-400: rgb(148, 30, 53);
  --clr-gradient-full: linear-gradient(
    90deg,
    rgba(140, 198, 63, 1) 0%,
    rgba(22, 20, 28, 1) 50%,
    rgba(235, 39, 39, 1) 100%
  );
  --clr-gradient-bracket: linear-gradient(
    90deg,
    rgb(140, 198, 63) 0%,
    rgb(140, 198, 63) 5%,
    rgb(255, 255, 255) 5%,
    rgb(255, 255, 255) 95%,
    rgb(235, 39, 39) 95%,
    rgb(235, 39, 39) 100%
  );
  --clr-gradient-bracket-vert: linear-gradient(
    180deg,
    rgba(140, 198, 63, 1) 0%,
    rgba(140, 198, 63, 1) 5%,
    rgba(255, 255, 255, 0) 5%,
    rgba(255, 255, 255, 0) 95%,
    rgba(235, 39, 39, 1) 95%,
    rgba(235, 39, 39, 1) 100%
  );
  --clr-gradient-bracket-horz: linear-gradient(
    90deg,
    rgba(140, 198, 63, 1) 0%,
    rgba(140, 198, 63, 1) 2.5%,
    rgba(255, 255, 255, 0) 2.5%,
    rgba(255, 255, 255, 0) 97.5%,
    rgba(235, 39, 39, 1) 97.5%,
    rgba(235, 39, 39, 1) 100%
  );
  --color-scheme: light;
  --border-radius: 2px;
  --trans-lazy: linear(
    0,
    0.008 1.1%,
    0.031 2.2%,
    0.129 4.8%,
    0.257 7.2%,
    0.671 14.2%,
    0.789 16.5%,
    0.881 18.6%,
    0.957 20.7%,
    1.019 22.9%,
    1.063 25.1%,
    1.094 27.4%,
    1.114 30.7%,
    1.112 34.5%,
    1.018 49.9%,
    0.99 59.1%,
    1
  );
  interpolate-size: allow-keywords;
}

@view-transition {
  navigation: auto;
}
::-moz-selection {
  color: white;
  background: var(--clr-red-100);
}
::selection {
  color: white;
  background: var(--clr-red-100);
}

html {
  color-scheme: var(--color-scheme);
  scroll-behavior: smooth;
  scrollbar-gutter: stable;
}
html::-webkit-scrollbar {
  width: 10px;
}
html::-webkit-scrollbar-track {
  background: var(--clr-base-300);
}
html::-webkit-scrollbar-thumb {
  border-radius: 0;
  background: var(--clr-base-100);
}

body {
  margin: 0;
  font-family: var(--font-body);
  font-size: var(--fs-400);
  font-variation-settings: "ital" 0, "wght" 300, "wdth" 70;
  line-height: 1.6;
  color: var(--clr-base-300);
  background-color: var(--clr-accent-100);
  background-image: url("/assets/img/back-pixels-1440.webp");
  background-position: center;
}

h1,
h2,
h3,
h4,
h5,
h6,
p,
ul,
ol,
dl,
blockquote,
figure,
iframe,
details {
  -webkit-margin-before: 1rem;
          margin-block-start: 1rem;
  margin-inline: 2rem;
}

p:last-of-type {
  -webkit-margin-after: 1rem;
          margin-block-end: 1rem;
}

p:has(.btn) + h2,
p:has(.btn) + h3 {
  margin-top: 2rem;
}

b,
strong {
  font-variation-settings: "wght" 500;
}

hr {
  margin: 2rem;
  border: 2px solid;
  border-image-source: var(--clr-gradient-full);
  border-image-slice: 1;
}

blockquote {
  color: var(--clr-accent-200);
  font-variation-settings: "ital" 0, "wght" 500, "wdth" 70;
}
@supports ((-webkit-background-clip: text) or (background-clip: text)) {
  blockquote {
    background: linear-gradient(45deg, var(--clr-accent-200), var(--clr-red-100));
    -webkit-background-clip: text;
            background-clip: text;
    color: transparent;
  }
}
blockquote p {
  margin-inline: 0;
}
blockquote.bq__quo::before {
  content: open-quote;
}
blockquote.bq__quo::after {
  content: close-quote;
}

details {
  border-left: 5px solid currentColor;
  -webkit-transition: border 500ms var(--trans-lazy);
  transition: border 500ms var(--trans-lazy);
}
details::details-content {
  -webkit-transition: all 500ms var(--trans-lazy), content-visibility 500ms allow-discrete;
  transition: all 500ms var(--trans-lazy), content-visibility 500ms allow-discrete;
  height: 0;
  overflow: clip;
}
details[open] {
  border-left: 5px solid var(--clr-green-100);
}
details[open]::details-content {
  height: auto;
}
details[open] summary {
  height: auto;
  color: var(--clr-green-100);
}
details[open] summary::after {
  content: "\f146";
}
details summary {
  padding: 0.5rem;
  margin: 0;
  font-weight: 700;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  cursor: ns-resize;
}
details summary::marker {
  content: "";
}
details summary::after {
  content: "\f0fe";
  font-family: "Font Awesome 6 Pro";
  font-weight: 100;
  width: 1.25rem;
  aspect-ratio: 1;
  display: block;
}
details .details-content {
  padding: 1.5rem 0rem;
  font-size: var(--fs-300);
  /* We need margin-trim … */
}
details .details-content :first-child {
  margin-top: 0;
}
details .details-content :last-child {
  margin-bottom: 0;
}

code {
  display: block;
  background: none;
  white-space: pre;
  overflow-x: auto;
  max-width: 100%;
  min-width: 100px;
  padding: 1rem;
  background-color: var(--clr-accent-400);
}

menu {
  padding: 0;
  margin: 0;
}

aside {
  min-width: 280px;
}

a {
  color: var(--clr-accent-100);
  text-decoration-color: var(--clr-red-100);
  text-decoration-style: dotted;
  text-underline-offset: 3px;
  -webkit-transition: color 250ms ease-in;
  transition: color 250ms ease-in;
}
a:hover, a:focus {
  color: var(--clr-red-100);
}
a:has(> img), a:has(> svg) {
  display: block;
}

img.full-width {
  width: 100%;
  max-height: 45vh;
  -o-object-fit: cover;
     object-fit: cover;
  grid-column: full-width;
}

ol {
  padding-left: 0;
}
ol li {
  margin-left: 1rem;
  padding-left: 0.5rem;
}

ul {
  list-style: square;
  -webkit-padding-start: 2rem;
          padding-inline-start: 2rem;
  max-width: 65ch;
}
ul li::marker {
  color: var(--clr-green-100);
}

dl dt,
dl dd {
  margin: 0;
  border-let: 1px solid currentColor;
}
dl dt {
  font-variation-settings: "ital" 0, "wght" 500, "wdth" 70;
}
h1,
h2,
h3,
h4,
h5 {
  text-box: trim-both cap alphabetic;
}
h1 a,
h2 a,
h3 a,
h4 a,
h5 a {
  text-decoration: none;
}

h1 {
  font-family: var(--font-disp);
  font-size: var(--fs-800);
  font-variation-settings: "ital" 0, "wght" 600, "wdth" 100;
  line-height: 110%;
}

h2 {
  font-family: var(--font-disp);
  font-size: var(--fs-600);
  font-variation-settings: "ital" 0, "wght" 400, "wdth" 100;
  line-height: 110%;
}

h3 {
  font-family: var(--font-disp);
  font-size: var(--fs-500);
  font-variation-settings: "ital" 0, "wght" 100, "wdth" 60;
  line-height: 110%;
}

h4 {
  font-family: var(--font-disp);
  font-size: var(--fs-400);
  font-variation-settings: "ital" 0, "wght" 800, "wdth" 60;
  line-height: 110%;
}

h5 {
  font-family: var(--font-disp);
  font-size: var(--fs-300);
  font-variation-settings: "ital" 0, "wght" 100, "wdth" 40;
  line-height: 110%;
}

h6 {
  -webkit-margin-after: 0;
          margin-block-end: 0;
}

table {
  border-collapse: collapse;
  width: calc(100% - 4rem);
  margin: 2rem;
  border-top: 1px solid currentColor;
  border-left: 1px solid currentColor;
}
table th,
table td {
  border-bottom: 1px solid currentColor;
  border-right: 1px solid currentColor;
  padding: 0.5rem;
  text-align: left;
}

header,
footer,
main {
  container-type: inline-size;
}

main {
  position: relative;
  container-name: site-shell;
  min-height: calc(100dvh - 16.6666666667dvw);
}

main.content-grid::before {
  content: "";
  position: absolute;
  inset: 0;
  grid-column: content;
  z-index: -1;
  border-left: 1px dashed var(--clr-accent-200);
  border-right: 1px dashed var(--clr-accent-200);
}

nav ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 1rem;
}
nav ul li > ul {
  list-style: none;
}

nav a {
  color: inherit;
  text-decoration: none;
}

nav a:hover,
nav a:focus {
  color: var(--clr-accent-500);
  text-decoration: none;
}

/* System Styles */
.flow > * + * {
  margin-top: var(--flow-spacing, 1em);
}

/*------- Typeface and Block -------*/
.text__center {
  text-align: center;
}
.text__center img {
  margin-inline: auto !important;
}

.text__col-2 {
  -webkit-columns: 2;
     -moz-columns: 2;
          columns: 2;
}

.text__col-3 {
  -webkit-columns: 3;
     -moz-columns: 3;
          columns: 3;
}

.text__bold-1 {
  font-weight: 500;
}

.text__bold-2 {
  font-weight: 700;
}

.text__bold-3 {
  font-weight: 900;
}

.text__sml {
  font-size: var(--fs-300);
}

.text__lrg {
  font-size: var(--fs-500);
}

.text__upper {
  text-transform: uppercase;
}

.text__green-1 {
  color: var(--clr-green-100);
}

.text__green-4 {
  color: var(--clr-green-400);
}

.text__red-1 {
  color: var(--clr-red-100);
}

.text__base-0 {
  color: var(--clr-base--100);
}

.text__base-1 {
  color: var(--clr-base-100);
}

.text__base-2 {
  color: var(--clr-base-200);
}

.text__base-3 {
  color: var(--clr-base-300);
}

.text__accent-1 {
  color: var(--clr-accent-100);
}

.text__accent-2 {
  color: var(--clr-accent-200);
}

.text__green-emb {
  color: var(--clr-green-200);
  font-variation-settings: "ital" 0, "wght" 800, "wdth" 70;
  text-shadow: -1px -1px 1px var(--clr-green-000), 1px 1px 1px var(--clr-green-400);
}

.text__accent-emb {
  color: var(--clr-accent-300);
  font-variation-settings: "ital" 0, "wght" 800, "wdth" 70;
  text-shadow: -1px -1px 1px var(--clr-accent-400), 1px 1px 1px var(--clr-accent-100);
}

.text__base-emb {
  color: var(--clr-base-200);
  font-variation-settings: "ital" 0, "wght" 800, "wdth" 70;
  text-shadow: -1px -1px 1px var(--clr-base-000), 1px 1px 1px var(--clr-base-300);
}

.text__fancy {
  padding-block: 1rem;
}
.text__fancy::before {
  content: "//";
  color: var(--clr-red-100);
  display: inline-block;
  margin-right: 0.75rem;
  translate: 0 -10%;
}

.margin__top {
  -webkit-margin-before: 4rem;
          margin-block-start: 4rem;
}

.margin__btm {
  -webkit-margin-after: 4rem;
          margin-block-end: 4rem;
}

/*------- Responsive -------*/
.visually-hidden {
  clip: rect(0 0 0 0);
  clip-path: inset(50%);
  height: 1px;
  overflow: hidden;
  position: absolute;
  white-space: nowrap;
  width: 1px;
}

.mobile-show {
  display: none;
}

/*------- Tags -------*/
ul.tags {
  margin-block: 1rem;
  margin-inline: 0;
  padding: 0;
  list-style: none;
  margin-inline: 2rem;
  margin-block: 1rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 0.25rem;
}
ul.tags li {
  margin: 0;
  padding: 0;
}
ul.tags > li {
  padding: 0;
  margin: 0;
}
ul.tags > li a {
  display: block;
  padding: 0.5rem;
  color: var(--clr-accent-000);
  border: 1px solid currentColor;
  border-radius: var(--border-radius);
  font-family: var(--font-cond);
  font-size: 70%;
  text-transform: uppercase;
  text-box: trim-both cap alphabetic;
  text-decoration: none;
  -webkit-transition: color 250ms ease-in;
  transition: color 250ms ease-in;
}
ul.tags > li a::before {
  content: "\f02b";
  font-family: "Font Awesome 6 Pro";
  font-weight: 100;
  margin-right: 0.25rem;
}
ul.tags > li a:hover {
  color: var(--clr-base-200);
}
ul.tags .tag--front-end::before {
  content: "\f121";
}
ul.tags .tag--back-end::before {
  content: "\f1c0";
}

/*------- Buttons -------*/
.btn-group {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 0.5rem;
  margin: 1rem 2rem;
}
.btn-group__center {
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.btn-group__stack {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
.btn-group__stack .btn {
  margin-block: 0;
}

button {
  cursor: pointer;
}

.btn,
button,
input[type=submit] {
  display: inline-block;
  padding: 1rem 2rem;
  min-width: -webkit-fit-content;
  min-width: -moz-fit-content;
  min-width: fit-content;
  cursor: pointer;
  color: var(--clr-accent-000);
  background-color: var(--clr-base-200);
  border-top: 1px solid var(--clr-base--100);
  border-left: 1px solid var(--clr-base--100);
  border-bottom: 1px solid var(--clr-base-300);
  border-right: 1px solid var(--clr-base-300);
  border-radius: var(--border-radius);
  font-family: var(--font-disp);
  font-size: var(--fs-300);
  font-variation-settings: "slnt" 0, "wght" 500, "wdth" 50;
  line-height: 120%;
  text-transform: uppercase;
  text-decoration: none;
  text-shadow: none;
  text-box: trim-both cap alphabetic;
  text-shadow: 1px 1px 1px rgba(37, 40, 58, 0.5);
  -webkit-transition: background-color 250ms ease-in, color 250ms ease-in, border 250ms ease-in;
  transition: background-color 250ms ease-in, color 250ms ease-in, border 250ms ease-in;
}
.btn i,
button i,
input[type=submit] i {
  margin-left: 0px;
}
.btn:hover, .btn:active, .btn:focus, .btn:focus-visible,
button:hover,
button:active,
button:focus,
button:focus-visible,
input[type=submit]:hover,
input[type=submit]:active,
input[type=submit]:focus,
input[type=submit]:focus-visible {
  background-color: var(--clr-base-000);
  color: var(--clr-accent-000);
  -webkit-transition: all 250ms ease-in;
  transition: all 250ms ease-in;
}
.btn:disabled,
button:disabled,
input[type=submit]:disabled {
  background-color: var(--clr-base-400);
  color: var(--clr-base-300);
}

.btn__cta {
  border: 0;
  background: -webkit-gradient(linear, left top, right top, from(rgb(140, 198, 63)), color-stop(rgb(37, 40, 58)), to(rgb(235, 39, 39)));
  background: linear-gradient(90deg, rgb(140, 198, 63), rgb(37, 40, 58), rgb(235, 39, 39));
  background-size: 200% 100%;
  background-position: 100% 0;
  -webkit-transition: background-position 0.5s;
  transition: background-position 0.5s;
}
.btn__cta:hover {
  border: 0;
  background-position: 0 0;
}

.btn__green {
  color: var(--clr-accent-000);
  background-color: var(--clr-green-200);
  border-top: 1px solid var(--clr-green-000);
  border-left: 1px solid var(--clr-green-000);
  border-bottom: 1px solid var(--clr-green-300);
  border-right: 1px solid var(--clr-green-300);
}
.btn__green:hover, .btn__green:focus-visible {
  border-top: 1px solid var(--clr-green-000);
  border-left: 1px solid var(--clr-green-000);
  border-bottom: 1px solid var(--clr-green-300);
  border-right: 1px solid var(--clr-green-300);
  background-color: var(--clr-green-100);
  color: var(--clr-accent-000);
  -webkit-transition: all 250ms ease-in;
  transition: all 250ms ease-in;
}

.btn__red {
  color: var(--clr-accent-000);
  background-color: var(--clr-red-200);
  border-top: 1px solid var(--clr-red-000);
  border-left: 1px solid var(--clr-red-000);
  border-bottom: 1px solid var(--clr-red-300);
  border-right: 1px solid var(--clr-red-300);
}
.btn__red:hover, .btn__red:focus-visible {
  border-top: 1px solid var(--clr-red-000);
  border-left: 1px solid var(--clr-red-000);
  border-bottom: 1px solid var(--clr-red-300);
  border-right: 1px solid var(--clr-red-300);
  background-color: var(--clr-red-100);
  color: var(--clr-accent-000);
  -webkit-transition: all 250ms ease-in;
  transition: all 250ms ease-in;
}

.btn__accent {
  color: var(--clr-base-400);
  background-color: var(--clr-accent-300);
  border-top: 1px solid var(--clr-accent-400);
  border-left: 1px solid var(--clr-accent-400);
  border-bottom: 1px solid var(--clr-accent-000);
  border-right: 1px solid var(--clr-accent-000);
  text-shadow: unset;
}
.btn__accent:hover, .btn__accent:focus-visible {
  border-top: 1px solid var(--clr-accent-400);
  border-left: 1px solid var(--clr-accent-400);
  border-bottom: 1px solid var(--clr-accent-000);
  border-right: 1px solid var(--clr-accent-000);
  background-color: var(--clr-accent-200);
  color: var(--clr-base-400);
  -webkit-transition: all 250ms ease-in;
  transition: all 250ms ease-in;
}

.btn__outline {
  color: var(--clr-accent--100);
  border: 1px solid currentColor;
  text-shadow: unset;
  background-color: color-mix(in srgb, currentColor 5%, transparent);
}
.btn__outline:hover, .btn__outline:focus-visible {
  color: var(--clr-accent--100);
  background-color: color-mix(in srgb, currentColor 15%, transparent);
}

.btn__outline--accent {
  color: var(--clr-accent-400);
}

.btn__outline--fancy {
  background-color: transparent;
  color: var(--clr-accent-400);
  border: 1px solid;
  border-image-source: var(--clr-gradient-full);
  border-image-slice: 1;
  text-shadow: unset;
}
.btn__outline--fancy:hover, .btn__outline--fancy:focus-visible {
  background-color: transparent;
  color: var(--clr-accent-300);
}

.btn__neon {
  position: relative;
  display: inline-block;
  padding: 1.5rem 2rem;
  text-decoration: none;
  text-box: trim-both cap alphabetic;
  font-family: var(--font-disp);
  font-size: var(--fs-400);
  color: var(--clr-accent-400);
  background-color: var(--clr-base-300);
  border-radius: var(--border-radius);
  border: 1px solid;
  border-image-source: var(--clr-gradient-full);
  border-image-slice: 1;
  -webkit-transition: padding 250ms var(--trans-lazy), letter-spacing 250ms var(--trans-lazy);
  transition: padding 250ms var(--trans-lazy), letter-spacing 250ms var(--trans-lazy);
}
.btn__neon:hover, .btn__neon:focus-visible {
  color: var(--clr-accent-400);
  background-color: var(--clr-base-300);
  padding: 1.5rem 4rem;
  letter-spacing: 0.2rem;
}
.btn__neon::before {
  content: "";
  display: block;
  position: absolute;
  inset: -5px;
  background: var(--clr-gradient-full);
  z-index: -1;
  -webkit-filter: blur(20px);
          filter: blur(20px);
  -webkit-transition: inset 250ms ease-in, -webkit-filter 250ms ease-in;
  transition: inset 250ms ease-in, -webkit-filter 250ms ease-in;
  transition: inset 250ms ease-in, filter 250ms ease-in;
  transition: inset 250ms ease-in, filter 250ms ease-in, -webkit-filter 250ms ease-in;
}
.btn__neon:hover::before, .btn__neon:focus-visible::before {
  inset: -10px;
  -webkit-filter: blur(10px);
          filter: blur(10px);
}

.btn__block {
  display: block;
  width: 100%;
  max-width: 100%;
  text-align: center;
}

.btn__icon {
  padding: 0.5rem 1rem;
  font-size: 90%;
  text-align: center;
  min-width: 38px;
}

.btn__txtIcon {
  padding: 0.5rem 1rem;
  text-align: center;
}
.btn__txtIcon span {
  font-size: 90%;
}

input[type=submit].btn__lrg,
.btn__lrg {
  font-size: var(--fs-400);
  padding: 1.5rem 2rem;
}

.btn__sml {
  font-size: 0.8rem;
  padding: 0.75rem 1rem;
}

/* ================= Site Messaging ================= */
.modal {
  padding: 1rem;
  max-width: 60ch;
  background-color: var(--clr-accent-400);
  color: var(--clr-base-100);
  border: 12px solid;
  border-image-source: var(--clr-gradient-bracket);
  border-image-slice: 1;
  outline: 0;
  -webkit-box-shadow: 0px 0px 10px rgba(37, 40, 58, 0.25);
          box-shadow: 0px 0px 10px rgba(37, 40, 58, 0.25);
}
.modal::-ms-backdrop {
  background-color: rgba(22, 20, 28, 0.75);
}
.modal::backdrop {
  background-color: rgba(22, 20, 28, 0.75);
}

dialog {
  -webkit-transform: scale(105%);
          transform: scale(105%);
}
dialog::-ms-backdrop {
  -ms-transition: display 500ms allow-discrete, overlay 500ms allow-discrete, opacity 250ms ease, transform 500ms ease;
  transition: display 500ms allow-discrete, overlay 500ms allow-discrete, opacity 250ms ease, transform 500ms ease;
  opacity: 0;
}
dialog, dialog::backdrop {
  -webkit-transition: display 500ms allow-discrete, overlay 500ms allow-discrete, opacity 250ms ease, -webkit-transform 500ms ease;
  transition: display 500ms allow-discrete, overlay 500ms allow-discrete, opacity 250ms ease, -webkit-transform 500ms ease;
  transition: display 500ms allow-discrete, overlay 500ms allow-discrete, opacity 250ms ease, transform 500ms ease;
  transition: display 500ms allow-discrete, overlay 500ms allow-discrete, opacity 250ms ease, transform 500ms ease, -webkit-transform 500ms ease;
  opacity: 0;
}
dialog[open] {
  opacity: 1;
  -webkit-transform: scale(100%);
          transform: scale(100%);
}
dialog[open]::-ms-backdrop {
  opacity: 0.8;
}
dialog[open]::backdrop {
  opacity: 0.8;
}
@starting-style {
  dialog[open]::-ms-backdrop {
    opacity: 0;
  }
  dialog[open], dialog[open]::backdrop {
    opacity: 0;
  }
  dialog[open] {
    -webkit-transform: scale(105%);
            transform: scale(105%);
  }
}

.user-msg {
  margin: 1rem;
  padding: 1rem;
  background-color: var(--clr-accent-400);
}
.user-msg__confirm {
  background-color: var(--clr-green-100);
  color: #ffffff;
}
.user-msg__error {
  background-color: var(--clr-red-100);
  color: #ffffff;
}

.status-msg {
  display: none;
  opacity: 0;
  position: fixed;
  z-index: 6000;
  bottom: 1rem;
  left: 1rem;
  width: 400px;
  text-align: left;
  pointer-events: none;
}
.status-msg p {
  display: inline-block;
  margin: auto;
  padding: 1rem 2rem;
  background-color: var(--clr-light);
  color: #22262a;
  font-size: 16px;
  line-height: 20px;
  -webkit-box-shadow: 0px 0px 5px rbga(63, 59, 120, 0.25);
          box-shadow: 0px 0px 5px rbga(63, 59, 120, 0.25);
  -webkit-transition: all 0.2s ease;
  transition: all 0.2s ease;
}
.status-msg .status-msg--type__confirm {
  background-color: var(--clr-green-200);
  border-left: 10px solid var(--clr-green-100);
}
.status-msg .status-msg--type__error {
  background-color: var(--clr-red-200);
  border-left: 10px solid var(--clr-red-100);
}

/* Notification System */
.notification-shell {
  display: none;
  opacity: 0;
  -webkit-transition: opacity 250ms ease-in 250ms, display 500ms allow-discrete 250ms;
  transition: opacity 250ms ease-in 250ms, display 500ms allow-discrete 250ms;
}
.notification-shell:has(li.notification-item) {
  display: block;
  opacity: 1;
}
@starting-style {
  .notification-shell:has(li.notification-item) {
    opacity: 0;
  }
}
.notification-shell .notification-shell--button {
  position: fixed;
  z-index: 12;
  bottom: 2rem;
  left: 2rem;
  font-size: var(--fs-400);
  background-color: var(--clr-accent-400);
  color: var(--clr-red-100);
  border: 0;
  margin: 0px;
  padding: 0px;
  width: 64px;
  height: 64px;
  -webkit-box-shadow: 0px 0px 10px rgba(37, 40, 58, 0.25);
          box-shadow: 0px 0px 10px rgba(37, 40, 58, 0.25);
  anchor-name: --notification-list;
}
.notification-shell .notification-shell--button i {
  scale: 1.4;
}
.notification-shell .notification-shell--button:hover {
  background-color: var(--clr-accent-200);
  color: var(--clr-base-100);
}
.notification-shell .notification-shell--controls {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 0.25rem;
  margin-block: 0.25rem 0.5rem;
}
.notification-shell .notification-shell--controls button {
  margin-bottom: 0;
}
.notification-shell .notification-shell--list {
  position-anchor: --notification-list;
  margin: 0;
  padding: 0;
  inset: auto;
  bottom: anchor(top);
  left: anchor(left);
  background-color: transparent;
  width: 50ch;
  max-width: 80%;
  border: 0;
  -webkit-transition: opacity 250ms ease-in;
  transition: opacity 250ms ease-in;
}
.notification-shell .notification-shell--list .notification-items {
  margin-block: 1rem;
  margin-inline: 0;
  padding: 0;
  list-style: none;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 0.25rem;
  overflow: clip;
  margin-block: 0;
}
.notification-shell .notification-shell--list .notification-items li {
  margin: 0;
  padding: 0;
}
.notification-shell .notification-shell--list .notification-items .notification-item {
  color: var(--clr-base-200);
  background-color: var(--clr-accent-400);
  padding: 1rem;
  border-left: 2px solid var(--clr-accent-100);
  border-radius: var(--border-radius);
  font-size: var(--fs-300);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: 0.5rem;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  opacity: 1;
  transition-behavior: allow-discrete;
  -webkit-transition: opacity 250ms ease-in, -webkit-transform 250ms ease-in;
  transition: opacity 250ms ease-in, -webkit-transform 250ms ease-in;
  transition: opacity 250ms ease-in, transform 250ms ease-in;
  transition: opacity 250ms ease-in, transform 250ms ease-in, -webkit-transform 250ms ease-in;
}
.notification-shell .notification-shell--list .notification-items .notification-item__critical {
  border-left: 2px solid var(--clr-red-100);
}
.notification-shell .notification-shell--list .notification-items .notification-item__dismiss {
  opacity: 0;
  -webkit-transform: translateX(50px);
          transform: translateX(50px);
}
.notification-shell .notification-shell--list .notification-items .notification-item .nt-list--item__msg {
  border-top: 1px dashed var(--clr-accent-200);
  padding-top: 0.5rem;
  display: none;
  -ms-flex-preferred-size: 100%;
      flex-basis: 100%;
}
.notification-shell .notification-shell--list .notification-items .notification-item:first-child .nt-list--item__msg {
  display: block;
}
@starting-style {
  .notification-shell .notification-shell--list:popover-open {
    opacity: 0;
  }
}

.pixel {
  display: none;
}

@-webkit-keyframes pixel-track {
  from {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  to {
    -webkit-transform: translateX(var(--px-track));
            transform: translateX(var(--px-track));
  }
}

@keyframes pixel-track {
  from {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  to {
    -webkit-transform: translateX(var(--px-track));
            transform: translateX(var(--px-track));
  }
}
/*------- Skip to Main ------- */
.skip-link {
  position: absolute;
  display: inline-block;
  left: 1rem;
  padding: 0.5rem 1rem;
  background-color: var(--clr-accent-000);
  font-size: var(--fs-300);
  text-decoration: none;
  -webkit-transform: translateY(-120%);
          transform: translateY(-120%);
  -webkit-transition: -webkit-transform 250ms ease-in;
  transition: -webkit-transform 250ms ease-in;
  transition: transform 250ms ease-in;
  transition: transform 250ms ease-in, -webkit-transform 250ms ease-in;
}

.skip-link:focus {
  outline: 0;
  -webkit-transform: translateY(0);
          transform: translateY(0);
}

/*------- Actions ------- */
.action__showElem {
  cursor: pointer;
}

/*------- Loader Animation ------- */
.spinner {
  margin: 20px auto;
  background-color: var(--clr-green-100);
  width: 40px;
  height: 40px;
  -webkit-animation: pulseScaleOut 1s infinite ease-in-out;
          animation: pulseScaleOut 1s infinite ease-in-out;
}

@-webkit-keyframes pulseScaleOut {
  0% {
    -webkit-transform: scale(0);
            transform: scale(0);
  }
  100% {
    -webkit-transform: scale(1);
            transform: scale(1);
    opacity: 0;
  }
}

@keyframes pulseScaleOut {
  0% {
    -webkit-transform: scale(0);
            transform: scale(0);
  }
  100% {
    -webkit-transform: scale(1);
            transform: scale(1);
    opacity: 0;
  }
}
/* Form Styles */
/*------- Forms -------*/
form {
  margin: 2rem;
}
form .btn-group {
  margin-inline: 0;
  margin-block: 1rem;
}

fieldset {
  border: 1px solid var(--clr-base--100);
  margin-block: 1rem;
}
fieldset legend {
  color: var(--clr-base--100);
  font-size: var(--fs-400);
  font-variation-settings: "ital" 0, "wght" 600, "wdth" 90;
  text-transform: uppercase;
  padding-inline: 0.5rem;
}
fieldset hr {
  margin: 1rem 0;
  border: 0;
  border-top: 1px dashed var(--clr-base--100);
  border-image-source: unset;
  border-image-slice: unset;
}

label {
  position: relative;
  text-transform: uppercase;
  display: block;
  margin: 1rem 0.5rem;
  font-size: var(--fs-300);
}
label span {
  font-size: 90%;
  display: block;
  text-transform: none;
  color: var(--clr-base--100);
  margin-top: 0.25rem;
}
label:has(input[type=checkbox]) {
  text-transform: unset;
  border: 1px solid var(--clr-ui-100);
  padding: 1rem;
}
label:has(input:invalid)::before, label:has(select:invalid)::before, label:has(textarea:invalid)::before {
  position: absolute;
  display: inline-block;
  right: 10px;
  bottom: 14px;
  content: "*";
  font-family: "Font Awesome 6 Pro";
  font-weight: 700;
  color: var(--clr-red-100);
  pointer-events: none;
  z-index: 10;
}
label:has(select:invalid)::before {
  right: 20px;
}
label.terms-agree {
  text-transform: none;
  color: #000000;
  font-size: 1rem;
  border: 1px solid #000000;
  padding: 1rem;
  cursor: pointer;
}
label.terms-agree::before {
  content: unset !important;
}

select {
  position: relative;
  display: block;
  width: 100%;
  padding: 0.75rem;
  margin: auto;
  color: #252525;
  text-transform: none;
  font-family: inherit;
  font-size: inherit;
  font-variation-settings: "slnt" 0, "wght" 400, "wdth" 100;
  background-color: var(--clr-accent-000);
  border: 0;
  border-bottom: 3px solid var(--clr-accent-300);
  border-radius: var(--border-rad);
  -webkit-transition: all 0.2s ease;
  transition: all 0.2s ease;
}
select:hover {
  border-color: var(--clr-accent-200);
  outline: 0;
}
select:focus, select:focus-within {
  border-color: var(--clr-accent-100);
  outline: 0;
}
select::-webkit-input-placeholder {
  color: var(--clr-accent-200);
  opacity: 1;
}
select::-moz-placeholder {
  color: var(--clr-accent-200);
  opacity: 1;
}
select:-ms-input-placeholder {
  color: var(--clr-accent-200);
  opacity: 1;
}
select::-ms-input-placeholder {
  color: var(--clr-accent-200);
  opacity: 1;
}
select::placeholder {
  color: var(--clr-accent-200);
  opacity: 1;
}
select option {
  font-family: system-ui;
}

textarea {
  position: relative;
  display: block;
  width: 100%;
  padding: 0.75rem;
  margin: auto;
  color: #252525;
  text-transform: none;
  font-family: inherit;
  font-size: inherit;
  font-variation-settings: "slnt" 0, "wght" 400, "wdth" 100;
  background-color: var(--clr-accent-000);
  border: 0;
  border-bottom: 3px solid var(--clr-accent-300);
  border-radius: var(--border-rad);
  -webkit-transition: all 0.2s ease;
  transition: all 0.2s ease;
  field-sizing: content;
  overflow: hidden;
}
textarea:hover {
  border-color: var(--clr-accent-200);
  outline: 0;
}
textarea:focus, textarea:focus-within {
  border-color: var(--clr-accent-100);
  outline: 0;
}
textarea::-webkit-input-placeholder {
  color: var(--clr-accent-200);
  opacity: 1;
}
textarea::-moz-placeholder {
  color: var(--clr-accent-200);
  opacity: 1;
}
textarea:-ms-input-placeholder {
  color: var(--clr-accent-200);
  opacity: 1;
}
textarea::-ms-input-placeholder {
  color: var(--clr-accent-200);
  opacity: 1;
}
textarea::placeholder {
  color: var(--clr-accent-200);
  opacity: 1;
}

input[type=text],
input[type=email],
input[type=password],
input[type=search],
input[type=number],
input[type=url],
input[type=date],
input[type=time] {
  position: relative;
  display: block;
  width: 100%;
  padding: 0.75rem;
  margin: auto;
  color: #252525;
  text-transform: none;
  font-family: inherit;
  font-size: inherit;
  font-variation-settings: "slnt" 0, "wght" 400, "wdth" 100;
  background-color: var(--clr-accent-000);
  border: 0;
  border-bottom: 3px solid var(--clr-accent-300);
  border-radius: var(--border-rad);
  -webkit-transition: all 0.2s ease;
  transition: all 0.2s ease;
}
input[type=text]:hover,
input[type=email]:hover,
input[type=password]:hover,
input[type=search]:hover,
input[type=number]:hover,
input[type=url]:hover,
input[type=date]:hover,
input[type=time]:hover {
  border-color: var(--clr-accent-200);
  outline: 0;
}
input[type=text]:focus, input[type=text]:focus-within,
input[type=email]:focus,
input[type=email]:focus-within,
input[type=password]:focus,
input[type=password]:focus-within,
input[type=search]:focus,
input[type=search]:focus-within,
input[type=number]:focus,
input[type=number]:focus-within,
input[type=url]:focus,
input[type=url]:focus-within,
input[type=date]:focus,
input[type=date]:focus-within,
input[type=time]:focus,
input[type=time]:focus-within {
  border-color: var(--clr-accent-100);
  outline: 0;
}
input[type=text]::-webkit-input-placeholder, input[type=email]::-webkit-input-placeholder, input[type=password]::-webkit-input-placeholder, input[type=search]::-webkit-input-placeholder, input[type=number]::-webkit-input-placeholder, input[type=url]::-webkit-input-placeholder, input[type=date]::-webkit-input-placeholder, input[type=time]::-webkit-input-placeholder {
  color: var(--clr-accent-200);
  opacity: 1;
}
input[type=text]::-moz-placeholder, input[type=email]::-moz-placeholder, input[type=password]::-moz-placeholder, input[type=search]::-moz-placeholder, input[type=number]::-moz-placeholder, input[type=url]::-moz-placeholder, input[type=date]::-moz-placeholder, input[type=time]::-moz-placeholder {
  color: var(--clr-accent-200);
  opacity: 1;
}
input[type=text]:-ms-input-placeholder, input[type=email]:-ms-input-placeholder, input[type=password]:-ms-input-placeholder, input[type=search]:-ms-input-placeholder, input[type=number]:-ms-input-placeholder, input[type=url]:-ms-input-placeholder, input[type=date]:-ms-input-placeholder, input[type=time]:-ms-input-placeholder {
  color: var(--clr-accent-200);
  opacity: 1;
}
input[type=text]::-ms-input-placeholder, input[type=email]::-ms-input-placeholder, input[type=password]::-ms-input-placeholder, input[type=search]::-ms-input-placeholder, input[type=number]::-ms-input-placeholder, input[type=url]::-ms-input-placeholder, input[type=date]::-ms-input-placeholder, input[type=time]::-ms-input-placeholder {
  color: var(--clr-accent-200);
  opacity: 1;
}
input[type=text]::placeholder,
input[type=email]::placeholder,
input[type=password]::placeholder,
input[type=search]::placeholder,
input[type=number]::placeholder,
input[type=url]::placeholder,
input[type=date]::placeholder,
input[type=time]::placeholder {
  color: var(--clr-accent-200);
  opacity: 1;
}

input[type=checkbox] {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  width: 10px;
  height: 10px;
  background-color: var(--clr-ui-100);
  outline: 2px solid var(--clr-ui-200);
  outline-offset: 2px;
  margin-right: 5px;
}
input[type=checkbox]:checked {
  background-color: var(--clr-tertiary);
  outline: 2px solid var(--clr-tertiary);
}

input[type=submit] {
  color: var(--clr-accent-000);
  background-color: var(--clr-green-200);
  border-top: 1px solid var(--clr-green-000);
  border-left: 1px solid var(--clr-green-000);
  border-bottom: 1px solid var(--clr-green-300);
  border-right: 1px solid var(--clr-green-300);
}
input[type=submit]:hover, input[type=submit]:active, input[type=submit]:focus-visible {
  border-top: 1px solid var(--clr-green-000);
  border-left: 1px solid var(--clr-green-000);
  border-bottom: 1px solid var(--clr-green-300);
  border-right: 1px solid var(--clr-green-300);
  background-color: var(--clr-green-100);
  color: var(--clr-accent-000);
  -webkit-transition: all 250ms ease-in;
  transition: all 250ms ease-in;
}

input::-webkit-file-upload-button {
  font-weight: bold;
  color: var(--clr-ui-300);
  padding: 0.5em;
  border: 1px solid var(--clr-ui-300);
  border-radius: var(--border-rad);
}

input::file-selector-button {
  font-weight: bold;
  color: var(--clr-ui-300);
  padding: 0.5em;
  border: 1px solid var(--clr-ui-300);
  border-radius: var(--border-rad);
}

input.input-attention {
  border-color: var(--clr-red-100) !important;
}

.flex-form {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 1rem;
  margin: 1rem 0.5rem;
}
.flex-form label {
  margin: 0;
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}
.flex-form__wrap {
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}

/*------- Input Validation -------*/
textarea:user-valid,
input:user-valid {
  border-color: var(--clr-green-100) !important;
}

textarea:user-invalid,
input:user-invalid {
  border-color: var(--clr-red-100) !important;
}

/* Header / Nav / Footer */
/* Main Logo */
.logo--main {
  position: relative;
  display: block;
}

#logoRPX {
  display: block;
  -webkit-transform: translateX(0px);
          transform: translateX(0px);
  -webkit-transform-origin: top left;
          transform-origin: top left;
  -webkit-transition: opacity 250ms ease-in;
  transition: opacity 250ms ease-in;
}
#logoRPX .logo--main-box {
  fill: var(--clr-green-200);
  -webkit-transition: fill 250ms ease-in;
  transition: fill 250ms ease-in;
}
#logoRPX .logo--main-text {
  fill: var(--clr-base-300);
}

#logoRPX:hover .logo--main-box,
#logoRPX:focus .logo--main-box {
  fill: var(--clr-green-100);
}

.logo--footer {
  font-family: var(--font-disp);
  font-size: var(--fs-800);
  line-height: 100%;
  color: var(--clr-red-100);
  text-decoration: none;
  text-box: trim-both cap alphabetic;
  margin: 0;
}
.logo--footer strong {
  color: var(--clr-accent-000);
  font-variation-settings: "wght" 800;
}

/* Header */
header {
  anchor-name: --header;
  container-name: header;
  position: sticky;
  top: 0;
  color: var(--clr-accent-200);
  z-index: 10;
}
header .breakout {
  position: relative;
}
header .primary-header__layout {
  view-transition-name: --header;
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 1rem;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  padding: 1rem;
  margin-top: 1rem;
  background-color: var(--clr-base-200);
  border: 1px solid var(--clr-base-100);
  -webkit-transition: -webkit-transform 250ms ease-in;
  transition: -webkit-transform 250ms ease-in;
  transition: transform 250ms ease-in;
  transition: transform 250ms ease-in, -webkit-transform 250ms ease-in;
}
header .primary-header__layout[data-hide=true] {
  -webkit-transform: translateY(-100%);
          transform: translateY(-100%);
}
header .primary-header__layout[data-hide=true] .nav-primary {
  background-color: rgba(10, 9, 12, 0);
}

/* Navigation */
.nav-primary {
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  height: 48px;
  gap: 0.5rem;
  font-family: var(--font-disp);
}
.nav-primary .nav-primary--item:has(a) {
  padding-inline: 0.5rem;
}
.nav-primary a.nav-basket--btn {
  display: -ms-grid;
  display: grid;
  place-items: center;
  padding: 0;
  margin: 0;
  border: 0;
  border-radius: 0;
  height: 48px;
  width: 48px;
  text-shadow: none;
  background-color: var(--clr-base-100);
}
.nav-primary a.nav-basket--btn:hover, .nav-primary a.nav-basket--btn:focus {
  background-color: var(--clr-base-000);
}
.nav-primary button.nav-mobile--btn {
  padding: 0;
  margin: 0;
  border: 0;
  border-radius: 0;
  height: 48px;
  width: 48px;
  text-shadow: none;
  background-color: var(--clr-green-200);
}
.nav-primary button.nav-mobile--btn:hover, .nav-primary button.nav-mobile--btn:focus {
  background-color: var(--clr-green-100);
}
.nav-primary button.nav-mobile--btn[aria-expanded=true] {
  color: var(--clr-accent-000);
  background-color: var(--clr-red-100);
}
.nav-primary button.nav-mobile--btn::before {
  content: "\f0c9";
  font-family: "Font Awesome 6 Pro";
  font-weight: 400;
}
.nav-primary button.nav-mobile--btn::after {
  content: unset;
}
.nav-primary button.nav-mobile--btn[aria-expanded=true]::before {
  content: "\f00d";
}

.nav-mobile {
  position-anchor: --header;
  inset: auto;
  top: calc(anchor(top) + 1rem);
  right: calc(anchor(right) + 1rem);
  width: 360px;
  height: calc(100dvh - 2rem);
  opacity: 1;
  padding: 2rem;
  visibility: visible;
  border: 0;
  border-radius: 2px;
  background-color: var(--clr-accent-000);
  -webkit-box-shadow: 0px 0px 10px var(--clr-base-400);
          box-shadow: 0px 0px 10px var(--clr-base-400);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  gap: 2rem;
  color: var(--clr-base-300);
  -webkit-transition: all 250ms var(--trans-lazy);
  transition: all 250ms var(--trans-lazy);
  transition-behavior: allow-discrete;
  -webkit-transform-origin: right;
          transform-origin: right;
  view-transition-name: --mainnav;
}
.nav-mobile .nav-mobile--close {
  margin-top: auto;
  margin-bottom: 0;
}
.nav-mobile .nav-mobile--links {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -ms-flex-wrap: nowrap;
      flex-wrap: nowrap;
  gap: 0.25rem;
  height: 90%;
  opacity: 1;
  list-style: none;
  margin: 0;
  padding: 0;
  -webkit-transition: opacity 250ms ease-in 250ms;
  transition: opacity 250ms ease-in 250ms;
}
.nav-mobile .nav-mobile--links > li {
  background-color: rgb(235, 245, 253);
  color: var(--clr-base-200);
}
.nav-mobile .nav-mobile--links > li a {
  display: block;
  color: var(--clr-base-200);
  font-size: var(--fs-300);
  font-variation-settings: "ital" 0, "wght" 500, "wdth" 90;
  text-transform: uppercase;
  text-decoration: none;
  text-align: center;
  text-box: trim-both cap alphabetic;
  padding-block: 1rem;
  padding-inline: 2rem;
  -webkit-transition: background-color 250ms ease-in, color 250ms ease-in;
  transition: background-color 250ms ease-in, color 250ms ease-in;
}
.nav-mobile .nav-mobile--links > li a:hover {
  background-color: var(--clr-green-100);
  color: var(--clr-base-200);
}
.nav-mobile .nav-mobile--tools {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 1rem;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.nav-mobile .nav-mobile--tools a {
  display: block;
  margin: 0;
}

#mobileMenu[data-visible=false] {
  visibility: hidden;
  opacity: 0;
  width: 0;
}
#mobileMenu[data-visible=false] ul {
  opacity: 0;
}

.nav-side {
  border: 1px dashed var(--clr-base-100);
  background-color: color-mix(in srgb, var(--clr-base-200) 40%, var(--clr-base-300));
}
.nav-side .nav-side--btn {
  display: none;
  background-color: var(--clr-red-100);
  border: 0;
  border-radius: 0;
  font-size: var(--fs-400);
  margin: 0;
  padding: 1rem 1.5rem;
}
.nav-side a:hover {
  color: var(--clr-accent-200);
}
.nav-side .nav-side--panel {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 0;
}
.nav-side .nav-side--panel .nav-side--item {
  border-bottom: 1px dashed var(--clr-base-100);
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.nav-side .nav-side--panel .nav-side--item:has(a.active)::before {
  view-transition-name: --secnav;
  content: url(/assets/img/rpx_marker.webp);
  position: absolute;
  font-size: var(--fs-300);
  left: -0.5rem;
  top: 14px;
}
.nav-side .nav-side--panel .nav-side--item:last-child {
  border-bottom: 0;
}
.nav-side .nav-side--panel .nav-side--item > a {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  display: block;
  padding: 1rem;
  font-variation-settings: "ital" 0, "wght" 300, "wdth" 40;
  text-transform: uppercase;
  text-box: trim-both cap alphabetic;
}
.nav-side .nav-side--panel .nav-side--item > a.active {
  color: var(--clr-green-100);
  font-variation-settings: "ital" 0, "wght" 500, "wdth" 40;
}
.nav-side .nav-side--panel .nav-side--item > span {
  display: none;
  padding-inline: 1rem;
  cursor: pointer;
  rotate: 180deg;
}
.nav-side .nav-side--panel .nav-side--item > span.reveal {
  rotate: 0deg;
}
.nav-side .nav-side--panel .nav-side--item > span:hover {
  color: var(--clr-red-100);
}
.nav-side .nav-side--panel .nav-side--item:has(ul) span {
  display: block;
}
.nav-side .nav-side--panel .nav-side--item > ul {
  display: none;
  -ms-flex-preferred-size: 100%;
      flex-basis: 100%;
  background-color: var(--clr-base-300);
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 0;
  margin-left: 0;
  height: 0;
  transition-behavior: allow-discrete;
  -webkit-transform-origin: top;
          transform-origin: top;
  -webkit-transition: height 500ms var(--trans-lazy), display 250ms;
  transition: height 500ms var(--trans-lazy), display 250ms;
}
.nav-side .nav-side--panel .nav-side--item > ul li > a {
  display: block;
  padding: 1rem 1.6rem 0;
  font-size: var(--fs-300);
  font-variation-settings: "ital" 0, "wght" 300, "wdth" 40;
  text-transform: uppercase;
  text-box: trim-both cap alphabetic;
}
.nav-side .nav-side--panel .nav-side--item > ul li:last-child > a {
  padding: 1rem 1.6rem;
}
.nav-side .nav-side--panel .nav-side--item:has(.reveal) > ul {
  height: auto;
  display: block;
}
@starting-style {
  .nav-side .nav-side--panel .nav-side--item:has(.reveal) > ul {
    height: 0;
  }
}

/* Footer */
footer {
  anchor-name: --footer;
  container-name: footer;
  color: var(--clr-accent-200);
  border-bottom: 10px solid;
  border-image-source: var(--clr-gradient-full);
  border-image-slice: 1;
  background-color: var(--clr-base-300);
}
footer .primary-footer__layout {
  min-height: 200px;
  margin-block: 4rem 2rem;
}
footer .footer-flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 1rem;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
footer .list__social {
  margin-inline: 0.5rem;
}
footer .footer-tag {
  color: var(--clr-accent-100);
  margin-top: 0;
  margin-inline: 0.5rem;
  font-variation-settings: "ital" 0, "wght" 100, "wdth" 100;
}
footer .footer-tag i {
  scale: 0.5;
}
footer .footer-legal {
  font-size: 80%;
  color: var(--clr-base-000);
  text-align: right;
  margin-inline: 0.5rem;
}
footer .footer-legal a {
  text-decoration: none;
}

nav .nav-footer {
  margin-top: 2rem;
  margin-inline: auto;
  border: 1px dashed var(--clr-base-100);
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
nav .nav-footer li {
  border-right: 1px dashed var(--clr-base-100);
  text-align: center;
}
nav .nav-footer li:last-child {
  border-right: 0;
}
nav .nav-footer a {
  position: relative;
  color: var(--clr-accent-000);
  font-size: 90%;
  text-transform: uppercase;
  display: inline-block;
  padding-block: 0.5rem;
  text-box: trim-both cap alphabetic;
}
nav .nav-footer a:after {
  content: "";
  position: absolute;
  width: 100%;
  -webkit-transform: scaleX(0);
          transform: scaleX(0);
  height: 1px;
  bottom: 0;
  left: 0;
  background-color: var(--clr-red-100);
  -webkit-transform-origin: bottom right;
          transform-origin: bottom right;
  -webkit-transition: -webkit-transform 0.25s ease-out;
  transition: -webkit-transform 0.25s ease-out;
  transition: transform 0.25s ease-out;
  transition: transform 0.25s ease-out, -webkit-transform 0.25s ease-out;
}
nav .nav-footer a:hover:after {
  -webkit-transform: scaleX(1);
          transform: scaleX(1);
  -webkit-transform-origin: bottom left;
          transform-origin: bottom left;
}

.list-flex.list__social {
  margin-left: auto;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.list-flex.list__social i {
  font-size: 200%;
}

/* Container Queries */
@container header (max-width: 1440px) {}
@container header (max-width: 1024px) {}
@container header (max-width: 820px) {}
@container header (max-width: 480px) {
  header .primary-header__layout {
    margin: 0.5rem;
    margin-top: 0.5rem;
  }
}
@container footer (max-width: 820px) {
  .primary-footer__layout .list__social {
    margin-top: 2rem;
  }
}
@container footer (max-width: 480px) {
  .logo--footer {
    display: block;
    font-size: 2.6rem;
    text-align: center;
    margin-bottom: 1rem;
  }
  .footer-tag {
    text-align: center;
    margin-inline: auto;
  }
}
@media only screen and (max-width: 480px) {
  /*------- 480 & Under ------- */
  header {
    position: relative;
    background-image: url(/assets/img/back_header-mobile.webp);
    background-size: contain;
  }
  header.content-grid {
    display: block;
  }
}
/* Sections & Content */
section {
  padding-block: 2.5rem;
}

.section__hero {
  min-height: 75dvh;
  -ms-flex-line-pack: end;
      align-content: end;
}

.section__header {
  position: relative;
  min-height: 35dvh;
  -ms-flex-line-pack: end;
      align-content: end;
}
.section__header-slim {
  min-height: 15dvh;
}
.section__header .icon__header {
  width: 240px;
  position: absolute;
  bottom: 1rem;
  right: 1rem;
}

.section__splash {
  min-height: 100dvh;
  -ms-flex-line-pack: center;
      align-content: center;
}

.content__white {
  text-shadow: unset;
  color: var(--clr-base-300);
  background-color: var(--clr-accent-400);
  padding-block: 2rem;
  margin-inline: 1rem;
}

.site-title {
  position: relative;
  color: var(--clr-accent-000);
  margin: 2rem;
  font-family: var(--font-cond);
  font-size: var(--fs-1000);
  font-variation-settings: "ital" 0, "wght" 800, "wdth" 30;
  line-height: 0.9;
  letter-spacing: 0.2rem;
  text-transform: uppercase;
  paint-order: stroke fill;
  -webkit-text-stroke: 10px rgba(10, 9, 12, 0.25);
}

.page-title {
  color: var(--clr-accent-000);
  font-family: var(--font-cond);
  font-size: var(--fs-900);
  font-variation-settings: "ital" 0, "wght" 800, "wdth" 30;
  line-height: 0.8;
  letter-spacing: 0.2rem;
  text-transform: uppercase;
  paint-order: stroke fill;
  -webkit-text-stroke: 6px rgba(22, 20, 28, 0.5);
}

.section-title {
  font-size: var(--fs-800);
  line-height: 1.1;
}

/* Grid & Flex List Transforms */
.list-grid {
  margin-block: 1rem;
  margin-inline: 0;
  padding: 0;
  list-style: none;
  margin: 0;
  max-width: unset;
  display: -ms-grid;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: 1rem;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.list-grid li {
  margin: 0;
  padding: 0;
}
.list-grid.list-grid__3-col {
  grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
}
.list-grid .list-grid--item {
  overflow: clip;
}
.list-grid .list-grid--item__alt {
  padding-top: 1rem;
  background-color: var(--clr-ui-100);
  border: 1px solid var(--clr-ui-100);
  border-radius: var(--border-radius);
  font-size: var(--fs-300);
}

.list-grid__sub {
  --grid-row-span: 4;
  -ms-grid-rows: (auto)[var(--grid-row-span)];
  grid-template-rows: repeat(var(--grid-row-span), auto);
}
.list-grid__sub .list-grid--item {
  display: -ms-grid;
  display: grid;
  gap: 0;
  -ms-grid-columns: 1fr;
  grid-template-columns: 1fr;
  -ms-grid-rows: subgrid;
  grid-template-rows: subgrid;
  grid-row: span var(--grid-row-span);
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: end;
}
.list-grid__sub .list-grid--item > *:nth-child(1) {
  -ms-grid-row: 1;
  -ms-grid-column: 1;
}

.list-flex {
  margin-block: 1rem;
  margin-inline: 0;
  padding: 0;
  list-style: none;
  max-width: unset;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 1rem;
}
.list-flex li {
  margin: 0;
  padding: 0;
}
.list-flex__wrap {
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
.list-flex__stack {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 0.25rem;
}
.list-flex .list-flex--item {
  position: relative;
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}
.list-flex .list-flex--item > * {
  margin-inline: 1rem;
  margin-block: 1rem;
}
.list-flex__primary {
  margin-inline: 0.5rem;
}
.list-flex__primary .list-flex--item {
  padding: 1rem;
  border: 1px dashed var(--clr-green-400);
  background: var(--clr-green-200);
}

/* Media Queries */
#basketButton {
  position: relative;
}

#basketButton::before {
  content: attr(data-qty);
  position: absolute;
  z-index: 1;
  top: -12px;
  right: -12px;
  display: -ms-grid;
  display: grid;
  place-items: center;
  width: 24px;
  height: 24px;
  color: var(--clr-accent-000);
  background-color: var(--clr-red-100);
  font-size: 75%;
  text-box: trim-both cap alphabetic;
  border-radius: 50%;
}

/* Products */
.product-grid {
  margin: 2rem;
}

.product-card {
  position: relative;
  container: product-item/inline-size;
  text-align: center;
  color: var(--clr-base-200);
  background-color: var(--clr-accent-000);
  border-radius: var(--border-radius);
  -webkit-box-shadow: 0px 0px 10px color-mix(in srgb, var(--clr-base--100) 10%, transparent);
          box-shadow: 0px 0px 10px color-mix(in srgb, var(--clr-base--100) 10%, transparent);
}
.product-card .tag-list {
  opacity: 0.25;
  -webkit-transition: opacity 250ms ease-in;
  transition: opacity 250ms ease-in;
}
.product-card:hover .tag-list, .product-card:focus-within .tag-list {
  opacity: 1;
}
.product-card a {
  display: block;
  color: var(--clr-base-100);
  text-decoration: none;
  border: 1px solid var(--clr-accent-100);
  margin: 0.5rem;
  -webkit-transition: all 250ms ease-in;
  transition: all 250ms ease-in;
}
.product-card a:hover, .product-card a:focus {
  border: 1px solid var(--clr-accent-300);
  color: var(--clr-base-200);
}
.product-card h4 {
  font-family: var(--font-body);
  font-size: var(--fs-400);
  font-variation-settings: "ital" 0, "wght" 800, "wdth" 60;
  line-height: 110%;
}
.product-card img {
  -webkit-margin-before: 0;
          margin-block-start: 0;
  margin-inline: auto;
}

/* Featured Products */
.product-grid__featured .product-card a {
  aspect-ratio: 1;
  display: -ms-grid;
  display: grid;
  -ms-grid-rows: 2fr 1fr;
  grid-template-rows: 2fr 1fr;
}
.product-grid__featured .product-card a .product-card--img {
  background-image: linear-gradient(45deg, var(--clr-accent-200), var(--clr-accent-100));
  display: -ms-grid;
  display: grid;
  place-items: center;
}
.product-grid__featured .product-card a .product-card--info {
  display: -ms-grid;
  display: grid;
  place-items: center;
}
.product-grid__featured .product-card a h4 {
  font-size: var(--fs-500);
}
.product-grid__featured .product-card a .tag-list li {
  background-color: var(--clr-accent-000);
}

.item-title {
  font-family: var(--font-cond);
  font-size: var(--fs-800);
  font-variation-settings: "ital" 0, "wght" 800, "wdth" 30;
  line-height: 0.8;
  letter-spacing: 0.2rem;
  text-transform: uppercase;
}

.product-detail {
  container: product-detail/inline-size;
  position: relative;
}
.product-detail .tag-list {
  position: relative;
  margin-inline: 2rem;
}

aside.basket-add {
  background-color: var(--clr-base-300);
  padding-block: 1rem;
  border: 12px solid;
  border-image-source: var(--clr-gradient-bracket-vert);
  border-image-slice: 1;
  color: var(--clr-accent-000);
}
aside.basket-add .flex-form {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
aside.basket-add .basket-form--attr select, aside.basket-add .basket-form--attr select::picker(select) {
  -webkit-appearance: base-select;
     -moz-appearance: base-select;
          appearance: base-select;
}
aside.basket-add .basket-form--attr select::picker-icon, aside.basket-add .basket-form--attr select::picker(select)::picker-icon {
  content: "\f13a";
  font-family: "Font Awesome 6 Pro";
  font-weight: 400;
}
aside.basket-add .basket-form--attr select option {
  padding: 0.5rem;
}
aside.basket-add .basket-form--attr select option:hover {
  background-color: var(--clr-accent-100);
}
aside.basket-add .basket-form--attr select option:checked {
  background-color: var(--clr-green-100);
  color: var(--clr-accent-000);
}
aside.basket-add .basket-form--attr select option:checked::checkmark {
  content: "\f058";
  font-family: "Font Awesome 6 Pro";
  font-weight: 400;
}

/* Basket/Cart */
.basket-table {
  border-top: 1px solid var(--clr-base-000);
  border-left: 1px solid var(--clr-base-000);
}
.basket-table th,
.basket-table td {
  border-bottom: 1px solid var(--clr-base-000);
  border-right: 1px solid var(--clr-base-000);
  padding: 0.5rem;
  text-align: left;
}

.basket-details[data-visible=false] {
  display: none;
}

/* Checkout */
.promo-box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 0.5rem;
  background-color: var(--clr-base-300);
  padding-block: 1rem;
  border: 12px solid;
  border-image-source: var(--clr-gradient-bracket-horz);
  border-image-slice: 1;
  padding: 1rem;
  margin-inline: 2rem;
  margin-block: 1rem;
}
.promo-box .action--clearPromo {
  margin-left: auto;
}

input[type=text].card-number {
  font-size: var(--fs-400);
}

/* Tags */
.tag-list {
  margin-block: 1rem;
  margin-inline: 0;
  padding: 0;
  list-style: none;
  margin-inline: 1rem;
  margin-block: 1rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 0.25rem;
  font-variation-settings: "ital" 0, "wght" 300, "wdth" 30;
  position: absolute;
  top: 0;
  left: 0;
}
.tag-list li {
  margin: 0;
  padding: 0;
}
.tag-list > li {
  padding: 0.5rem;
  color: var(--clr-base-100);
  background-color: var(--clr-accent-100);
  border-radius: 3px;
  font-family: var(--font-cond);
  font-size: 70%;
  text-transform: uppercase;
  text-box: trim-both cap alphabetic;
  pointer-events: none;
}
.tag-list > li::before {
  content: "\f02b";
  font-family: "Font Awesome 6 Pro";
  font-weight: 100;
  margin-right: 0.25rem;
}
.tag-list > li[data-tag=sale] {
  background-color: var(--clr-red-100);
  color: #ffffff;
}
.tag-list > li[data-tag=sale]::before {
  content: "\f645";
}
.tag-list > li[data-tag=hot]::before {
  content: "\f06d";
}
.tag-list > li[data-tag=top-seller]::before {
  content: "\f762";
}
.tag-list > li[data-tag=new]::before {
  content: "\e5d6";
}
.tag-list > li[data-tag=limited-time]::before {
  content: "\e41b";
}

/* Product Quick-View */
.product--quick-view {
  visibility: visible;
  border: 0;
  border-radius: 2px;
  background-color: var(--clr-accent-000);
  -webkit-box-shadow: 0px 0px 10px var(--clr-base-400);
          box-shadow: 0px 0px 10px var(--clr-base-400);
  inset: auto;
  left: 50%;
  bottom: 1rem;
  width: calc(100dvw - 2rem);
  max-width: 1440px;
  opacity: 0;
  padding: 2rem;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  -webkit-transition: all 250ms var(--trans-lazy);
  transition: all 250ms var(--trans-lazy);
  transition-behavior: allow-discrete;
  -webkit-transform-origin: bottom;
          transform-origin: bottom;
}
.product--quick-view[data-visible=true] {
  position: fixed;
  display: -ms-grid;
  display: grid;
  place-items: center;
  height: 50dvh;
  opacity: 1;
}
.product--quick-view[data-visible=true] .product--quick-view-content {
  opacity: 1;
}
.product--quick-view[data-visible=true]::-ms-backdrop {
  opacity: 0.9;
}
.product--quick-view[data-visible=true]::backdrop {
  opacity: 0.9;
}
.product--quick-view::-ms-backdrop {
  background-color: var(--clr-base-200);
  -ms-transition: opacity 250ms ease-in;
  transition: opacity 250ms ease-in;
  opacity: 0;
}
.product--quick-view::backdrop {
  background-color: var(--clr-base-200);
  -webkit-transition: opacity 250ms ease-in;
  transition: opacity 250ms ease-in;
  opacity: 0;
}

.product--quick-view-content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: nowrap;
      flex-wrap: nowrap;
  gap: 1rem;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 100%;
  opacity: 0;
  -webkit-transition: opacity 250ms 250ms ease-in;
  transition: opacity 250ms 250ms ease-in;
}
.product--quick-view-content > div {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}

.product--quick-view-close {
  position: absolute;
  padding: 0.75rem;
  top: 0.25rem;
  right: 0.25rem;
  font-size: var(--fs-300);
  background-color: var(--clr-red-200);
  border-top: 1px solid var(--clr-red-000);
  border-left: 1px solid var(--clr-red-000);
  border-bottom: 1px solid var(--clr-red-300);
  border-right: 1px solid var(--clr-red-300);
}
.product--quick-view-close:hover {
  background-color: var(--clr-red-100);
}

/* Live Search */
.widget--live-search {
  container-name: live-search;
  container-type: inline-size;
  position: relative;
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}
.widget--live-search form {
  margin: 0;
}
.widget--live-search label {
  margin: 0;
}
.widget--live-search .live-search--input {
  position: relative;
  anchor-name: --ls-input;
  border-bottom: 0;
  color: var(--clr-accent-300);
  font-size: var(--fs-400);
}
.widget--live-search .live-search--input:focus {
  color: var(--clr-base-200);
  background-color: var(--clr-accent-000);
}
.widget--live-search .live-search--results {
  position-anchor: --ls-input;
  inset: auto;
  top: anchor(bottom);
  left: anchor(left);
  width: 100cqw;
  max-width: anchor-size(width);
  height: auto;
  background-color: var(--clr-base-100);
  outline: 0;
  border: 0;
  color: var(--clr-accent-300);
  text-align: center;
  font-size: var(--fs-300);
}
.widget--live-search .live-search--results .result-output {
  margin: 1rem;
  display: -ms-grid;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 0.5rem;
  -webkit-animation: fadeIn 250ms 1 ease-in;
          animation: fadeIn 250ms 1 ease-in;
}
.widget--live-search .live-search--results .result-output a {
  display: block;
  background-color: var(--clr-accent-000);
  border-left: 5px solid var(--clr-accent-300);
  padding: 1rem;
  text-decoration: none;
  -webkit-transition: border 250ms ease-in;
  transition: border 250ms ease-in;
}
.widget--live-search .live-search--results .result-output a:hover {
  border-left: 5px solid var(--clr-green-100);
}
.widget--live-search .live-search--results .result-output img {
  display: block;
  margin-inline: auto;
  margin-bottom: 0.5rem;
}
.widget--live-search .live-search--results .result-output h5 {
  font-family: var(--font-body);
  font-size: var(--fs-400);
  font-variation-settings: "ital" 0, "wght" 600, "wdth" 30;
  margin: 0 auto 1rem;
  text-wrap: balance;
}

@-webkit-keyframes fadeIn {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}

@keyframes fadeIn {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@container live-search (max-width: 480px) {
  .widget--live-search form {
    display: none;
  }
  #liveSearchForm {
    margin-inline: 0.5rem;
  }
  .widget--live-search .live-search--results .result-output {
    margin: 0.5rem;
    -ms-grid-columns: (1fr)[2];
    grid-template-columns: repeat(2, 1fr);
  }
  .widget--live-search .live-search--results .result-output a {
    padding: 0.5rem;
  }
}
/* Custom Sections */
.bg-base {
  position: relative;
}
.bg-base::before {
  content: "";
  position: absolute;
  inset: 0;
  grid-column: content;
  border-left: 1px dashed var(--clr-base-100);
  border-right: 1px dashed var(--clr-base-100);
  z-index: 1;
  pointer-events: none;
}
.bg-base > * {
  z-index: 2;
}
.bg-base aside {
  background-color: var(--clr-base-300);
  padding-block: 1rem;
  font-size: var(--fs-300);
  border: 12px solid;
  border-image-source: var(--clr-gradient-bracket-vert);
  border-image-slice: 1;
}

.bg-accent {
  position: relative;
  color: var(--clr-base-200);
  background: var(--clr-accent-400);
}
.bg-accent::before {
  content: "";
  position: absolute;
  inset: 0;
  grid-column: content;
  border-left: 1px dashed var(--clr-accent-100);
  border-right: 1px dashed var(--clr-accent-100);
  z-index: 1;
  pointer-events: none;
}
.bg-accent hr {
  border: 1px dashed var(--clr-accent-100);
  border-image-source: unset;
  border-image-slice: unset;
}
@supports ((-webkit-background-clip: text) or (background-clip: text)) {
  .bg-accent blockquote {
    background: linear-gradient(45deg, var(--clr-base-100), var(--clr-base-300));
    -webkit-background-clip: text;
            background-clip: text;
    color: transparent;
  }
}
.bg-accent .call-out {
  color: var(--clr-base-400);
  background-color: var(--clr-accent-400);
}
.bg-accent .btn__fancy {
  color: var(--clr-base-200);
  background-color: rgba(186, 215, 238, 0.25);
}
.bg-accent .btn__fancy:hover {
  background-color: rgba(186, 215, 238, 0);
}
.bg-accent .list-grid .list-grid--item__alt {
  border: 1px dashed var(--clr-accent-100);
  border-radius: var(--border-radius);
}
.bg-accent .call-to-action {
  outline: 1px dashed var(--clr-accent-100);
}
.bg-accent > * {
  z-index: 2;
}
.bg-accent aside {
  background-color: var(--clr-accent-300);
  padding-block: 1rem;
  font-size: var(--fs-300);
  border: 1px dashed var(--clr-accent-100);
  border-radius: var(--border-radius);
}

.bg-primary {
  position: relative;
  background: var(--clr-green-200);
  border-top: 1px solid #9fd649;
}
.bg-primary::before {
  content: "";
  position: absolute;
  inset: 0;
  grid-column: content;
  border-left: 1px dashed var(--clr-green-400);
  border-right: 1px dashed var(--clr-green-400);
  pointer-events: none;
}

.breakout {
  z-index: 1;
}

.call-to-action {
  padding: 2rem;
  margin-block: 2rem;
  margin-inline: 2rem;
  color: var(--clr-green-100);
  background: var(--clr-base-300);
  outline-color: var(--clr-base-100);
  outline-style: dashed;
  outline-width: 1px;
  outline-offset: 0.5rem;
}
.call-to-action__light {
  background: var(--clr-accent-400);
  color: var(--clr-base-300);
  font-variation-settings: "ital" 0, "wght" 400, "wdth" 70;
}

.call-out {
  margin: 2rem;
  padding: 1rem;
  border-left: 5px solid var(--clr-accent-200);
}
.call-out:has(*) {
  padding: 1rem 0;
}
.call-out > * {
  margin: 1rem 2rem;
}
.call-out__neg {
  border-left: 5px solid var(--clr-red-200);
}
.call-out__pos {
  border-left: 5px solid var(--clr-green-200);
}

.box__fancy {
  background-color: var(--clr-base-200);
  border: 6px solid;
  border-image-source: var(--clr-gradient-full);
  border-image-slice: 1;
  padding: 2rem;
  margin-block: 2rem;
}

/* Navigation Elements */
.nav__icon-menu {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 0;
  margin: 1rem 2rem;
  border-top: 1px dotted var(--clr-accent-100);
}
.nav__icon-menu li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 1rem;
  padding-block: 0.5rem;
  font-size: var(--fs-400);
  border-bottom: 1px dotted var(--clr-accent-100);
}

.post-menu {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 0.5rem;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  margin-inline: 2rem;
}
.post-menu a {
  text-transform: uppercase;
}

/* User Generated CMS Content */
.content__user h1:first-of-type {
  border-left: 5px solid var(--clr-green-100);
  padding-left: 1rem;
}
.content__user > img {
  margin: 2rem;
  width: calc(100% - 4rem);
}
.content__user p > iframe {
  margin-left: 0;
}
.content__user .img__border {
  border: 5px solid var(--clr-base-100);
}

#backdropRPX {
  position: fixed;
  overflow: clip;
  top: 0;
  left: 0;
  min-width: 100dvw;
  min-height: 100svh;
  background-color: var(--clr-base-200);
  background-image: url(/assets/img/back-pixels-header.jpg);
  background-attachment: fixed;
  background-position: center;
  background-repeat: no-repeat;
  z-index: -2;
}

.backdrop__half {
  grid-column: full-width;
  position: absolute;
  z-index: -1;
  overflow: clip;
  top: 0;
  left: 0;
  width: 100%;
  height: 400px;
  background-color: var(--clr-base-300);
  background-image: url(/assets/img/back-pixels-header.jpg);
  background-attachment: fixed;
  background-position: top;
  background-repeat: no-repeat;
}
.backdrop__overlay::after {
  content: "";
  position: absolute;
  inset: 0;
  background-color: color-mix(in srgb, var(--clr-base-200) 60%, transparent);
}

body:has(.backdrop__half) main section:first-child {
  margin-top: 120px;
}
body:has(.backdrop__half) main section:first-child h1 {
  margin-bottom: 4rem;
}

/* Media Queries */
@media only screen and (min-width: 1024px) {
  /*------- 1024 & Over ------- */
  .make-sticky {
    position: sticky;
    top: 2rem;
  }
}
@media only screen and (max-width: 1024px) {
  .footer-cta {
    bottom: 1rem;
    right: 1rem;
  }
  .notification-shell--button {
    bottom: 1rem;
    left: 1rem;
  }
}
@media only screen and (max-width: 820px) {
  /*------- 820 & Under ------- */
  .list-flex {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .btn-group {
    gap: 0.5rem;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .btn-group .btn {
    margin-block: 0;
  }
  footer .primary-footer__layout {
    padding-bottom: 4rem;
  }
  footer .footer-flex {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  footer .footer-tag {
    text-align: center;
  }
  footer .list__social {
    margin: auto;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
  }
  footer .footer-legal {
    text-align: center;
  }
  footer .nav-footer {
    gap: 0;
    -webkit-box-align: normal;
        -ms-flex-align: normal;
            align-items: normal;
  }
  footer .nav-footer li {
    border-bottom: 1px dashed var(--clr-base-100);
    border-right: 0;
  }
  footer .nav-footer li:last-child {
    border: 0;
  }
  .content-grid__right,
  .content-grid__left {
    -ms-grid-columns: 1fr;
    grid-template-columns: 1fr;
  }
  .text__col-2,
  .text__col-3 {
    -webkit-columns: 1;
       -moz-columns: 1;
            columns: 1;
  }
  form {
    margin: 2rem 1rem;
  }
  body:has(.backdrop__half) .nav-side {
    margin-top: 276px;
  }
  body:has(.backdrop__half) article {
    margin-top: 1rem;
  }
  body:has(.backdrop__half) article h1 {
    margin-bottom: 2rem;
  }
}
@media only screen and (max-width: 480px) {
  /*------- 480 & Under ------- */
  .mobile-hide {
    display: none;
  }
  .mobile-show {
    display: unset;
  }
  .nav-side .nav-side--panel {
    min-width: 75%;
  }
  .site-title {
    font-variation-settings: "ital" 0, "wght" 800, "wdth" 25;
  }
  .section__header {
    min-height: 20dvh;
    -ms-flex-line-pack: end;
        align-content: end;
  }
  footer .footer-tag {
    font-size: var(--fs-300);
  }
  form {
    margin: 2rem 0rem;
  }
  .content__user > img {
    margin: 2rem 0;
    width: 100%;
  }
  body:has(.backdrop__half) .nav-side {
    margin-top: 290px;
  }
}