@keyframes shake {
  10%,
  90% {
    transform: translate3d(-1px, 0, 0);
  }
  20%,
  80% {
    transform: translate3d(2px, 0, 0);
  }
  30%,
  50%,
  70% {
    transform: translate3d(-4px, 0, 0);
  }
  40%,
  60% {
    transform: translate3d(4px, 0, 0);
  }
}

/* CORP STYLE OVERRIDES */
:root {
  --max-container-width: 80rem;
  --container-padding: clamp(3rem, 4vw, 4rem);
  --text-weight-bold: 700;
  --text-weight-regular: 500;
}

.new-footer__copywrite {
  margin: unset;
  padding: unset;
  border: unset;
}

.flexible-row-container:has(#mktoForm) {
  padding-block-start: 2rem;
}

.mainContainer {
  container-type: inline-size;
  container-name: mkto-form;
}
.download-resource {
  text-decoration: none;
}
/* MARKETO OVERRIDES */

:is(.mktoOffset, .mktoClear, .mktoGutter, .mktoAsterix, .mktoRangeValueArrowWrap) {
  display: none;
}

/* MARKETO GENERAL LAYOUT */

.mktoHtmlText.mktoHasWidth {
  width: unset !important;
  inline-size: min(100%, 37rem);
}
:is(#mktoForm, form.mktoForm) {
  --accent: #25517b;
  --accent-check: #0888cd;
  --error-red: hsl(6deg 75% 54%);
  /* #00a8d5; */
  font-family: unset !important;
  font-size: unset !important;
  color: unset !important;

  :where(select, textarea, input:not([type="checkbox"], [type="radio"], [type="search"])) {
    margin-block-start: 0.125rem;
  }
}
form.mktoForm {
  width: unset !important;
}
:where(body:not(.full-page-form)) form.mktoForm {
  max-inline-size: 47ch;
}
#mktoForm {
  padding-block: var(--gap);
}
body {
  &[data-form-width="wide"] {
    :is(#mktoForm) {
      max-inline-size: 100% !important;
    }
  }
}
:is(#formAreaText-top, #formAreaText-bottom, .mktoHtmlText, .mktoText) {
  &:empty {
    display: none;
  }
  & > * + * {
    margin-block-start: 0.35lh;
  }
  :where(ul, ol) {
    padding-inline-start: 2ch;
    li {
      padding-inline-start: 0.5ch;
      padding-block-end: 0.5ch;
    }
  }
}
:is(#formAreaText-top) {
  margin-block-end: 2rem;
  transition:
    block-size var(--speed-snail) var(--transition-in-out-quadratic),
    content-visibility var(--speed-snail) step-end,
    margin var(--speed-snail) ease-in;
  transition-behavior: allow-discrete;
  block-size: calc-size(auto, size);
  h1 {
    font-size: var(--text-size-h2);
  }
  h2 {
    font-size: calc(0.85 * var(--text-size-h2));
  }
}
:is(#formAreaText-bottom) {
  margin-block-start: 3rem;
}

/* overrides the hiding of the lightswitch */
body:not(.menu-open) :is(.header-lower-navigation, .header-upper-navigation) {
  display: block;
}

.mktoForm .mktoFormRow {
  break-inside: avoid;
  margin-block-end: 1.75rem;
  &:not(:has(.group-switch, .cx-tile)) label {
    width: unset;
  }
  &:has(.mktoFormCol:nth-of-type(2)) {
    display: grid;
    /* grid-template-columns: 1fr; */
    gap: 2rem;
  }
  &:has(.mktoPlaceholder:empty) {
    display: none;
  }
}
@container mkto-form (min-width: 65ch) {
  .mktoFormRow:has(.mktoFormCol:nth-of-type(2)) {
    grid-template-columns: 1fr 1fr;
  }
}

.mktoFormCol,
.mktoFieldWrap {
  width: 100% !important;
  float: unset !important;
}

.mktoFieldWrap {
  position: relative;
  display: grid;
  max-inline-size: 100%;
  :where(input, select, textarea, .mktoLogicalField, .mktoLabel, .mktoHasWidth) {
    width: unset !important;
  }
}

/* INPUTS */

.mktoFormRow:has(> input[type="hidden"]) {
  display: none;
}

.mktoForm
  :is(
    input[type="text"],
    input[type="url"],
    input[type="email"],
    input[type="tel"],
    input[type="number"],
    input[type="date"],
    textarea.mktoField,
    select.mktoField
  ) {
  inline-size: min(100%, 37rem);
  border: var(--border-soft) !important;
  color: #202020 !important;
  font-size: 1rem !important;
  font-weight: 500 !important;
  line-height: calc(0.5rem + 1em) !important;
  padding: 0.65rem 0.5rem !important;
  margin: 0 !important;
  border-radius: 0.1875rem !important;
  background-color: white !important;
  height: auto !important;
  &:focus {
    border-color: var(--accent) !important;
  }
  &:hover {
    border-color: #919fa9 !important;
  }
  &:is(:focus-visible) {
    outline-style: dotted;
    outline-width: 0.1875rem;
    outline-color: var(--text-white);
  }
  &:is(:disabled, [disabled], [readonly]) {
    filter: contrast(0.7);
    cursor: not-allowed !important;
  }
  /* SELECT */
}
.mktoForm select.mktoField {
  &:has(button) {
    input[type="search"] {
      inline-size: calc(100% - 2ch) !important;
      margin: 1ch;
    }
    &::picker(select) {
      box-shadow: 0rem 0.25rem 1rem rgb(0 0 0 / 25%);
    }
    svg {
      padding: 0 !important;
    }
    selectedcontent {
      padding: 0 !important;
    }
  }

  &.mktoHasWidth {
    width: 100% !important;
  }
  & .scrollable .disabled {
    display: none;
  }
}

/* LABELS */

.mktoForm {
  .mktoLabel {
    display: block !important;
    color: var(--text-white) !important;
    font-size: 1rem !important;
    padding-bottom: 0.1rem !important;
    padding-top: 0px !important;
    width: 100% !important;
    & a {
      color: var(--text-white);
    }
  }
  .mktoInstruction {
    &:empty {
      display: none;
    }
  }
  label > :is(a, strong) {
    padding: 0 !important;
  }
}

.mktoForm .mktoRequiredField {
  label[for].mktoLabel {
    font-weight: var(--text-weight-regular);
  }
  .mktoAsterix {
    display: none !important;
    color: var(--accent); /* optional: to visually stand out */
  }
}
.mktoFieldDescriptor {
  margin-bottom: unset !important;
}
.mktoRequiredField::before {
  content: "✱";
  position: absolute;
  inset-block-start: 0;
  inset-inline-start: -1.7ch;
  font-size: 86%;
  color: var(--error-red);
}
/* CHECKBOXES AND RADIOLISTS */

:where(.mktoCheckboxList, .mktoRadioList) {
  margin-block-start: var(--gap-tiny);
  display: grid;
  grid-template-columns: 1.75rem 1fr;
  gap: var(--gap-tiny);
  align-items: center;
  justify-items: start;
}

.mktoForm .mktoCheckboxList > input {
  border-radius: 4px !important;
}

.mktoForm :is(.mktoCheckboxList, .mktoRadioList) {
  border: var(--border-soft) !important;
  border-radius: 5px !important;
  background-color: white !important;
  padding: 1rem 0.5rem 1rem 0.75rem !important;
  margin-top: 5px !important;
  margin-bottom: 5px !important;
  inline-size: min(100%, 37rem);
  & input {
    border: 2px solid #ccc !important;
    width: 1.5em !important;
    height: 1.5em !important;
    background: #fff !important;
    box-shadow: inset 0 1px 3px rgb(0 0 0 / 10%) !important;
    color: var(--accent-check);
  }
  & > label {
    position: relative !important;
    margin-left: 0 !important;
    margin-bottom: 0 !important;
    line-height: 1.2em;
    display: block;
    min-height: 12px;
    cursor: pointer !important;
    color: var(--text-dark);
    text-wrap-style: pretty;
  }
  &:is(:has(.toggle-switch), :not(:has(:nth-of-type(2)))) {
    background: unset !important;
    padding: unset !important;
    border: none !important;
    border-radius: unset !important;
    & > label {
      color: var(--text-white);
    }
  }
}

[type="checkbox"] + label::after {
  content: "" !important;
}

.dark {
  --range: var(--theme-light-blue);
}
.light {
  --range: var(--theme);
}
/* RANGE SLIDER */
input[type="range"] {
  -webkit-appearance: none;
  appearance: none;
  background: transparent;
  border: unset;
  cursor: pointer;
  width: 25rem;
  box-shadow: unset !important;
  &::-webkit-slider-thumb {
    -webkit-appearance: none; /* Override default look */
    appearance: none;
    margin-top: -4px; /* Centers thumb on the track */
    background-color: var(--range);
    border-radius: 1rem;
    height: 1.5rem;
    width: 1.5rem;
  }
  &::-moz-range-track {
    background-color: #a3cdf5;
    border-radius: 0.5rem;
    height: 1rem;
  }
  &::-moz-range-thumb {
    background-color: var(--range);
    border: none; /*Removes extra border that FF applies*/
    border-radius: 1rem;
    height: 1.5rem;
    width: 1.5rem;
  }
  &:focus {
    outline: none;
    &::-webkit-slider-thumb {
      outline: 3px solid var(--range);
      outline-offset: 0.125rem;
    }
    &::-moz-range-thumb {
      outline: 3px solid var(--range);
      outline-offset: 0.125rem;
    }
  }
  &::-webkit-slider-runnable-track {
    background-color: color-mix(in srgb, var(--range), transparent 70%);
    box-shadow: inset 0 0 0.25rem color-mix(in srgb, var(--range), transparent 70%);
    border-radius: 0.5rem;
    height: 1rem;
  }
}
.mktoRangeField {
  display: grid;
}
/* .mktoRangeValue {
  margin: unset !important;
} */
.mktoRangeValueText {
  text-align: center;
  color: white;
}

/* BUTTONS */
.mktoButtonWrap {
  margin-left: 0 !important;
}
.mktoButtonRow {
  width: 100% !important;
}
/* Required additional specificity */
.mktoForm .mktoButtonRow button.mktoButton {
  margin-top: 20px !important;
  display: inline-block;
  --theme: var(--theme-blue);
  --gradient-light: var(--theme-light-blue);
  --gradient-dark: var(--theme-dark-blue);
  --theme-gradient: linear-gradient(var(--angle), var(--gradient-dark) 0%, var(--gradient-light) 100%);
  background:
    linear-gradient(var(--bg-main-hover), var(--bg-main-hover)) padding-box,
    var(--theme-gradient) border-box !important;
  border: var(--border-width-button) solid transparent !important;
  border-radius: 100vmax;
  color: var(--text-white) !important;
  font-weight: var(--text-weight-bold);
  padding: var(--btn-padding-block) var(--btn-padding-inline) !important;
  appearance: none;
  text-decoration: none;
  text-transform: none;
  user-select: none;
  touch-action: manipulation;
  cursor: pointer;
  word-break: keep-all;
  z-index: 0;
  transition: all var(--speed-slow) var(--transition-out-quadratic);
  filter: brightness(1.4);
  --angle: 15deg;

  &:hover:not(:active) {
    background-color: var(--accent) !important;
    box-shadow: 0 0 0 0.125rem var(--theme);
    scale: 1.025;
    filter: brightness(1.2);
  }
  &:active:not(:disabled) {
    transition-duration: 0ms;
    color: var(--cta-pressed);
    box-shadow: 0 0 1rem rgb(var(--bg-inverse-rgb) / 0.2);
  }
  &:is(:focus-visible) {
    outline: dotted 0.1875rem var(--text-white) !important;
  }
}

.mktoFieldWrap:has(.mktoRangeField) {
  & label {
    left: 0;
    top: 0;
    position: relative;
    display: grid;
    margin-bottom: 5px;
    z-index: unset;
  }
  /* :is(.mktoRangeField.mktoHasWidth, input[type="range"]) {
    width: 300px !important;
  } */
  & :is(.mktoRangeValueText, .mktoRangeValueArrow) {
    background-color: var(--theme-green-blue) !important;
    background-image: linear-gradient(#4f87bd 43%, #1d4164 100%) !important;
    border-color: var(--theme-green-blue) !important;
  }
}

/* ERRORS */

.mktoForm .mktoError {
  position: relative !important;
  z-index: 99 !important;
  font-weight: bold;
  color: var(--accent) !important;
  left: 0px !important;
  bottom: 0 !important;
  top: 0.125rem !important;
  right: 0 !important;
  width: 100% !important;
  .mktoErrorMsg {
    display: block;
    max-width: 16em;
    animation: alternate-reverse;
    animation: bounce var(--speed-standard) infinite;
    background-color: transparent !important;
    background-image: none !important;
    border: 0px !important;
    box-shadow: none !important;
    text-shadow: none !important;
    font-size: 85% !important;
    font-weight: bold;
    color: var(--error-red) !important;
  }
  .mktoErrorArrowWrap {
    display: none !important;
  }
}

/* when an error is being displayed */
.mktoFieldWrap:has([aria-invalid="true"]) {
  &::before {
    content: "";
    position: absolute;
    width: 0.5rem;
    inset-inline-start: -2rem;
    inset-block: 0rem;
    background-color: var(--error-red);
    opacity: 0.4;
    border-radius: var(--border-radius-standard);
    pointer-events: none;
    animation-name: zoomIn;
    animation-duration: var(--speed-standard);
    animation-timing-function: var(--transition-spring);
    animation-fill-mode: both;
  }
}

/* EXCEPTIONS */

.mktoRequiredField label[for="leadaccepttermsandconditions"] {
  translate: calc(min(100%, 37rem) - 1rem) 1.4ch;
  position: absolute;
}

#Email[readonly]:hover + #InstructEmail {
  animation-name: shake;
  animation-duration: var(--speed-snail);
  animation-fill-mode: forwards;
}
#InstructEmail {
  margin-block-start: 0.75ex;
  inline-size: max-content;
  padding-inline: 1ch;
  margin-inline-start: -1ch;
  font-weight: var(--text-weight-medium);
  button {
    margin-inline-start: 0.5ch;
    padding-inline: 0.5ch;
    padding-block: 0.25ch;
    text-decoration: 1px underline var(--error-red);
    border-radius: 0.7ch;
    &:is(:focus-visible, :hover) {
      background-color: var(--accent);
      color: white;
      outline-color: var(--text-white);
    }
  }
  &:has(button:focus-visible) {
    background-color: color-mix(in srgb, var(--accent) 25%, transparent);
    border-radius: 1rem;
    /* color: white; */
  }
}

/* Custom questions and tools */
.custom-warning {
  color: var(--error-red);
  font-weight: var(--text-weight-bold);
  &[data-enable="false"] {
    display: none;
  }
}

.switch-group {
  display: flex;
  isolation: isolate;
  font-size: calc(50% + 50% * var(--size));
  position: relative;
  inline-size: fit-content;
  /* card surface should sit above background */
  /* background: transparent; */
  background-color: white;
  border-radius: var(--border-radius-standard);

  border: none;

  --size: 1;
  --squish: 1;
  &[data-size="small"] {
    --size: 0.5;
  }
  &[data-size="large"] {
    --size: 1.5;
  }
  &.squish {
    --squish: 0.5;
  }

  &[data-wrap="wrap"] {
    flex-wrap: wrap;
  }
  &[data-direction="horizontal"] {
    & .group-switch {
      margin-inline-end: -1px;
      &:nth-of-type(2) {
        border-radius: var(--border-radius-standard) 0 0 var(--border-radius-standard);
      }
      &:last-of-type {
        border-radius: 0 var(--border-radius-standard) var(--border-radius-standard) 0;
      }
    }
  }
  &[data-direction="vertical"] {
    flex-direction: column;
    inline-size: 100%;
    & .group-switch {
      margin-block-start: -1px;
      inline-size: 100%;
      &:nth-of-type(2) {
        border-radius: var(--border-radius-standard) var(--border-radius-standard) 0 0;
      }
      &:last-child {
        border-radius: 0 0 var(--border-radius-standard) var(--border-radius-standard);
      }
    }
    & .visual-indicator {
      &:has(+ .group-switch:nth-of-type(2) input:checked) {
        border-radius: var(--border-radius-standard) var(--border-radius-standard) 0 0;
      }
      &:has(~ .group-switch:last-of-type input:checked) {
        border-radius: 0 0 var(--border-radius-standard) var(--border-radius-standard);
      }
    }
  }

  & > legend {
    margin-bottom: 0.5rem;
    font-weight: var(--text-weight-bold);
    & :is(i, svg) {
      margin-right: calc(1ch * var(--size));
      color: var(--accent-check);
      width: 2ch;
      height: 2ch;
      translate: 0 12.5%;
    }
  }

  &:has(:disabled) {
    opacity: 0.5;
    pointer-events: none;
  }

  & .visual-indicator {
    position: absolute;
    will-change: left, right, top, bottom;
    position-anchor: var(--anchor);
    top: anchor(var(--anchor) top);
    bottom: anchor(var(--anchor) bottom);
    left: anchor(var(--anchor) left);
    right: anchor(var(--anchor) right);
    transition: all var(--speed-standard) var(--transition-in-out-quadratic);
    background: var(--accent);
    z-index: -1;
    &:has(+ .group-switch:nth-of-type(2) input:checked) {
      border-radius: var(--border-radius-standard) 0 0 var(--border-radius-standard);
    }
    &:has(~ .group-switch:last-of-type input:checked) {
      border-radius: 0 var(--border-radius-standard) var(--border-radius-standard) 0;
    }
  }
}
.group-switch {
  /* single cell grid, prepare for the pile */
  display: grid;
  place-items: center;
  border: 1px solid rgb(0 0 0 / 0.25);

  /* sets width */
  inline-size: fit-content;
  min-block-size: calc(3rem * var(--size));
  color: var(--text-dark);
  transition:
    outline-offset var(--speed-standard) ease,
    color var(--speed-standard) var(--transition-in-out-quadratic);

  /* when not pressed via keyboard */
  /* has the side effect of creating an animation */
  /* because :active will be 0 offset */
  &:not(:has(:active)) {
    outline-offset: 2px;
  }

  /* if focus is showing and there's focus within */
  /* provide a nice outline style */
  &:has(:focus-visible):focus-within {
    outline: 1px solid var(--accent);
  }

  /* stylish hover/selected background */
  &:has(:checked) {
    color: white;
    anchor-name: var(--anchor);
  }

  & label[for] {
    padding: 1ex calc(2ch * var(--size) * var(--squish)) !important;
    display: grid;
    grid-template-columns: auto auto;
    align-items: center;
    color: inherit;
    margin: 0;
  }
  /* all direct children pile into the single grid cell */
  & > :is(input, label) {
    grid-area: 1/1;
    line-height: 1;
    inline-size: 100%;
    block-size: 100%;
    cursor: pointer;
  }

  /* and dont just grow to fit, but max the size to fit */
  /* if not the SVG icon */
  /* content is there and interactive, just not visible */
  & > :is(input, label) {
    overflow: hidden;
    /* white-space: nowrap; */
  }
  & > input {
    box-shadow: unset;
    color: transparent;
    background: none;
    &::after {
      content: unset !important;
    }
  }

  /* icon color to follow the text color set on the switch parent */
  & svg {
    fill: currentColor;
    margin-right: calc(0.5ch * var(--size));
  }
}
.mktoCheckboxList:has(> .toggle-switch) {
  grid-template-columns: 1fr;
}
.toggle-switch {
  --th: 1.56rem;
  align-items: start;
  display: grid !important;
  grid-auto-flow: column;
  gap: 1ch;

  &:has(input:focus-visible) > div {
    outline-style: dotted;
    outline-width: 0.1875rem;
    outline-color: currentColor;
    border-radius: 100vmax;
  }

  & > div {
    position: relative;
    display: block;
    width: calc(var(--th) * 2);
    height: var(--th);
    & input {
      opacity: 0;
      width: 0;
      height: 0;
      &:checked + span {
        background-color: var(--accent-check);
        &:before {
          transform: translateX(var(--th));
        }
      }
      &:focus + span {
        box-shadow: 0 0 1px var(--accent);
      }
    }

    & span {
      position: absolute;
      cursor: pointer;
      inset: 0;
      background-color: rgb(var(--bg-inverse-rgb) / 10%);
      transition: var(--speed-slow);
      border-radius: 100vmax;
      border: var(--border-medium);
      &:before {
        position: absolute;
        content: "";
        inset-block: 0.25rem;
        aspect-ratio: 1;
        left: 0.25rem;
        background-color: white;
        transition: var(--speed-slow);
        border-radius: 100vmax;
        box-shadow: var(--shadow-small);
        border: 1px solid color-mix(in srgb, var(--accent) 50%, transparent 50%);
      }
    }
  }
  &[data-size="large"] {
    & > div {
      --th: 1.8rem;
      & span {
        border: var(--border-soft);
      }
    }
    font-size: 110%;
  }
}

.flex:has(> .mini-buttons) {
  flex-wrap: wrap;
  justify-content: space-between;
}
.mini-buttons {
  gap: 1ch;
  display: flex;
  flex-direction: row;
  flex: 0 1 fit-content;
  & :is(a, button) {
    font-size: var(--text-size-tiny);
    padding: 0ch 1.25ch;
  }
}
label:has(+ .mini-buttons) {
  flex: 0 1 fit-content;
  inline-size: fit-content;
}

.mktoFormRow:not(.no-margin):has(.checkbox-grid) {
  margin-block-start: 4rem;
}
.mktoForm .checkbox-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(var(--button-size, 17ch), 1fr));
  gap: 1.5rem;
  justify-content: center;
  border: none !important;
  background: none !important;
  padding-inline: unset !important;
  padding-block: 0.5rem 0 !important;
  user-select: none;

  &[data-size="small"] {
    --button-size: 12ch;
  }
  &[data-size="medium"] {
    --button-size: 15ch;
  }
  &[data-size="large"] {
    --button-size: 17ch;
  }

  label {
    inline-size: 100%;
    &:has(:disabled) {
      display: none;
    }
  }

  input[type="checkbox"] {
    clip: rect(0 0 0 0);
    clip-path: inset(100%);
    height: 1px;
    overflow: hidden;
    position: absolute;
    white-space: nowrap;
    width: 1px;

    &:checked + .cx-tile {
      border-color: var(--accent-check);
      box-shadow:
        var(--shadow-standard),
        inset 0 0 0.5rem 0.25rem color-mix(in srgb, var(--accent-check) var(--is-light, 50%), transparent 50%);
      color: var(--accent-check);
      scale: 1.1;
      &:before {
        transform: scale(1);
        opacity: 1;
        background-color: var(--accent-check);
        border-color: var(--accent-check);
      }

      .cx-icon,
      .cx-label {
        color: var(--accent-check);
      }
    }

    &:is(:focus, :focus-visible) + .cx-tile {
      border-color: var(--accent-check);
      box-shadow:
        var(--shadow-standard),
        inset 0 0 0.5rem 0.25rem color-mix(in srgb, var(--accent-check) var(--is-light, 50%), transparent 50%),
        0 0 0 0.25rem color-mix(in srgb, var(--accent-check), transparent);

      &:before {
        transform: scale(1);
        opacity: 1;
      }
    }
    &:not(:checked) + :where(.cx-tile) {
      box-shadow: inset 0 0 1.5rem 0.5rem color-mix(in srgb, var(--bg-main), transparent 75%);
    }
  }

  .cx-tile {
    display: grid;
    place-items: center;
    aspect-ratio: 16 / 9;
    padding-inline: 2ch;
    border-radius: var(--border-radius-standard);
    border: 0.125rem solid rgb(var(--bg-inverse-rgb) / 0.125);
    background-color: #fff;
    box-shadow: var(--shadow-standard);
    transition: scale var(--speed-fast) ease;
    will-change: scale;
    cursor: pointer;
    position: relative;

    &:before {
      content: "";
      position: absolute;
      display: block;
      width: 1.5ch;
      height: 1.5ch;
      border: 0.125rem solid #b5bfd9;
      background-color: #fff;
      border-radius: 50%;
      top: 0.25rem;
      left: 0.25rem;
      opacity: 0.5;
      transition: var(--speed-standard) ease;
      background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='192' height='192' fill='%23FFFFFF' viewBox='0 0 256 256'%3E%3Crect width='256' height='256' fill='none'%3E%3C/rect%3E%3Cpolyline points='216 72.005 104 184 48 128.005' fill='none' stroke='%23FFFFFF' stroke-linecap='round' stroke-linejoin='round' stroke-width='32'%3E%3C/polyline%3E%3C/svg%3E");
      background-size: 0.75rem;
      background-repeat: no-repeat;
      background-position: 50% 50%;
    }

    &:hover {
      border-color: var(--accent-check);
      box-shadow:
        var(--shadow-standard),
        inset 0 0 0.5rem 0.25rem color-mix(in srgb, var(--accent-check), transparent 75%);
      &:before {
        opacity: 1;
      }
    }
  }

  .cx-icon {
    transition: var(--speed-standard) ease;
    color: var(--text-dark);
    pointer-events: none;
    svg {
      width: 3rem;
      height: 3rem;
    }
    img {
      filter: unset !important;
      width: 100%;
    }
    &:has([data-error="true"]) {
      display: none;
    }
  }

  &[data-labels="hidden"] {
    label:has(.cx-icon):not(:has([data-error="true"])) {
      .cx-label {
        display: none;
      }
    }
  }
  .cx-label {
    color: var(--text-dark);
    /* transition: var(--speed-standard) ease; */
    text-align: center;
  }
}

.custom-validation {
  &[data-validation="error"] {
    position: relative;
    margin-block-end: 0;
    &::before {
      content: "";
      position: absolute;
      width: 0.5rem;
      inset-inline-start: -2rem;
      inset-block: 0rem;
      background-color: var(--error-red);
      opacity: 0.4;
      border-radius: var(--border-radius-standard);
      pointer-events: none;
      animation-name: zoomIn;
      animation-duration: var(--speed-standard);
      animation-timing-function: var(--transition-spring);
      animation-fill-mode: both;
    }
    & + .custom-warning {
      display: block;
      margin-block-end: 2rem;
      font-size: 85%;
    }
  }
}

/* Specific template overrides */
.westcon.full-page-form {
  &::before {
    background: var(--theme-blue);
  }
  #gradient-canvas {
    position: fixed;
  }
  .mainContainer {
    box-shadow: inset 0 0 0 100vmax var(--bg-main);
  }
}
.westcon.simple-design {
  --bg-main-hover: var(--bg-main);

  .mainContainer {
    padding-top: unset;
    --container-padding: clamp(0rem, 4 * (100vw - 37.5em) / 25, 4rem);
    --border-width: clamp(0rem, 1.5 * (100vw - 37.5em) / 25, 0.75rem);
    /* to ensure footer always at end of page */
    min-height: 100vh;
    display: grid;
    grid-template-rows: auto 1fr;
    align-items: start;
    align-content: start;
  }
  header {
    z-index: 2;
    position: relative;
    padding-block-start: 1rem;
    padding-block-end: 1rem;
    background-color: var(--bg-main);
    box-shadow: 0 0 0 100vmax var(--bg-main);
    clip-path: inset(-10rem -100vmax 0 -100vmax);
    img,
    .header-upper-navigation {
      margin-inline: clamp(0rem, (100em - 100vw) / 25, 1rem);
    }
  }
  :where(header, #main) {
    --excess: calc(100rem - 100% - 2 * var(--container-padding));
    --dynamic-margin: clamp(0%, 16.66rem - var(--excess) / 2, 16.66rem);
    padding-inline-start: var(--dynamic-margin);
  }
  .footer {
    margin-block-start: unset;
  }
  header {
    margin-block-end: 2rem;
    margin-block-start: 0;
    padding-inline-end: var(--inline-reverse-padding);
    padding-inline-start: calc(var(--inline-reverse-padding) + var(--dynamic-margin, 0));
    margin-inline: var(--inline-reverse-margin);
  }
  #gradient-canvas {
    position: fixed;
    height: 100vh;
    width: 100vw;
    left: 0;
    top: 0;
    right: 0;
    z-index: 0;
  }
  #mktoForm {
    z-index: 1;
    position: relative;
    --shift: calc(4rem + var(--gap-large));
    margin-bottom: 4rem;
    max-inline-size: calc(47ch + 8rem);
    --angle: 90deg;
    border: var(--border-width) solid;
    border-image-slice: 1;
    border-image-source: var(--theme-gradient);
    background-color: var(--bg-main);
    padding-block: min(4rem, 5vw);
    padding-inline-start: min(4rem, 5vw);
    padding-inline-end: min(3rem, 3vw);
    box-shadow: var(--shadow-large);
  }
}
.westcon.embedded-form {
  &::before,
  &::after {
    content: unset;
  }
  --bg-scrollbar-track: rgb(0 0 0 / 0.1);
  --bg-scrollbar-thumb: rgb(from var(--theme-light-blue) r g b / 0.4);
  --bg-scrollbar-thumb-outline: transparent;
}
.westcon.standard-design {
  --max-container-width: 100rem;
  --block-gap: clamp(2rem, 14vh, 11rem);
  --bg-color: color-mix(in oklch, rgb(0 10 26) 50%, transparent);
  .page-title {
    color: white;
  }
  &::before {
    z-index: -1;
  }
  header {
    margin-block-end: calc(1rem + var(--block-gap));
  }

  .header-grid-container {
    display: grid;
    align-items: start;
    grid-template: "title form" auto "intro form" auto "space form" auto / 1fr 1fr;
    gap: calc(0.5 * var(--block-gap));
    outline-offset: 1px;
  }

  .page-title {
    grid-area: title;
    margin-block-end: calc(1rem + var(--block-gap));
    position: relative;
    z-index: 0;
    h1 {
      font-size: calc(var(--text-size-h1-dynamic) * clamp(0.6, (100 - (var(--length, 22) - 22)) / 100 + 0.1, 0.85));
      &:has(span:empty) {
        display: none;
      }
    }
    &::before {
      content: "";
      position: absolute;
      inset: -2rem;
      inset-inline-end: -100%;
      /* inset-block: -2rem;
      inset-inline: -100vw; */
      z-index: -1;
      background-color: var(--bg-color);
      backdrop-filter: blur(1rem);
      /* filter: blur(0.5rem); */
    }
  }
  #gradient-canvas {
    position: absolute;
    height: calc(100% + 2 * var(--block-gap));
    width: 100vw;
    top: calc(-1 * var(--block-gap) + var(--gap));
    bottom: var(--block-gap);
    left: calc(
      -1 *
        clamp(
          var(--container-padding),
          var(--container-padding) + 0.5 * (100vw - var(--max-container-width)),
          2 * var(--gap-section)
        )
    );
    z-index: -2;
  }
  .marketo-form {
    max-inline-size: unset;
    grid-area: form;
    z-index: 1;
    justify-self: end;
    background-color: var(--bg-main);
    /* margin-block-start: calc(-1 * var(--block-gap)); */
    margin-block-end: var(--gap-large);
    --block-padding: clamp(1.75rem, 3.5vw, 3rem);
    padding: var(--block-padding);
    padding-block-start: calc(0.5 * var(--block-padding));
    box-shadow: var(--shadow-large);
    --angle: 93deg;
    border: var(--border-width) solid;
    border-image-slice: 1;
    border-image-source: var(--theme-gradient);
    form {
      padding: 0;
    }
  }
  .page-introduction {
    grid-area: intro;
  }
  :is(.page-title, .page-introduction, ) {
    :where(ul, ol) {
      padding-inline-start: 2ch;
      li {
        padding-inline-start: 0.5ch;
        padding-block-end: 0.5ch;
      }
    }
  }
  @media (max-width: 980px) {
    & {
      --block-gap: 4rem;
    }
    header {
      margin-block-end: calc(1rem + var(--block-gap));
    }
    .header-grid-container {
      grid-template: "title" auto "form" auto "intro" auto "space" auto / 1fr;
      gap: 0;
    }
    .marketo-form {
      justify-self: center;
      margin-block-start: 1rem;
    }
    #gradient-canvas {
      top: calc(-1 * var(--block-gap));
    }
    #mktoForm {
      --dynamic-padding: clamp(0.5rem, 4 * (100vw - 45em) / 32, 4rem);
      padding-inline-start: calc(2rem + 0.5 * var(--dynamic-padding));
      padding-inline-end: calc(1rem + 0.5 * var(--dynamic-padding));
      margin-inline: calc(-1 * var(--dynamic-padding) - var(--border-width) * 2);
    }
    form.mktoForm {
      max-inline-size: 60ch;
      margin-inline: auto;
    }
  }
  &:has(.mktoPlaceholder) {
    .marketo-form {
      min-inline-size: 22ch;
    }
    h1:has(span:empty) {
      display: block !important;
      & span::before {
        content: "{{Title not yet used}}";
        font-size: 75%;
      }
    }
    #HTMLCode:is(:empty, :has(div:empty:only-child))::before {
      content: "{{Optional additional content not used - this message will not be displayed in production}}";
    }
  }
}
:where(#logo-switch) {
  grid-area: logo;
  height: calc(1.25rem + var(--icon-upper-header));
  z-index: 3;
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center left;
  &:not([data-logo="westcon"], [data-logo="comstor"]) {
    inline-size: min(80vw, 14rem);
    background-image: url("https://www.westconcomstor.com/content/dam/wcgcom/Global/CorpSite/logos/westcon-comstor.svg");
  }
  &[data-logo="comstor"] {
    inline-size: min(80vw, 14rem);
    background-image: url("https://www.westconcomstor.com/content/dam/wcgcom/Global/CorpSite/logos/comstor.svg");
  }
  &[data-logo="westcon"] {
    inline-size: min(80vw, 14rem);
    background-image: url("https://www.westconcomstor.com/content/dam/wcgcom/Global/CorpSite/logos/westcon.svg");
  }
  &[data-logo="rebura"] {
    inline-size: min(80vw, 10rem);
    background-image: url("https://rebura.com/content/dam/rebura/logo_rebura.svg");
  }
  &:is([data-logo*=".png"], [data-logo*=".jpg"], [data-logo*=".svg"]) {
    inline-size: min(80vw, 14rem);
    background-image: var(--logo);
  }
}
/* Success message */
:where(#mktoSuccessMsg) {
  p:first-child {
    font-size: var(--text-size-larger);
  }
  .flexibleRowContainer {
    margin-block-end: 0;
  }
}
#mktoForm:has(form[data-showing-success]) {
  @supports not (transition-behavior: allow-discrete) {
    #formAreaText-top {
      display: none;
    }
  }
  #formAreaText-top {
    content-visibility: hidden;
    block-size: 0;
    overflow: clip;
    margin: 0;
  }
  #formAreaText-bottom {
    display: none;
  }
}
