/*************************************
  Spotix General Branding Styles
  # Common Variables

  # page width class

  # Eyebrow Styles
    -large eyebrow styles
    -small eyebrow styles
  # Heading Styles
    -large heading styles
    -medium heading styles
    -small heading styles
    -Display Styles
  # Body Text Styles
    -large body styles
    -medium body styles
    -small body styles 

  # Overall styles for buttons
    -large button styles
    -small button styles
  # styles for primary buttons
    -hover/active state
  # styles for secondary buttons
    -hover/active state
  # styles for link "buttons"
    -hover state
  # mobile styles (tentative breakpoint of 750px)
    -heading sizes
    -body sizes
  # Styles for form fields
    -general / input styles
    -select styles
    -checkbox / radio styles
*************************************/

:root {
  --page-width: 144rem;
  --color-error: #C80000;
  --color-brand-primary: #EB7722;
  --color-brand-charcoal: #3D3935;
  --color-brand-gray: #B5B4AF;
  --color-brand-cool-gray: #63666A;
  --color-brand-cool-gray-2: #D0D0CE;
  --color-brand-cool-gray-3: #E6E7E8;
  --color-brand-light-gray: #E1E1DC;
  --color-brand-warm-gray: #F5F4F0;
  --color-brand-off-white: #F7F6F4;
  --color-brand-black: #000;
  --color-brand-white: #FFF;
  --color-brand-pro-yellow: #F2A900;
  --color-success: #007011;

  --propel-font-body-family: Poppins, sans-serif;
  --propel-font-body-style: normal;
  --propel-font-body-weight: 400;
  --propel-font-body-weight-semibold: 600;
  --propel-font-body-weight-bold: 700;
  --propel-font-heading-family: "Libre Caslon Display", serif;
  --propel-font-heading-style: normal;
  --propel-font-heading-weight: 400;
  --propel-font-bottom-margin: 2rem;
}

.page-width {
  width: 100%;
  max-width: var(--page-width);
  margin: 0 auto;
  padding-inline: 6rem;
}

body {
  font-family: var(--propel-font-body-family);
}

div,
span {
  color: var(--color-brand-charcoal);

  .dark-bg &:not(.dark-bg .lite-bg *) {
    color: var(--color-brand-white);
  }
}

p,
.body-lg,
.body-md,
.body-sm,
.body-xs {

  &,
  & a:not(.link),
  & p {
    color: var(--color-brand-charcoal);
    font-style: normal;
    font-weight: 400;
    font-style: normal;
    font-size: 2rem;
    letter-spacing: normal;
    line-height: 180%;
    margin: 0 0 2rem;
    text-transform: none;

    .dark-bg &:not(.dark-bg .lite-bg *),
    .dark-bg & p:not(.dark-bg .lite-bg *) {
      color: var(--color-brand-white);
    }

    &.zero-m,
    &.zero-m p,
    &.zero-m a {
      margin-bottom: 0;
    }
  }

  a:not(.link) &:hover,
  a:not(.link)&:hover,
  & a:not(.link):hover {
    text-decoration: underline;
  }
}

.body-lg,
.body-lg p,
.body-lg a:not(.link) {
  font-size: 2.4rem;
}

.body-sm,
.body-sm p,
.body-sm a:not(.link) {
  font-size: 1.6rem;
}

.body-xs,
.body-xs p,
.body-xs a:not(.link) {
  font-size: 1.2rem;
}

.eyebrow,
.eyebrow>p {
  color: var(--color-brand-charcoal);
  text-transform: uppercase;
  font-family: var(--propel-font-body-family);
  font-size: 1.8rem;
  font-weight: 500;
  line-height: normal;
  letter-spacing: 0.27rem;
  text-transform: uppercase;
  margin-bottom: var(--propel-font-bottom-margin);


  &.zero-m,
  &.eyebrow>p {
    margin-bottom: 0;
  }

  &.lg,
  &.lg>p {
    font-size: 2.2rem;
    letter-spacing: 0.33rem;
  }

  &.sm,
  &.sm>p {
    font-size: 1.4rem;
    letter-spacing: 0.14rem;
  }

  &.xs,
  &.xs>p {
    font-size: 1.2rem;
    letter-spacing: 0.12rem;
  }

  .dark-bg &:not(.dark-bg .lite-bg *),
  .dark-bg &:not(.dark-bg .lite-bg *)>p {
    color: var(--color-brand-white);
  }

  a &:hover,
  a&:hover,
  & a:hover {
    text-decoration: underline;
  }
}

h1,
h2,
h3,
h4,
h5,
h6,
.heading-1,
.heading-2,
.heading-3,
.display-1,
.display-2,
.display-3 {

  &,
  &>a:not(.link),
  &.text-block>* {
    color: var(--color-brand-charcoal);
    font-style: var(--propel-font-heading-style);
    font-weight: var(--propel-font-heading-weight);
    font-family: var(--propel-font-body-family);
    font-style: normal;
    font-weight: 400;
    line-height: normal;
    letter-spacing: normal;
    margin: 0 0 2rem;

    .dark-bg &:not(.dark-bg .lite-bg *) {
      color: var(--color-brand-white);
    }

    &.zero-m {
      margin-bottom: 0;
    }
  }
}

.display-1,
.display-2,
.display-3 {

  &,
  &>a:not(.link),
  &.text-block>* {
    font-family: var(--propel-font-heading-family);
    line-height: 110%;
  }
}

h1,
.heading-1 {

  &,
  &>a:not(.link),
  &.text-block>* {
    font-size: 4.2rem;
  }
}

h2,
.heading-2 {

  &,
  &>a:not(.link),
  &.text-block>* {
    font-size: 3.4rem;
  }
}

h3,
h4,
h5,
h6,
.heading-3 {

  &,
  &>a:not(.link),
  &.text-block>* {
    font-size: 2.4rem;
    line-height: 1.2;
  }
}

.heading-xl,
.heading-xl>a:not(.link),
.heading-xl.text-block>* {
  font-size: 6.2rem;
}

.display-1,
.display-1>a:not(.link),
.display-1.text-block>* {
  font-size: 9.2rem;
}

.display-2,
.display-2>a:not(.link),
.display-2.text-block>* {
  font-size: 6.2rem;
}

.display-3,
.display-3>a:not(.link),
.display-3.text-block>* {
  font-size: 4.2rem;
}

.cta-button {
  cursor: pointer;
  background-color: var(--color-brand-primary);
  border: .1rem solid var(--color-brand-primary);
  border-radius: .6rem;
  display: inline-flex;
  height: 6rem;
  padding: 1.5rem 4.9rem;
  justify-content: center;
  align-items: center;
  transition: opacity .3s;

  &,
  & * {
    color: var(--color-brand-charcoal);
    font-family: var(--propel-font-body-family);
    font-weight: 500;
    font-size: 1.4rem;
    text-transform: uppercase;
    letter-spacing: 0.21rem;
    line-height: normal;
  }

  &:hover,
  &.hover,
  &:active,
  &.active {
    opacity: 0.8;
  }

  &.sm {
    padding: 1rem 2rem;
    height: 3.8rem;
  }
}

.cta-button.secondary {
  border-color: var(--color-brand-charcoal);
  background-color: var(--color-brand-charcoal);

  &,
  & * {
    color: var(--color-brand-white);
  }

  .dark-bg &:not(.dark-bg .lite-bg *),
  &.lite-cta {
    background-color: var(--color-brand-white);
    border-color: var(--color-brand-white);

    &,
    & * {
      color: var(--color-brand-cool-gray);
    }

    &[disabled] {
      background-color: var(--color-brand-light-gray);
      border-color: var(--color-brand-light-gray);

      &,
      & * {
        color: var(--color-brand-charcoal);
      }
    }
  }
}

.cta-button.tertiary {
  color: var(--color-brand-white);
  border-color: var(--color-brand-cool-gray);
  background-color: var(--color-brand-cool-gray);

  &,
  & * {
    color: var(--color-brand-white);
  }
}

.cta-button.outline {
  border-color: var(--color-brand-charcoal);
  background-color: transparent;

  &,
  & * {
    color: var(--color-brand-charcoal);
  }

  .dark-bg &:not(.dark-bg .lite-bg *),
  &.lite-cta {
    border-color: var(--color-brand-white);

    &,
    & * {
      color: var(--color-brand-white);
    }

    &[disabled] {
      background-color: var(--color-brand-light-gray);
      border-color: var(--color-brand-light-gray);

      &,
      & * {
        color: var(--color-brand-charcoal);
      }
    }
  }

  &:hover,
  &.hover,
  &:active,
  &.active {
    opacity: 1;
    text-underline-offset: 0.3rem;
    text-decoration: underline;
  }
}

a,
.link {
  color: var(--color-brand-charcoal);
  font-family: var(--propel-font-body-family);
  font-size: 1.2rem;
  font-style: normal;
  font-weight: 700;
  line-height: normal;
  letter-spacing: 0.18rem;
  text-transform: uppercase;
  text-decoration: underline;
  text-decoration-line: underline;
  text-decoration-color: var(--color-brand-charcoal);
  text-decoration-style: solid;
  text-underline-offset: .3rem;
  cursor: pointer;

  .dark-bg &:not(.dark-bg .lite-bg *),
  &.lite-cta {
    color: var(--color-brand-white);
  }

  &:hover,
  &.hover {
    text-decoration: none;
  }
}

.cta-button.disabled,
.cta-button[disabled],
.cta-button[disabled]:hover,
.cta-button.outline[disabled] {
  opacity: 1;
  text-decoration: none;
  background-color: var(--color-brand-light-gray);
  border-color: var(--color-brand-light-gray);
  cursor: not-allowed;

  &,
  & * {
    color: var(--color-brand-charcoal);
  }
}

/*** Dark Background Text Styles ***/

.dark-bg .cta-button.secondary[disabled]:not(.dark-bg .lite-bg *),
.dark-bg .cta-button.outline[disabled]:not(.dark-bg .lite-bg *) {
  background-color: var(--color-brand-light-gray);
  border-color: var(--color-brand-light-gray);

  &,
  & * {
    color: var(--color-brand-charcoal);
  }
}

/* component-form */
.field__input,
.select__select {
  -webkit-appearance: none;
  appearance: none;
  color: rgb(var(--color-foreground));
  font-family: var(--font-body-family);
  font-style: var(--font-body-style);
  font-weight: var(--font-body-weight);
  font-size: 1.6rem;
  width: 100%;
  box-sizing: border-box;
  transition: box-shadow .1s ease;
  border-radius: .6rem;
  border: .1rem solid var(--color-brand-charcoal);
  height: 7rem;
  min-height: calc(var(--inputs-border-width) * 2);
  min-width: calc(7rem + (var(--inputs-border-width) * 2));
  position: relative;
  padding: 2rem;

  &[disabled] {
    cursor: not-allowed;
    background-color: var(--color-brand-off-white);
  }

  &:focus,
  &:focus-visible {
    box-shadow: none;
    outline: 0;
  }

  .field.error & {
    border-color: var(--color-error);
    color: var(--color-error);
  }
}

.select__select {
  font-family: var(--font-body-family);
  font-style: var(--font-body-style);
  font-weight: var(--font-body-weight);
  font-size: 1.6rem;
  color: rgba(var(--color-foreground), 0.75);
}

.custom-select::after {
  content: '';
  position: absolute;
  right: 2rem;
  top: 50%;
  transform: translateY(-50%) rotate(45deg);
  width: 0.8rem;
  height: 0.8rem;
  border-right: 0.1rem solid var(--color-brand-black);
  border-bottom: 0.1rem solid var(--color-brand-black);
  pointer-events: none;
}

.field.error+span {
  color: var(--color-error);
  margin-left: 2rem;
  font-size: 1.2rem;
}

/* Field */

.field {
  position: relative;
  width: 100%;
  display: flex;
  transition: box-shadow .1s ease;
}

.field__input {
  flex-grow: 1;
  text-align: left;
  margin: var(--inputs-border-width);
  transition: box-shadow .1s ease;

  &:focus,
  &:not(:placeholder-shown),
  &:-webkit-autofill {
    padding: 2.2rem 1.5rem 0.8rem 2rem;
    margin: var(--inputs-border-width);

    &~.field__label {
      font-size: 1rem;
      top: 1.4rem;
      left: 2.1rem;
      letter-spacing: 0.04rem;
    }
  }
}

.field__label {
  font-size: 1.6rem;
  left: 2rem;
  top: 50%;
  transform: translateY(-50%);
  margin-bottom: 0;
  pointer-events: none;
  position: absolute;
  transition: top .1s ease, font-size .1s ease;
  color: rgba(var(--color-foreground), 0.75);
  letter-spacing: 0.1rem;
  line-height: 1.8;

  .field.error & {
    color: var(--color-error);
  }
}

.field__label--inline {
  font-weight: 500;
  font-size: 1.4rem;
  text-transform: uppercase;
}

.field__input::-webkit-search-cancel-button {
  display: none;
}

.field__input::placeholder {
  opacity: 0;
}

input[type='checkbox'],
input[type='radio'] {
  display: inline-block;
  vertical-align: middle;
  width: auto;
  margin: 0 0.5rem 0 0;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  position: relative;
  width: 1.6rem;
  height: 1.6rem;
  border: 1px solid var(--color-brand-charcoal);
  border-radius: .4rem;

  &+label {
    vertical-align: middle;
  }

  &[disabled] {
    border-color: #3336;
  }

  &[disabled]~label {
    color: #3336;
  }
}

input[type='radio'] {
  border-radius: 50%;
}

input[type='checkbox']:before {
  content: '';
  top: 3px;
  left: 2px;
  font-size: 7px;
  position: absolute;
  height: 0.7rem;
  width: 1rem;
  pointer-events: none;
}

input[type=checkbox]:checked {
  background-color: var(--color-brand-charcoal);
  border-color: var(--color-brand-charcoal);
}

input[type=checkbox]:checked:before {
  content: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" width="10" height="8" viewBox="0 0 10 8" fill="none"><rect x="0.121094" y="3.49121" width="1.60515" height="5.00032" transform="rotate(-45 0.121094 3.49121)" fill="white"/><rect x="8.65674" y="0.235352" width="1.60515" height="8" transform="rotate(45 8.65674 0.235352)" fill="white"/></svg>');
}

input[type='radio']:checked:before {
  content: '';
  position: absolute;
  border-radius: 50%;
  top: 0.2rem;
  left: 0.2rem;
  background-color: var(--color-brand-charcoal);
  width: calc(100% - 0.4rem);
  height: calc(100% - 0.4rem);
}

@media (max-width: 750px) {

  .field__input,
  .select__select {
    font-size: 1.2rem;
    padding: 1rem;
    height: 4.2rem;
  }

  .field__input:focus,
  .field__input:not(:placeholder-shown),
  .field__input:-webkit-autofill {
    padding: 2rem 1rem 1rem;

    &~.field__label {
      top: 1.2rem;
      left: 1.1rem;
    }
  }

  .field__label {
    font-size: 1.2rem;
    left: 1rem;
  }

  .field.error+span {
    margin-left: 1rem;
    font-size: 1rem;
  }

  .field__label--inline {
    font-size: 1.2rem;
  }
}

@media (max-width: 750px) {
  .page-width {
    padding-inline: 2rem;
  }

  .eyebrow,
  .eyebrow>p {
    font-size: 1.6rem;
    letter-spacing: 0.24rem;

    &.lg,
    &.lg>p {
      font-size: 2rem;
      letter-spacing: 0.3rem;
    }

    &.sm,
    &.sm>p {
      font-size: 1.2rem;
      letter-spacing: 0.18rem;
    }
  }

  p,
  .body-lg,
  .body-md,
  .body-sm {
    font-size: 1.6rem;
    line-height: 160%;
    margin-bottom: 1.5rem;
  }

  .body-lg,
  .body-lg p {
    font-size: 2rem;
  }

  .body-sm,
  .body-sm p {
    font-size: 1.2rem;
  }

  h1,
  .heading-1,
  .heading-1.text-block>* {
    font-size: 3.6rem;
  }

  h2,
  .heading-2,
  .heading-2.text-block>* {
    font-size: 2.8rem;
  }

  h3,
  h4,
  h5,
  h6,
  .heading-3 {

    &,
    &.text-block>* {
      font-size: 2rem;
      line-height: 1.2;
    }
  }

  .heading-xl,
  .heading-xl.text-block>* {
    font-size: 3.6rem;
  }

  .display-1,
  .display-1.text-block>* {
    font-size: 6.2rem;
  }

  .display-2,
  .display-2.text-block>* {
    font-size: 4.2rem;
  }

  .display-3,
  .display-3.text-block>* {
    font-size: 3.6rem;
  }

  .cta-button {
    height: 4rem;
    padding: 1rem 2.3rem;

    &,
    & * {
      font-size: 1.2rem;
      letter-spacing: 0.18rem;
    }
  }
}