.glide{position:relative;width:100%;box-sizing:border-box}.glide *{box-sizing:inherit}.glide__track{overflow:hidden}.glide__slides{position:relative;width:100%;list-style:none;backface-visibility:hidden;transform-style:preserve-3d;touch-action:pan-Y;overflow:hidden;padding:0;white-space:nowrap;display:flex;flex-wrap:nowrap;will-change:transform}.glide__slides--dragging{user-select:none}.glide__slide{width:100%;height:100%;flex-shrink:0;white-space:normal;user-select:none;-webkit-touch-callout:none;-webkit-tap-highlight-color:transparent}.glide__slide a{user-select:none;-webkit-user-drag:none;-moz-user-select:none;-ms-user-select:none}.glide__arrows{-webkit-touch-callout:none;user-select:none}.glide__bullets{-webkit-touch-callout:none;user-select:none}.glide--rtl{direction:rtl}
/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */
/* Document
   ========================================================================== */
/**
 * 1. Correct the line height in all browsers.
 * 2. Prevent adjustments of font size after orientation changes in iOS.
 */
html {
  line-height: 1.15;
  /* 1 */
  -webkit-text-size-adjust: 100%;
  /* 2 */ }

/* Sections
   ========================================================================== */
/**
 * Remove the margin in all browsers.
 */
body {
  margin: 0; }

/**
 * Render the `main` element consistently in IE.
 */
main {
  display: block; }

/**
 * Correct the font size and margin on `h1` elements within `section` and
 * `article` contexts in Chrome, Firefox, and Safari.
 */
h1 {
  font-size: 2em;
  margin: 0.67em 0; }

/* Grouping content
   ========================================================================== */
/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */
hr {
  box-sizing: content-box;
  /* 1 */
  height: 0;
  /* 1 */
  overflow: visible;
  /* 2 */ }

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
pre {
  font-family: monospace, monospace;
  /* 1 */
  font-size: 1em;
  /* 2 */ }

/* Text-level semantics
   ========================================================================== */
/**
 * Remove the gray background on active links in IE 10.
 */
a {
  background-color: transparent; }

/**
 * 1. Remove the bottom border in Chrome 57-
 * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 */
abbr[title] {
  border-bottom: none;
  /* 1 */
  text-decoration: underline;
  /* 2 */
  text-decoration: underline dotted;
  /* 2 */ }

/**
 * Add the correct font weight in Chrome, Edge, and Safari.
 */
b,
strong {
  font-weight: bolder; }

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
code,
kbd,
samp {
  font-family: monospace, monospace;
  /* 1 */
  font-size: 1em;
  /* 2 */ }

/**
 * Add the correct font size in all browsers.
 */
small {
  font-size: 80%; }

/**
 * Prevent `sub` and `sup` elements from affecting the line height in
 * all browsers.
 */
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline; }

sub {
  bottom: -0.25em; }

sup {
  top: -0.5em; }

/* Embedded content
   ========================================================================== */
/**
 * Remove the border on images inside links in IE 10.
 */
img {
  border-style: none; }

/* Forms
   ========================================================================== */
/**
 * 1. Change the font styles in all browsers.
 * 2. Remove the margin in Firefox and Safari.
 */
button,
input,
optgroup,
select,
textarea {
  font-family: inherit;
  /* 1 */
  font-size: 100%;
  /* 1 */
  line-height: 1.15;
  /* 1 */
  margin: 0;
  /* 2 */ }

/**
 * Show the overflow in IE.
 * 1. Show the overflow in Edge.
 */
button,
input {
  /* 1 */
  overflow: visible; }

/**
 * Remove the inheritance of text transform in Edge, Firefox, and IE.
 * 1. Remove the inheritance of text transform in Firefox.
 */
button,
select {
  /* 1 */
  text-transform: none; }

/**
 * Correct the inability to style clickable types in iOS and Safari.
 */
button,
[type="button"],
[type="reset"],
[type="submit"] {
  -webkit-appearance: button; }

/**
 * Remove the inner border and padding in Firefox.
 */
button::-moz-focus-inner,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
  border-style: none;
  padding: 0; }

/**
 * Restore the focus styles unset by the previous rule.
 */
button:-moz-focusring,
[type="button"]:-moz-focusring,
[type="reset"]:-moz-focusring,
[type="submit"]:-moz-focusring {
  outline: 1px dotted ButtonText; }

/**
 * Correct the padding in Firefox.
 */
fieldset {
  padding: 0.35em 0.75em 0.625em; }

/**
 * 1. Correct the text wrapping in Edge and IE.
 * 2. Correct the color inheritance from `fieldset` elements in IE.
 * 3. Remove the padding so developers are not caught out when they zero out
 *    `fieldset` elements in all browsers.
 */
legend {
  box-sizing: border-box;
  /* 1 */
  color: inherit;
  /* 2 */
  display: table;
  /* 1 */
  max-width: 100%;
  /* 1 */
  padding: 0;
  /* 3 */
  white-space: normal;
  /* 1 */ }

/**
 * Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */
progress {
  vertical-align: baseline; }

/**
 * Remove the default vertical scrollbar in IE 10+.
 */
textarea {
  overflow: auto; }

/**
 * 1. Add the correct box sizing in IE 10.
 * 2. Remove the padding in IE 10.
 */
[type="checkbox"],
[type="radio"] {
  box-sizing: border-box;
  /* 1 */
  padding: 0;
  /* 2 */ }

/**
 * Correct the cursor style of increment and decrement buttons in Chrome.
 */
[type="number"]::-webkit-inner-spin-button,
[type="number"]::-webkit-outer-spin-button {
  height: auto; }

/**
 * 1. Correct the odd appearance in Chrome and Safari.
 * 2. Correct the outline style in Safari.
 */
[type="search"] {
  -webkit-appearance: textfield;
  /* 1 */
  outline-offset: -2px;
  /* 2 */ }

/**
 * Remove the inner padding in Chrome and Safari on macOS.
 */
[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none; }

/**
 * 1. Correct the inability to style clickable types in iOS and Safari.
 * 2. Change font properties to `inherit` in Safari.
 */
::-webkit-file-upload-button {
  -webkit-appearance: button;
  /* 1 */
  font: inherit;
  /* 2 */ }

/* Interactive
   ========================================================================== */
/*
 * Add the correct display in Edge, IE 10+, and Firefox.
 */
details {
  display: block; }

/*
 * Add the correct display in all browsers.
 */
summary {
  display: list-item; }

/* Misc
   ========================================================================== */
/**
 * Add the correct display in IE 10+.
 */
template {
  display: none; }

/**
 * Add the correct display in IE 10.
 */
[hidden] {
  display: none; }

@font-face {
  font-family: 'Graphik';
  src: url(/fonts/Graphik-Regular.woff) format("woff"), url(/fonts/Graphik-Regular.woff2) format("woff2");
  font-weight: 400;
  font-style: normal; }

@font-face {
  font-family: 'Graphik';
  src: url(/fonts/Graphik-Medium.woff) format("woff"), url(/fonts/Graphik-Medium.woff2) format("woff2");
  font-weight: 500;
  font-style: normal; }

* {
  box-sizing: border-box;
  font-family: "Graphik";
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale; }

:focus {
  outline: 0; }

.app-root {
  position: relative; }
  .app-root.rtl {
    direction: rtl; }
    .app-root.rtl * {
      direction: inherit; }
    .app-root.rtl .video-hero.homepage .subheading2 {
      text-align: right; }
    @media (min-width: 1150px) {
      .app-root.rtl .carousel .videos video {
        right: 10%;
        left: 0%; } }
    .app-root.rtl .home-hero .hero-content {
      right: 83px;
      left: 0; }
    .app-root.rtl .specs3-header .content {
      text-align: center; }
      @media (min-width: 1150px) {
        .app-root.rtl .specs3-header .content {
          text-align: right; } }
    @media (min-width: 1150px) {
      .app-root.rtl .specs3-slides .slide {
        text-align: right; } }
    .app-root.rtl .specs3-slides.mineral .art {
      direction: ltr; }
    .app-root.rtl .whats-inside {
      direction: ltr; }
      .app-root.rtl .whats-inside * {
        direction: rtl; }
      @media (min-width: 1150px) {
        .app-root.rtl .whats-inside .left {
          text-align: right; } }
      @media (min-width: 1150px) {
        .app-root.rtl .whats-inside .labels button .name {
          text-align: right; } }
    @media (min-width: 1150px) {
      .app-root.rtl .product-gallery {
        flex-direction: row-reverse; } }
    @media (min-width: 1150px) {
      .app-root.rtl .product-gallery.full-screen .copy {
        text-align: right; } }
    .app-root.rtl .product-image-box.main p {
      right: 40px;
      left: 0; }
    @media (min-width: 1150px) {
      .app-root.rtl .product-image-box.wide-2 .copy {
        text-align: right;
        margin-right: 40px; } }
    @media (min-width: 1150px) {
      .app-root.rtl .variant-picker .lenses p {
        text-align: right; } }
    @media (min-width: 1150px) {
      .app-root.rtl .creators-lens-studio .headline {
        text-align: right; } }
    @media (min-width: 1150px) {
      .app-root.rtl .creators-lens-studio .sub-heading {
        text-align: right; } }
    .app-root.rtl .creators-lens-studio .links a {
      margin: auto !important; }
      @media (min-width: 1150px) {
        .app-root.rtl .creators-lens-studio .links a {
          margin: 0 10px 0 0 !important; } }

main {
  position: relative;
  z-index: 2; }

.component-container {
  padding: 80px 20px;
  width: 100%; }
  @media (min-width: 720px) {
    .component-container {
      padding: 80px 40px; } }
  .component-container.center-text h1, .component-container.center-text h2, .component-container.center-text h3, .component-container.center-text p, .component-container.center-text span {
    text-align: center; }

h1, h2, h3, p {
  font-family: "Graphik";
  font-weight: 400;
  color: #000000; }

h1 {
  font-size: 48px; }
  @media (min-width: 720px) {
    h1 {
      font-size: 64px; } }

h2 {
  font-size: 32px; }
  @media (min-width: 720px) {
    h2 {
      font-size: 64px; } }

h3 {
  font-family: "Graphik";
  font-weight: 500;
  font-size: 16px; }

p {
  font-size: 16px;
  line-height: 24px;
  letter-spacing: .5; }
  @media (min-width: 720px) {
    p {
      font-size: 24px;
      line-height: 40px; } }

button,
[type="button"],
.button {
  font-family: "Graphik";
  font-weight: 400;
  border-radius: 36px;
  color: #000000;
  border: solid 1px #000000;
  background-color: transparent;
  background: transparent;
  box-shadow: none;
  display: inline-block;
  font-size: 12px;
  padding: 8px 20px;
  pointer: cursor;
  text-decoration: none;
  transition: all .25s ease; }
  button:hover,
  [type="button"]:hover,
  .button:hover {
    color: #000000;
    background-color: rgba(0, 0, 0, 0.1);
    border-color: #000000;
    cursor: pointer; }
  button.grow:hover,
  [type="button"].grow:hover,
  .button.grow:hover {
    margin-left: -2px;
    padding: 8px 22px; }
  button:focus, button:active,
  [type="button"]:focus,
  [type="button"]:active,
  .button:focus,
  .button:active {
    outline: none; }
  button.carbon, button.white,
  [type="button"].carbon,
  [type="button"].white,
  .button.carbon,
  .button.white {
    color: #000000;
    border-color: #ffffff;
    background-color: #ffffff; }
    button.carbon:hover, button.white:hover,
    [type="button"].carbon:hover,
    [type="button"].white:hover,
    .button.carbon:hover,
    .button.white:hover {
      color: #000000;
      background-color: rgba(255, 255, 255, 0.9); }
  button.mineral, button.black,
  [type="button"].mineral,
  [type="button"].black,
  .button.mineral,
  .button.black {
    color: #ffffff;
    border-color: #000000;
    background-color: #000000; }
    button.mineral:hover, button.black:hover,
    [type="button"].mineral:hover,
    [type="button"].black:hover,
    .button.mineral:hover,
    .button.black:hover {
      color: #ffffff;
      background-color: rgba(0, 0, 0, 0.8);
      border-color: rgba(0, 0, 0, 0.8); }
  button.ghost,
  [type="button"].ghost,
  .button.ghost {
    background-color: transparent; }
    button.ghost:hover,
    [type="button"].ghost:hover,
    .button.ghost:hover {
      color: #000000;
      background-color: rgba(0, 0, 0, 0.1);
      border-color: #000000;
      cursor: pointer; }
    button.ghost.mineral, button.ghost.black,
    [type="button"].ghost.mineral,
    [type="button"].ghost.black,
    .button.ghost.mineral,
    .button.ghost.black {
      color: #000000; }
      button.ghost.mineral:hover, button.ghost.black:hover,
      [type="button"].ghost.mineral:hover,
      [type="button"].ghost.black:hover,
      .button.ghost.mineral:hover,
      .button.ghost.black:hover {
        color: #000000;
        border-color: #000000;
        background-color: rgba(0, 0, 0, 0.1); }
    button.ghost.carbon, button.ghost.white,
    [type="button"].ghost.carbon,
    [type="button"].ghost.white,
    .button.ghost.carbon,
    .button.ghost.white {
      color: #ffffff; }
      button.ghost.carbon:hover, button.ghost.white:hover,
      [type="button"].ghost.carbon:hover,
      [type="button"].ghost.white:hover,
      .button.ghost.carbon:hover,
      .button.ghost.white:hover {
        color: #ffffff;
        border-color: #ffffff;
        background-color: rgba(255, 255, 255, 0.2); }
  button.yellow,
  [type="button"].yellow,
  .button.yellow {
    color: #000000;
    border-color: #fffc00;
    background-color: #fffc00; }
    button.yellow:hover,
    [type="button"].yellow:hover,
    .button.yellow:hover {
      border-color: #efe530;
      background-color: #efe530; }
  button.large,
  [type="button"].large,
  .button.large {
    font-size: 16px;
    font-weight: 500;
    letter-spacing: -0.2px;
    padding: 14px 56px; }
  button.basic,
  [type="button"].basic,
  .button.basic {
    background: transparent;
    border: none;
    padding: inherit;
    cursor: default; }
    button.basic:hover,
    [type="button"].basic:hover,
    .button.basic:hover {
      background: transparent; }
  button:disabled,
  [type="button"]:disabled,
  .button:disabled {
    opacity: .5; }

.home {
  background-color: #ffffff; }
  .home img {
    display: block;
    width: 100%; }

.learn {
  background-color: #ffffff; }
  .learn .videos {
    display: flex;
    flex-wrap: wrap;
    width: 100%; }

.compare {
  background-color: #ffffff;
  padding-top: 75px; }
  @media (min-width: 1150px) {
    .compare {
      padding-top: 95px; } }
  .compare img {
    max-width: 100%; }
  .compare .compare-overflow-box {
    overflow-y: scroll; }
    @supports (scroll-snap-align: center) {
      .compare .compare-overflow-box {
        -webkit-overflow-scrolling: touch;
        scroll-snap-type: x mandatory;
        overflow-y: scroll; } }
    @media (min-width: 1150px) {
      .compare .compare-overflow-box {
        overflow: visible; } }
  .compare .compare-title {
    font-size: 24px;
    padding: 40px 20px;
    border-bottom: 1px solid #EAEAEA;
    width: 100vw;
    position: sticky;
    left: 0;
    text-align: center; }
    @media (min-width: 1150px) {
      .compare .compare-title {
        font-size: 32px;
        width: 100%; } }
  .compare .compare-header, .compare .compare-row {
    display: flex;
    border-bottom: 1px solid #EAEAEA; }
  .compare .compare-header-product, .compare .compare-cell {
    width: 94vw;
    flex-basis: 94vw;
    flex-shrink: 0; }
    @media (min-width: 1150px) {
      .compare .compare-header-product, .compare .compare-cell {
        width: auto;
        flex-basis: 200px;
        flex-grow: 1; } }
    .compare .compare-header-product:first-child, .compare .compare-cell:first-child {
      scroll-snap-align: start;
      background-color: #F9F9F9; }
    .compare .compare-header-product:nth-child(2), .compare .compare-cell:nth-child(2) {
      scroll-snap-align: center;
      background-color: #F2F2F2; }
    .compare .compare-header-product:last-child, .compare .compare-cell:last-child {
      scroll-snap-align: end;
      background-color: #F9F9F9; }
  .compare .compare-header {
    transition: 450ms cubic-bezier(0.4, 0, 0.2, 1);
    position: sticky;
    top: 0;
    z-index: 3;
    transform: scale3d(1, 1, 1);
    will-change: transform; }
    .compare .compare-header.active .compare-header-product {
      padding: 125px 20px 25px !important; }
      .compare .compare-header.active .compare-header-product img {
        height: 55px !important;
        margin-bottom: 30px; }
      .compare .compare-header.active .compare-header-product .tagline {
        margin-bottom: 8px;
        text-align: left; }
      .compare .compare-header.active .compare-header-product .name {
        font-size: 23px !important;
        text-align: left; }
      .compare .compare-header.active .compare-header-product .price {
        font-size: 15px !important;
        margin-bottom: 0px;
        text-align: left; }
      .compare .compare-header.active .compare-header-product .button {
        position: absolute;
        bottom: 37px;
        right: 20px;
        padding: 8px 16px;
        font-size: 10px; }
  .compare .compare-header-product {
    transition: 450ms cubic-bezier(0.4, 0, 0.2, 1);
    text-align: center;
    padding: 130px 20px 55px;
    position: relative;
    text-align: center; }
    .compare .compare-header-product img {
      transition: 450ms cubic-bezier(0.4, 0, 0.2, 1);
      display: inline-block;
      margin: 0;
      margin-bottom: 40px;
      width: auto;
      height: 80px; }
      .compare .compare-header-product img:nth-of-type(2n) {
        display: none; }
        @media (min-width: 1150px) {
          .compare .compare-header-product img:nth-of-type(2n) {
            margin-left: 40px; } }
    .compare .compare-header-product p {
      margin: 0; }
    .compare .compare-header-product .tagline {
      transition: 450ms cubic-bezier(0.4, 0, 0.2, 1);
      font-size: 12px;
      margin-bottom: 16px;
      line-height: 12px; }
    .compare .compare-header-product .name {
      transition: 450ms cubic-bezier(0.4, 0, 0.2, 1);
      font-size: 32px;
      line-height: 1;
      margin-bottom: 10px; }
    .compare .compare-header-product .price {
      transition: 450ms cubic-bezier(0.4, 0, 0.2, 1);
      font-size: 22px;
      color: #9e9e9e;
      margin-bottom: 35px;
      line-height: 1.09; }
    .compare .compare-header-product .button {
      transition: 450ms cubic-bezier(0.4, 0, 0.2, 1); }
  .compare .compare-header.stuck .compare-header-product p, .compare .compare-header.stuck .compare-header-product a, .compare .compare-header.stuck .compare-header-product button {
    display: none; }
  .compare .compare-header.stuck .compare-header-product img {
    margin-bottom: 0; }
  .compare .section {
    width: 100%;
    min-width: max-content; }
  .compare .compare-cell {
    text-align: center;
    padding: 30px 20px;
    display: block;
    justify-content: center;
    align-items: center;
    white-space: pre-line;
    line-height: 1.5; }
    @media (min-width: 1150px) {
      .compare .compare-cell {
        padding: 40px 20px; } }
  .compare .color {
    width: 12px;
    height: 12px;
    display: inline-block;
    border-radius: 50%;
    margin-left: 0.5em; }
    .compare .color:first-of-type {
      margin-left: 1em; }
    .compare .color.carbon {
      background-color: #000000; }
    .compare .color.mineral {
      background-color: #D4996C; }
    .compare .color.black {
      background-color: #000; }
    .compare .color.onyx {
      background-color: #000000; }
    .compare .color.ruby {
      background-color: #FF4E4E; }
    .compare .color.sapphire {
      background-color: #163EFF; }
  .compare .gray {
    color: #9e9e9e; }

.accessory {
  background-color: #F4F4F4; }

.notfound-container {
  width: 100%;
  height: 100vh;
  background-color: #fffc00;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column; }

.shop {
  background-color: #ffffff; }
  @media (min-width: 720px) {
    .shop .desktop-2 {
      display: flex; } }
  @media (min-width: 720px) {
    .shop .desktop-2 .shop-accessory-product {
      width: 50%; } }

.spectacles-2 {
  background-color: #ffffff; }
  .spectacles-2 .images {
    display: flex;
    flex-wrap: wrap; }
  @media (min-width: 1150px) {
    .spectacles-2 .shared-specs-cta {
      margin-top: -92px;
      z-index: 5; } }

.spectacles-3 {
  background-color: #ffffff; }
  .spectacles-3 .buy-bar.mobile {
    display: flex; }
    @media (min-width: 1150px) {
      .spectacles-3 .buy-bar.mobile {
        display: none; } }
  .spectacles-3 .buy-bar.desktop {
    display: none; }
    @media (min-width: 1150px) {
      .spectacles-3 .buy-bar.desktop {
        display: flex; } }
  @media (min-width: 1150px) {
    .spectacles-3 .shared-specs-cta {
      margin-top: -92px;
      z-index: 5; } }

.terms {
  background-color: #ffffff; }
  .terms .textarticle-container {
    padding-top: 100px;
    max-width: 60em;
    margin: 0 auto; }

.setup {
  background-color: #ffffff;
  display: flex;
  flex-direction: column;
  margin-top: 10%; }
  @media (min-width: 1150px) {
    .setup {
      margin-top: 3%; } }
  .setup-headline {
    margin-top: 6%;
    text-align: center;
    width: 100%; }
  .setup-section {
    display: flex;
    flex-direction: column;
    text-align: center; }
    @media (min-width: 1150px) {
      .setup-section {
        align-items: center;
        flex-direction: row;
        justify-content: center;
        height: 83vh;
        margin: auto;
        padding: 0 75px;
        text-align: unset; } }
  .setup .step {
    font-family: Spectacles; }
    .setup .step-top {
      width: 100%; }
      @media (min-width: 1150px) {
        .setup .step-top {
          width: 31%; } }
    .setup .step-bottom {
      width: 100%; }
      .setup .step-bottom img {
        width: 100%; }
        @media (min-width: 1150px) {
          .setup .step-bottom img {
            width: 70%; } }
      @media (min-width: 1150px) {
        .setup .step-bottom {
          width: unset; } }
    .setup .step-copy {
      line-height: 27px;
      margin: auto; }

.creators {
  background-color: #ffffff; }
  .creators .cta-form {
    position: relative;
    z-index: 2; }
    @media (min-width: 720px) {
      .creators .cta-form {
        display: flex; }
        .creators .cta-form > * {
          flex-basis: 50%;
          flex-grow: 1; } }

.japan .m-0 {
  margin: 0 !important; }

.japan .p-0 {
  padding: 0 !important; }

.japan .d-flex {
  display: flex !important; }

@media (min-width: 320px) {
  .japan {
    margin-bottom: -800px;
    width: 100%; } }

@media (min-width: 720px) {
  .japan {
    margin-bottom: -424px; } }

.japan-hero {
  position: relative; }
  @media (min-width: 320px) {
    .japan-hero {
      background-image: url("https://storage.googleapis.com/spectacles-v3/6b5bcd7414cdddf3e35be5e76a62ac7e9ef89693/Homepage/module1/mobile/Homepage_Module1_mobile_CloudModelHero.jpg");
      background-repeat: no-repeat;
      background-size: cover;
      background-position: right center;
      height: 100vh;
      min-width: 100%;
      width: 100%; } }
  @media (min-width: 720px) {
    .japan-hero {
      background-image: url("https://storage.googleapis.com/spectacles-v3/6b5bcd7414cdddf3e35be5e76a62ac7e9ef89693/Homepage/module1/DT/Homepage_Module1_DT_CloudModelHero.jpg");
      background-repeat: no-repeat;
      background-size: cover;
      background-position: center center;
      height: 90vh;
      min-width: 100%;
      width: 100%; } }
  .japan-hero .logo {
    position: absolute;
    z-index: 2; }
    @media (min-width: 320px) {
      .japan-hero .logo {
        top: 15px;
        left: 15px;
        width: 80px;
        margin-top: 0; } }
    @media (min-width: 720px) {
      .japan-hero .logo {
        top: 20px;
        left: 40px;
        width: 85px;
        margin-top: 5px; } }
    .japan-hero .logo svg {
      width: 100%;
      fill: #ffffff; }
      @media (min-width: 1150px) {
        .japan-hero .logo svg {
          width: 120%; } }

.japan-specs {
  background: #ffffff; }
  @media (min-width: 320px) {
    .japan-specs {
      padding: 0 30px 30px 30px; } }
  @media (min-width: 720px) {
    .japan-specs {
      padding: 0 60px 100px 60px; } }
  @media (min-width: 1150px) {
    .japan-specs {
      padding: 0 150px 85px 150px; } }
  @media (min-width: 320px) {
    .japan-specs:first-child {
      padding-top: 30px; } }
  @media (min-width: 720px) {
    .japan-specs:first-child {
      padding-top: 100px; } }
  @media (min-width: 1150px) {
    .japan-specs:first-child {
      padding-top: 85px; } }
  .japan-specs img {
    display: block;
    max-width: 100%; }
    @media (min-width: 720px) {
      .japan-specs img {
        margin-top: 30px; } }
  .japan-specs h1 {
    color: #333333;
    font-size: 64px;
    font-family: 'Graphik';
    font-weight: bolder;
    margin-top: 0; }
    @media (min-width: 720px) {
      .japan-specs h1 {
        margin-bottom: 60px; } }
  .japan-specs h2 {
    color: #333333;
    font-size: 18px;
    font-family: 'Graphik';
    font-weight: 400;
    margin-top: 40px;
    padding-bottom: 6px;
    border-bottom: 1px solid #333333; }
    @media (min-width: 720px) {
      .japan-specs h2 {
        margin-bottom: 20px; } }
  .japan-specs h3 {
    color: #333333;
    font-weight: bolder;
    margin-bottom: 3px; }
  .japan-specs p {
    color: #333333;
    font-size: 18px;
    font-family: 'Graphik';
    font-weight: 400;
    margin-top: 0;
    line-height: 22px; }
  .japan-specs ul {
    margin: 0 0 0 20px;
    padding: 0;
    max-width: 80%; }
    .japan-specs ul.no-bullets {
      list-style-type: none;
      margin-bottom: 20px; }
    .japan-specs ul li {
      color: #333333;
      font-size: 18px;
      font-family: 'Graphik';
      font-weight: 400;
      margin-bottom: 0;
      line-height: 22px; }
  .japan-specs dl {
    font-size: 14px;
    color: #333333;
    font-family: 'Graphik';
    font-weight: 400;
    display: flex;
    margin-bottom: 0;
    margin-top: 10px; }
    @media (min-width: 320px) and (max-width: 719px) {
      .japan-specs dl {
        flex-direction: row; }
        .japan-specs dl dt, .japan-specs dl dd {
          flex-grow: 1;
          flex-basis: 100%;
          max-width: 50%;
          display: flex; } }
    .japan-specs dl dt {
      font-weight: bolder; }
      .japan-specs dl dt a {
        color: #333333;
        text-decoration: none;
        border-bottom: 1px solid transparent;
        padding-bottom: 3px; }
        .japan-specs dl dt a:hover {
          border-bottom-color: #333333; }
    .japan-specs dl dd {
      line-height: 22px; }
  .japan-specs-row {
    display: flex;
    width: 100%; }
    @media (min-width: 320px) {
      .japan-specs-row {
        margin-left: 0;
        margin-right: 0;
        flex-direction: column; } }
    @media (min-width: 720px) {
      .japan-specs-row {
        margin-left: 0px;
        margin-right: 0px;
        flex-direction: row; } }
    @media (min-width: 1150px) {
      .japan-specs-row {
        margin-left: -45px;
        margin-right: -45px;
        flex-direction: row; } }
    @media (min-width: 320px) {
      .japan-specs-row.flex-column-reverse {
        flex-direction: column-reverse; } }
    @media (min-width: 320px) {
      .japan-specs-row .col {
        padding: 15px; } }
    @media (min-width: 720px) {
      .japan-specs-row .col {
        padding: 30px; } }
    @media (min-width: 1150px) {
      .japan-specs-row .col {
        padding: 45px; } }
    .japan-specs-row .col.align-center {
      align-items: center; }
    .japan-specs-row .col.justify-content-between {
      justify-content: space-between; }
    .japan-specs-row .col .line {
      color: #333333;
      font-size: 16px;
      font-family: 'Graphik';
      font-weight: 400;
      position: relative; }
      @media (min-width: 720px) {
        .japan-specs-row .col .line {
          margin-top: 15px; } }
      .japan-specs-row .col .line:after {
        display: block;
        background: #333333;
        content: '';
        width: 1px;
        height: 35px;
        margin-top: 10px;
        margin-left: calc(50% - 1px); }
    .japan-specs-row .col .video-outer {
      max-width: 95%;
      width: 95%;
      height: 0;
      padding-top: 100%;
      border-radius: 50%;
      overflow: hidden;
      margin: 10px auto 30px auto;
      position: relative; }
      .japan-specs-row .col .video-outer video {
        width: 108%;
        position: absolute;
        top: -1%;
        left: -4%; }
    @media (min-width: 320px) and (max-width: 719px) {
      .japan-specs-row .col {
        flex: 1 0 100% !important;
        max-width: 100% !important; } }
    @media (min-width: 720px) {
      .japan-specs-row .col-3 {
        flex: 1 0 25%;
        max-width: 25%; }
      .japan-specs-row .col-4 {
        flex: 1 0 33.3333333%;
        max-width: 33.3333333%; }
      .japan-specs-row .col-6 {
        flex: 1 0 50%;
        max-width: 50%; }
      .japan-specs-row .col-8 {
        flex: 1 0 66.6666666%;
        max-width: 66.6666666%; }
      .japan-specs-row .col-9 {
        flex: 1 0 75%;
        max-width: 75%; }
      .japan-specs-row .col-12 {
        flex: 1 0 100%;
        max-width: 100%; } }

.header {
  transition: color 300ms cubic-bezier(0.4, 0, 0.2, 1);
  background-color: RGBA(0, 0, 0, var(--background-opacity));
  padding: 20px;
  z-index: 10;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%; }
  .header:before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    width: 100%;
    height: 100%;
    background-image: linear-gradient(0, transparent 0%, rgba(0, 0, 0, 0.3) 100%);
    z-index: 1; }
  @media (min-width: 720px) {
    .header {
      padding: 7px 40px;
      width: 100%; } }
  .header .header-content {
    position: relative;
    display: flex;
    justify-content: space-between;
    align-items: center;
    z-index: 2; }
  .header .logo {
    width: 85px;
    margin-top: 5px; }
    .header .logo svg {
      width: 100%; }
      @media (min-width: 1150px) {
        .header .logo svg {
          width: 120%; } }
      .header .logo svg .logo-fill {
        transition: all .25s ease; }
  .header ul {
    list-style-type: none;
    margin: 0;
    padding: 0; }
  .header .subnav {
    flex-grow: 1;
    margin-left: 40px;
    margin-right: 40px;
    display: none; }
    @media (min-width: 1150px) {
      .header .subnav {
        display: block; } }
    .header .subnav a {
      color: currentColor;
      text-decoration: none;
      opacity: 0.5;
      padding-left: 20px;
      padding-right: 20px; }
      .header .subnav a:hover, .header .subnav a.active {
        opacity: 1; }
  .header .main-nav-ul {
    display: flex;
    align-items: center; }
  .header .menu-item {
    font-size: 12px;
    padding-left: 20px;
    padding-right: 20px;
    opacity: 0.5; }
    .header .menu-item:hover {
      opacity: 1; }
    .header .menu-item.active {
      opacity: 1; }
  .header .desktop-menu-item {
    transition: all .25s ease;
    color: #000000;
    display: none;
    font-size: 16px;
    padding: 10px 20px;
    text-decoration: none; }
    @media (min-width: 720px) {
      .header .desktop-menu-item {
        display: block; } }
  .header .cta {
    padding: 10px 20px; }
    @media (min-width: 720px) {
      .header .cta {
        font-size: 12px;
        margin-left: 20px;
        padding: 10px 25px; } }
  @media (min-width: 720px) {
    .header .mobile-menu-trigger {
      display: none; } }
  .header.white-content .menu-item, .header.scrolled .menu-item {
    color: #ffffff; }
  .header.white-content .cta, .header.scrolled .cta {
    border-color: #ffffff;
    color: #ffffff; }
  .header.white-content .logo-fill, .header.scrolled .logo-fill {
    fill: #ffffff; }
  .header.white-content .cart-icon-svg, .header.white-content .cart-icon-svg *, .header.scrolled .cart-icon-svg, .header.scrolled .cart-icon-svg * {
    stroke: #ffffff; }
  .header.white-content .subnav a, .header.scrolled .subnav a {
    color: #ffffff; }

.mobile-menu {
  background-color: #fffc00;
  height: 0;
  left: 0;
  opacity: 0;
  overflow: hidden;
  overflow-y: auto;
  position: fixed;
  top: 0;
  transition: opacity 300ms cubic-bezier(0.4, 0, 0.2, 1);
  width: 100%;
  z-index: 1;
  pointer-events: none;
  display: flex;
  flex-direction: column; }
  .mobile-menu.active {
    height: 100%;
    opacity: 1;
    pointer-events: all;
    width: 100%;
    z-index: 10; }
  .mobile-menu .mobile-menu-header {
    border-bottom: solid 1px #efe530;
    display: flex;
    justify-content: space-between;
    padding: 13px 20px; }
    .mobile-menu .mobile-menu-header .mobile-logo {
      display: block;
      width: 32px; }
    .mobile-menu .mobile-menu-header .close {
      border: none; }
  .mobile-menu .mobile-menu-main-nav {
    flex-grow: 1; }
    .mobile-menu .mobile-menu-main-nav ul {
      height: 100%;
      display: flex;
      flex-direction: column; }
    .mobile-menu .mobile-menu-main-nav li {
      flex-grow: 1; }
  .mobile-menu .mobile-menu-item {
    border-bottom: solid 1px #efe530;
    display: flex;
    align-items: center;
    text-align: center; }
    .mobile-menu .mobile-menu-item a {
      color: #000000;
      display: block;
      font-size: 40px;
      padding: 80px 20px;
      text-decoration: none;
      transition: background-color .25s ease;
      width: 100%; }
      .mobile-menu .mobile-menu-item a.active {
        text-decoration: underline; }
      .mobile-menu .mobile-menu-item a:hover {
        background-color: #efe530; }
  .mobile-menu .mobile-menu-footer ul {
    overflow-y: scroll;
    white-space: nowrap;
    overflow-x: auto; }
    @supports (scroll-snap-align: center) {
      .mobile-menu .mobile-menu-footer ul {
        -webkit-overflow-scrolling: touch;
        scroll-snap-type: x mandatory;
        overflow-y: scroll; } }
    .mobile-menu .mobile-menu-footer ul li {
      display: inline-block; }
  .mobile-menu .mobile-menu-footer .mobile-footer-menu-item {
    scroll-snap-align: center; }
    .mobile-menu .mobile-menu-footer .mobile-footer-menu-item a {
      color: #000000;
      display: block;
      font-size: 12px;
      padding: 40px 20px;
      text-decoration: none;
      transition: all .25s ease; }
      .mobile-menu .mobile-menu-footer .mobile-footer-menu-item a:hover {
        background-color: #efe530; }

@media (min-width: 720px) {
  body {
    padding-bottom: 424px; } }

@media (min-width: 1150px) {
  body {
    padding-bottom: 369px; } }

footer.footer {
  width: 100%;
  z-index: 1;
  bottom: 0;
  left: 0;
  height: 800px; }
  footer.footer.disabled {
    visibility: hidden; }
  @media (min-width: 720px) {
    footer.footer {
      position: fixed; } }
  footer.footer.language-select-open {
    z-index: 5; }
  @media (min-width: 720px) {
    footer.footer {
      height: 424px; } }
  @media (min-width: 1150px) {
    footer.footer {
      height: 369px; } }
  footer.footer a {
    color: inherit;
    text-decoration: none;
    transition: color .25s ease; }
  footer.footer ul {
    list-style: none;
    padding: 0; }
  footer.footer .nav,
  footer.footer .copyright,
  footer.footer .social-language {
    padding: 30px; }
  footer.footer .nav {
    background-color: #000000;
    color: #ffffff;
    padding-bottom: 20px; }
    footer.footer .nav .logo {
      margin-bottom: 20px;
      width: 110px; }
    footer.footer .nav nav.main {
      font-size: 18px; }
      footer.footer .nav nav.main li {
        margin-bottom: 28px; }
      @media (min-width: 720px) {
        footer.footer .nav nav.main {
          font-size: 24px;
          line-height: 2; }
          footer.footer .nav nav.main li {
            margin-bottom: 0; } }
    footer.footer .nav nav.secondary {
      color: #9e9e9e;
      font-size: 14px; }
      footer.footer .nav nav.secondary li {
        margin-bottom: 18px; }
      footer.footer .nav nav.secondary li:first-child {
        color: #ffffff;
        font-size: 18px;
        margin-bottom: 32px; }
        @media (min-width: 720px) {
          footer.footer .nav nav.secondary li:first-child {
            font-size: 24px;
            line-height: 2; } }
  footer.footer .bottom-bar {
    position: relative;
    z-index: 1; }
    @media (min-width: 1150px) {
      footer.footer .bottom-bar {
        display: flex; } }
  footer.footer .copyright {
    font-size: 12px;
    letter-spacing: -0.15px;
    color: #999999;
    z-index: 10;
    background-color: #ffffff;
    padding-top: 26px;
    padding-bottom: 17px; }
    @media (min-width: 720px) {
      footer.footer .copyright {
        padding: 11px 40px; } }
    footer.footer .copyright small {
      font-size: 12px; }
    footer.footer .copyright small, footer.footer .copyright li {
      margin-bottom: 14px; }
    footer.footer .copyright nav.tertiary {
      margin-bottom: 60px; }
  footer.footer .social-language {
    align-items: center;
    background-color: #fffc00;
    display: flex;
    justify-content: space-between;
    position: relative;
    z-index: 10;
    padding: 15px 30px; }
    @media (min-width: 720px) {
      footer.footer .social-language {
        padding: 11px 40px; } }
    footer.footer .social-language nav.social li {
      display: inline-block;
      vertical-align: middle;
      margin-left: 14px; }
    footer.footer .social-language .language-select-toggle {
      border: none; }
      footer.footer .social-language .language-select-toggle::after {
        content: '\2304';
        font-size: 16px;
        transform: scaleX(1.5);
        display: inline-block;
        left: 7px;
        top: -3px;
        position: relative; }
      footer.footer .social-language .language-select-toggle img {
        width: 20px;
        height: 20px;
        border-radius: 50%;
        object-fit: cover;
        object-position: center center;
        vertical-align: -5px;
        margin-right: 5px;
        border: 1px solid #000000; }
  @media (min-width: 720px) {
    footer.footer .nav {
      align-items: flex-start;
      display: flex;
      padding-top: 34px;
      padding-right: 88px;
      padding-bottom: 44px;
      padding-left: 38px; }
      footer.footer .nav .logo-container {
        flex-grow: 1; }
      footer.footer .nav .logo {
        width: 140px; }
      footer.footer .nav nav {
        flex-basis: 178px; }
      footer.footer .nav ul {
        margin: 0; }
      footer.footer .nav nav.secondary li:first-child {
        margin-bottom: 0; }
    footer.footer .copyright {
      align-items: center;
      display: flex;
      flex-grow: 1; }
      footer.footer .copyright small {
        margin-bottom: 0; }
      footer.footer .copyright nav.tertiary {
        margin-bottom: 0; }
      footer.footer .copyright ul {
        align-items: center;
        display: flex;
        flex-wrap: wrap;
        margin-left: -10px;
        margin: 0; }
      footer.footer .copyright li {
        display: inline-block;
        flex-shrink: 0;
        margin: 10px; }
    footer.footer .social-language {
      flex-shrink: 0;
      flex-basis: 484px; } }
  footer.footer nav.secondary a:hover {
    color: #ffffff; }
  footer.footer nav.tertiary a:hover {
    color: #000000; }

.language-selector {
  background-color: #ffffff;
  bottom: -100px;
  left: 0;
  padding: 20px;
  transform: translateY(100%);
  transition: all 300ms cubic-bezier(0.4, 0, 0.2, 1);
  width: 100%;
  z-index: 5;
  position: absolute;
  display: none; }
  @media (min-width: 720px) {
    .language-selector {
      display: block;
      position: fixed; } }
  .language-selector.active {
    transform: translateY(0%);
    bottom: 110px;
    display: block; }
    @media (min-width: 1150px) {
      .language-selector.active {
        bottom: 73px; } }
  .language-selector .languages {
    list-style-type: none; }
    @media (min-width: 720px) {
      .language-selector .languages {
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
        grid-gap: 20px;
        margin: 0;
        padding: 28px 40px; } }
  .language-selector .language a {
    padding: 12px 12px 12px 0; }
  .language-selector a {
    align-items: center;
    display: flex;
    font-weight: 500;
    color: #000000;
    text-decoration: none; }
    .language-selector a:hover {
      color: rgba(0, 0, 0, 0.5); }
  .language-selector img {
    border-radius: 50%;
    border: 1px solid #9e9e9e;
    height: 40px;
    margin-right: 16px;
    object-fit: cover;
    object-position: center center;
    width: 40px; }

.scroll-container {
  position: relative; }
  .scroll-container ::-webkit-scrollbar,
  .scroll-container *::-webkit-scrollbar {
    display: none;
    appearance: none; }

.scroll-box {
  overflow: -moz-scrollbars-none;
  -ms-overflow-style: none;
  margin-bottom: -25px;
  padding-bottom: 25px; }

.scroll-box::-webkit-scrollbar {
  height: 0 !important;
  width: 0 !important;
  display: none; }

.scroll-box::-webkit-scrollbar-track {
  background-color: transparent; }

.scroll-box::-webkit-scrollbar {
  background-color: transparent; }

.scroll-box::-webkit-scrollbar-thumb {
  background-color: transparent; }

.scroll-bar {
  height: 2px;
  width: 100%;
  background-color: #e5e5e5;
  transform: scaleX(0.75);
  position: relative;
  overflow: visible; }

.scroll-handle {
  height: 2px;
  background-color: #000000;
  position: absolute; }

.scroll-container.yellow .scroll-bar {
  background-color: rgba(71, 71, 71, 0.28); }

.scroll-container.yellow .scroll-handle {
  background-color: #fffc00; }

.scroll-container.small .scroll-bar {
  transform: scaleX(0.458); }

.color-selector {
  display: flex;
  justify-content: center;
  width: 100%;
  margin-top: 15px; }
  .color-selector.left-aligned {
    justify-content: flex-start; }
  .color-selector .color-name {
    color: #1e1e1e;
    font-size: 16px;
    text-transform: capitalize;
    transition: all .15s ease; }
  .color-selector .active .color-name {
    color: #000000; }
  .color-selector .carbon .color-dot {
    border-color: #666660; }
  .color-selector .carbon .color-dot-inner {
    background-color: #000000; }
  .color-selector .mineral .color-dot {
    border-color: #ffd8a6; }
  .color-selector .mineral .color-dot-inner {
    background-color: #edc086; }
  .color-selector .color-dot-wrapper {
    height: 16px;
    position: relative;
    width: 16px;
    margin-right: 10px; }
  .color-selector .color-dot {
    align-items: center;
    border-radius: 60px;
    border-style: solid;
    border-width: 0;
    display: flex;
    height: 16px;
    justify-content: center;
    left: 50%;
    position: absolute;
    top: 50%;
    transform: translate(-50%, -50%);
    width: 16px; }
  .color-selector .color-dot-inner {
    border-radius: 16px;
    display: block;
    height: 8px;
    width: 8px; }
  .color-selector .button {
    align-items: center;
    border: none;
    display: flex; }
    .color-selector .button:hover .color-dot {
      border-width: 1px;
      height: 20px;
      width: 20px; }
    .color-selector .button:hover .color-name {
      color: #000000; }
    .color-selector .button + .button {
      margin-left: 20px; }
  .color-selector .active .color-dot {
    border-width: 1px; }
  .color-selector.white .color-name {
    color: #5e5e5e; }
  .color-selector.white .active .color-name {
    color: #ffffff; }
  .color-selector.white .button:hover .color-name {
    color: #ffffff; }
  .color-selector.on-light.white .active .color-name {
    color: #000000; }
  .color-selector.on-light.white .button:hover .color-name {
    color: #000000; }

.product-gallery {
  width: 100%;
  height: 100%;
  position: relative;
  display: flex;
  flex-direction: column;
  text-align: center;
  align-items: center; }
  @media (min-width: 1150px) {
    .product-gallery {
      width: 100vw;
      min-height: 720px;
      height: 56vw;
      max-height: 86vh; } }
  .product-gallery .images {
    width: 100%;
    position: relative;
    flex-grow: 1;
    margin-bottom: 32px;
    height: 45vh;
    overflow: hidden; }
    @media (min-width: 1150px) {
      .product-gallery .images {
        height: auto; } }
    .product-gallery .images img {
      position: absolute;
      left: 0;
      top: 0;
      width: 100%;
      height: 100%;
      object-fit: cover;
      object-position: bottom center;
      user-select: none;
      pointer-events: none;
      opacity: 0;
      transition: opacity 300ms cubic-bezier(0.4, 0, 0.2, 1); }
      @media (min-width: 320px) {
        .product-gallery .images img {
          object-position: center center;
          width: unset;
          top: 7%;
          left: -2%; } }
      @media (min-width: 1150px) {
        .product-gallery .images img {
          object-fit: contain;
          width: 80%; }
          .product-gallery .images img.spectacles-nico, .product-gallery .images img.spectacles-veronica {
            width: 86%; } }
      .product-gallery .images img.active {
        opacity: 1; }
  .product-gallery .copy p {
    margin: 0; }
  .product-gallery .copy .name {
    font-size: 32px;
    margin-bottom: 8px; }
    @media (min-width: 1150px) {
      .product-gallery .copy .name {
        font-size: 32px; } }
  .product-gallery .copy .subname {
    font-size: 20px;
    margin-bottom: 8px; }
    @media (min-width: 1150px) {
      .product-gallery .copy .subname {
        font-size: 20px; } }
  .product-gallery .copy .spectacles-nav {
    width: 100%;
    margin-bottom: 20px; }
    .product-gallery .copy .spectacles-nav > * {
      display: inline-block;
      text-decoration: none;
      margin-left: 20px; }
      .product-gallery .copy .spectacles-nav > *.active {
        text-decoration: underline; }
  .product-gallery .copy .price {
    font-size: 24px;
    color: #9e9e9e;
    margin-bottom: 30px; }
    @media (min-width: 1150px) {
      .product-gallery .copy .price {
        font-size: 20px;
        margin-bottom: 10px; } }
  .product-gallery .copy .ATP {
    font-size: 12px;
    color: #9e9e9e; }
    @media (min-width: 1150px) {
      .product-gallery .copy .ATP {
        font-size: 12px; } }
  .product-gallery .copy .prescription {
    display: inline-flex;
    font-size: 12px;
    color: #9e9e9e; }
    @media (min-width: 1150px) {
      .product-gallery .copy .prescription {
        display: flex;
        font-size: 12px;
        line-height: 10px; } }
  .product-gallery .copy .description {
    color: #9e9e9e;
    font-size: 14px;
    margin: 0 30px 20px;
    line-height: 1.5;
    white-space: pre-line; }
    .product-gallery .copy .description.full {
      display: none; }
    @media (min-width: 1150px) {
      .product-gallery .copy .description {
        font-size: 16px;
        margin: 0;
        margin-bottom: 20px; } }
    .product-gallery .copy .description .line {
      color: #9e9e9e;
      font-size: 14px;
      line-height: 1.5;
      white-space: pre-line; }
      .product-gallery .copy .description .line.full {
        display: none; }
      @media (min-width: 1150px) {
        .product-gallery .copy .description .line {
          font-size: 14px;
          margin: 0; } }
  .product-gallery .copy button {
    margin-bottom: 20px; }
  .product-gallery .copy .byline {
    font-size: 12px;
    color: #9e9e9e;
    margin-bottom: 6px; }
  .product-gallery .copy a {
    display: block;
    color: #000000;
    font-size: 12px; }
  .product-gallery .bullets {
    margin: 34px auto; }
    .product-gallery .bullets span {
      padding: 10px;
      opacity: 0.15;
      cursor: pointer; }
      .product-gallery .bullets span::before {
        content: '';
        display: block;
        width: 7px;
        height: 7px;
        display: inline-block;
        background-color: #000000;
        border-radius: 50%; }
      .product-gallery .bullets span.active {
        opacity: 1; }
      .product-gallery .bullets span + span {
        margin-left: 5px; }
  .product-gallery .color-selector {
    justify-content: center; }
    @media (min-width: 1150px) {
      .product-gallery .color-selector {
        justify-content: flex-start; } }
  @media (min-width: 1150px) {
    .product-gallery {
      flex-direction: row;
      padding-right: 50px; }
      .product-gallery .images {
        height: 100%;
        margin-bottom: 0;
        margin-right: 100px; }
        .product-gallery .images img {
          object-position: left center;
          object-fit: cover; }
      .product-gallery .copy {
        text-align: left;
        flex-basis: 388px;
        flex-shrink: 0; }
        .product-gallery .copy .description {
          margin-bottom: 20px; }
          .product-gallery .copy .description.excerpt {
            display: none; }
          .product-gallery .copy .description.full {
            display: block; }
        .product-gallery .copy .meta {
          position: absolute;
          bottom: 30px; }
      .product-gallery .bullets {
        position: absolute;
        bottom: 25px;
        left: 50px;
        margin: 0; } }
  @media (min-width: 1150px) {
    .product-gallery.full-screen::before {
      content: "";
      display: block;
      flex-grow: 1; }
    .product-gallery.full-screen .images {
      position: absolute;
      left: 0;
      top: 0;
      width: 100%;
      height: 100%; }
      .product-gallery.full-screen .images img {
        object-fit: contain; }
    .product-gallery.full-screen .copy {
      z-index: 5;
      position: relative;
      align-self: center; }
      .product-gallery.full-screen .copy .meta {
        position: relative; } }

.details {
  border-top: 1px solid #e5e5e5;
  border-bottom: 1px solid #e5e5e5; }
  .details + .details {
    border-top: 0; }
  .details summary {
    font-size: 24px;
    padding: 28px 15px;
    display: block;
    cursor: pointer;
    list-style-type: none; }
    @media (min-width: 720px) {
      .details summary {
        padding: 70px 48px;
        font-size: 32px; } }
    .details summary::-webkit-details-marker {
      display: none; }
    .details summary::after {
      content: '\25BC';
      float: right;
      font-size: 12px;
      vertical-align: -10px;
      display: inline-block;
      top: 9px;
      position: relative;
      transform: rotate(0deg);
      transform-origin: 50% 30%;
      transition: all 300ms cubic-bezier(0.4, 0, 0.2, 1); }
      @media (min-width: 720px) {
        .details summary::after {
          top: 20px; } }
  .details[open] summary::after {
    transform: rotate(180deg); }

.tech-specs {
  padding: 0 15px 30px; }
  @media (min-width: 720px) {
    .tech-specs {
      padding: 28px 48px 108px; } }
  .tech-specs dl {
    display: grid;
    grid-gap: 50px;
    justify-content: space-between; }
    @media (min-width: 720px) {
      .tech-specs dl {
        grid-gap: 84px 110px;
        grid-template-columns: repeat(auto-fill, minmax(520px, 1fr)); } }
  .tech-specs .section {
    display: flex;
    line-height: 1.2;
    flex-wrap: wrap; }
    .tech-specs .section dt {
      flex-basis: 220px;
      flex-shrink: 0; }
      @media (min-width: 720px) {
        .tech-specs .section dt {
          flex-basis: 141px; } }
    .tech-specs .section dt + .dds {
      margin-top: 20px; }
      @media (min-width: 440px) {
        .tech-specs .section dt + .dds {
          margin-top: 0; } }
    .tech-specs .section .dds {
      flex-grow: 1;
      flex-basis: 220px;
      color: #9e9e9e; }
      .tech-specs .section .dds dd {
        margin: 0; }
      .tech-specs .section .dds dd + dd {
        margin-top: 20px; }

.faq-section {
  padding: 0 15px 30px; }
  @media (min-width: 720px) {
    .faq-section {
      padding: 28px 48px 108px; } }
  .faq-section .faq {
    grid-gap: 50px; }
    @media (min-width: 720px) {
      .faq-section .faq {
        display: grid;
        grid-template-columns: repeat(auto-fill, minmax(520px, 1fr));
        justify-content: space-between;
        grid-gap: 84px 110px; } }
    .faq-section .faq a {
      color: currentColor; }
  .faq-section .question {
    margin-bottom: 1em; }
  .faq-section .answer {
    color: #9e9e9e;
    margin: 0;
    margin-bottom: 2em;
    max-width: 35em; }

.store-locator {
  background-color: #ffffff;
  display: flex;
  flex-direction: column;
  height: 100%;
  overflow-y: auto;
  pointer-events: none;
  position: fixed;
  right: -500px;
  top: 0;
  transition: all 300ms cubic-bezier(0.4, 0, 0.2, 1);
  z-index: 100;
  width: 100%; }
  .store-locator ul {
    padding: 0;
    list-style: none;
    margin-top: 60px; }
  @media (min-width: 720px) {
    .store-locator {
      width: 400px; } }
  .store-locator.active {
    opacity: 1;
    pointer-events: all;
    right: 0;
    width: 100%;
    z-index: 10; }
    @media (min-width: 720px) {
      .store-locator.active {
        width: 400px; } }
  .store-locator .store-locator-content {
    padding: 28px;
    max-width: 100%; }
    .store-locator .store-locator-content h1 {
      font-size: 32px;
      margin: 0 0 20px; }
    .store-locator .store-locator-content .state-city-or-region {
      font-size: 20px;
      margin: 26px 0; }
    @media (min-width: 720px) {
      .store-locator .store-locator-content {
        width: 400px;
        max-width: unset; } }
  .store-locator header {
    display: flex;
    justify-content: flex-end;
    max-width: 100%; }
    .store-locator header .close {
      padding: 20px; }
    @media (min-width: 720px) {
      .store-locator header {
        max-width: unset; } }

.store-item {
  padding: 0 0 20px; }
  .store-item .brand,
  .store-item .address,
  .store-item .city-state,
  .store-item .postal {
    color: #9e9e9e;
    font-size: 16px;
    font-style: normal;
    line-height: 26px; }
  .store-item .brand {
    color: #000000; }

.dropdown {
  position: relative;
  margin: 0 auto;
  width: 100%; }
  .dropdown .dropdown-content {
    display: flex;
    justify-content: space-between;
    align-items: center;
    border: 1px solid #9e9e9e;
    padding-left: 20px;
    border-radius: 6px;
    width: 100%; }
  .dropdown .dropdown-trigger {
    align-items: center;
    display: flex;
    height: 47px;
    position: relative;
    justify-content: center;
    padding: 0;
    width: 47px; }
    .dropdown .dropdown-trigger .pointer {
      transition: all .15s ease; }
    .dropdown .dropdown-trigger .spacer {
      height: 30px;
      background: #9e9e9e;
      width: 1px;
      position: absolute;
      left: 0; }
  .dropdown .selected-item {
    font-size: 16px;
    color: #9e9e9e; }
  .dropdown .menu {
    background-color: #ffffff;
    border-radius: 6px;
    border: 1px solid #9e9e9e;
    bottom: -144px;
    display: none;
    left: 0;
    list-style-type: none;
    margin: 0;
    padding: 0;
    position: absolute;
    width: 100%; }
  .dropdown .dropdown-li {
    border-bottom: 1px solid #9e9e9e; }
    .dropdown .dropdown-li:last-of-type {
      border-bottom: none; }
  .dropdown .dropdown-button {
    font-size: 16px;
    height: 47px;
    border: none;
    color: #9e9e9e;
    border-radius: 0;
    width: 100%; }
    .dropdown .dropdown-button:hover {
      background-color: rgba(158, 158, 158, 0.2);
      color: #000000; }
  .dropdown.active .menu {
    display: block; }
  .dropdown.active .pointer {
    transform: rotate(180deg); }

.cart-icon {
  position: relative; }
  .cart-icon::before {
    content: '';
    display: block;
    width: 8px;
    height: 8px;
    background-color: #fffc00;
    border-radius: 50%;
    position: absolute;
    top: -1px;
    right: 8px; }
  .cart-icon .cart-icon-svg .cart-icon-stroke {
    stroke: #000000; }

.video-hero {
  position: relative;
  width: 100vw;
  height: 86vh;
  display: flex;
  justify-content: flex-end;
  flex-direction: column;
  align-items: center;
  padding-bottom: 30px; }
  @media (min-width: 1150px) {
    .video-hero {
      padding-bottom: 110px; } }
  .video-hero::before {
    content: "";
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    background-color: #000000;
    opacity: var(--overlay-opacity);
    pointer-events: none;
    z-index: 2;
    will-change: opacity; }
  .video-hero .video-background {
    z-index: 1; }
  .video-hero .headline, .video-hero .subheading, .video-hero .play-button, .video-hero .cta, .video-hero .subheading2 {
    z-index: 2;
    position: relative;
    color: #ffffff;
    margin: 0; }
  .video-hero .headline {
    font-size: 40px;
    letter-spacing: 0.33px;
    line-height: 48px;
    margin-bottom: 13px;
    white-space: pre-line;
    text-align: center; }
    @media (min-width: 1150px) {
      .video-hero .headline {
        font-size: 52px;
        line-height: 64px;
        letter-spacing: -1.78px; } }
  .video-hero .subheading {
    font-size: 16px;
    line-height: 24px;
    letter-spacing: 0.13px;
    max-width: 320px;
    text-align: center;
    margin-bottom: 28px; }
    @media (min-width: 1150px) {
      .video-hero .subheading {
        font-size: 24px;
        line-height: 32px;
        letter-spacing: -0.67px;
        max-width: 681px; } }
  .video-hero .subheading2 {
    font-size: 12px;
    line-height: 24px;
    letter-spacing: 0.13px;
    max-width: 320px;
    text-align: center; }
    @media (min-width: 1150px) {
      .video-hero .subheading2 {
        font-size: 22px;
        line-height: 32px;
        letter-spacing: -0.67px;
        max-width: 681px; } }
  .video-hero .play-button .play, .video-hero .play-button .label {
    display: block;
    text-align: center;
    margin: 0 auto; }
  .video-hero .play-button .play {
    padding: 0;
    border-radius: 50%;
    width: 60px;
    height: 60px;
    display: flex;
    justify-content: center;
    align-items: center;
    margin-bottom: 20px; }
  .video-hero .play-button .label {
    font-size: 12px;
    letter-spacing: -0.15px; }
  .video-hero.homepage {
    padding-left: 33px;
    padding-right: 33px;
    padding-bottom: 33px;
    align-items: flex-start;
    text-align: left; }
    @media (min-width: 1150px) {
      .video-hero.homepage {
        padding-bottom: 11vh;
        padding-left: 83px;
        padding-right: 83px; } }
    .video-hero.homepage .headline {
      font-size: 32px;
      letter-spacing: -0.89px;
      line-height: 40px;
      text-align: left; }
      @media (min-width: 1150px) {
        .video-hero.homepage .headline {
          font-size: 52px;
          line-height: 64px;
          letter-spacing: 0.5px; } }
    .video-hero.homepage .headline .video-hero {
      font-size: 80px; }
    .video-hero.homepage .subheading {
      line-height: 24px;
      letter-spacing: 0.5px;
      font-size: 16px;
      text-align: left; }
      @media (min-width: 1150px) {
        .video-hero.homepage .subheading {
          font-size: 24px;
          line-height: 36px;
          letter-spacing: -0.67px; } }
    .video-hero.homepage .subheading2 {
      line-height: 24px;
      letter-spacing: 0.5px;
      font-size: 13px;
      text-align: left; }
      @media (min-width: 1150px) {
        .video-hero.homepage .subheading2 {
          font-size: 18px;
          line-height: 30px;
          letter-spacing: -0.67px; } }
    .video-hero.homepage .play-button {
      display: flex;
      align-items: center;
      position: absolute;
      right: 33px;
      bottom: 33px; }
      .video-hero.homepage .play-button.playing {
        display: none !important; }
      @media (min-width: 1150px) {
        .video-hero.homepage .play-button {
          right: auto;
          position: fixed;
          bottom: auto;
          display: none; }
          .video-hero.homepage .play-button > * {
            flex-shrink: 0; } }
      .video-hero.homepage .play-button .play {
        margin: 0;
        margin-right: 10px;
        width: 40px;
        height: 40px; }
        @media (min-width: 1150px) {
          .video-hero.homepage .play-button .play {
            width: 60px;
            height: 60px; }
            .video-hero.homepage .play-button .play:hover {
              cursor: none;
              background-color: transparent; } }
    .video-hero.homepage:hover .play-button {
      display: flex; }
    .video-hero.homepage .cta {
      z-index: 3; }
      .video-hero.homepage .cta:hover + .play-button {
        display: none; }
  @media (min-width: 1150px) {
    .video-hero.learnpage {
      padding-bottom: 0;
      padding-left: 55%;
      padding-right: 15px;
      align-items: start; } }
  .video-hero.learnpage .headline {
    font-size: 25px;
    line-height: 30px; }
    @media (min-width: 1150px) {
      .video-hero.learnpage .headline {
        font-size: 52px;
        line-height: 64px;
        letter-spacing: -1.78px;
        width: 100%;
        text-align: left;
        max-width: 550px; } }
  @media (min-width: 1150px) {
    .video-hero.learnpage .subheading {
      text-align: left;
      max-width: 550px; } }
  @media (min-width: 1150px) {
    .video-hero.learnpage .subheading2 {
      text-align: left; } }
  .video-hero.learnpage .play-button {
    display: flex;
    align-items: baseline; }
    @media (min-width: 1150px) {
      .video-hero.learnpage .play-button {
        margin-bottom: 140px; } }
    .video-hero.learnpage .play-button .label {
      margin-left: 20px; }

.stagger {
  opacity: 0;
  transform: translateY(40px);
  transition: 800ms cubic-bezier(0.4, 0, 0.2, 1);
  transition-property: transform, opacity;
  filter: brightness(50%); }
  .stagger.active {
    opacity: 1;
    transform: translateY(0px);
    filter: brightness(60%); }
  .stagger:hover {
    filter: brightness(100%); }

.shared-specs-cta {
  position: relative; }
  .shared-specs-cta .bar {
    background-color: #fffc00;
    padding: 10px 30px; }
    .shared-specs-cta .bar p {
      margin: 0;
      font-size: 12px;
      letter-spacing: -0.1px;
      line-height: 32px;
      white-space: pre-line; }
      @media (min-width: 1150px) {
        .shared-specs-cta .bar p {
          white-space: normal;
          font-size: 16px; } }
  .shared-specs-cta .glide__slides {
    margin: 0; }
  .shared-specs-cta .glide__slide {
    width: 100vw;
    height: 86vh;
    position: relative; }
    @media (min-width: 1150px) {
      .shared-specs-cta .glide__slide {
        height: 56vw; } }
    .shared-specs-cta .glide__slide .content {
      padding: 44px 30px;
      position: relative;
      z-index: 2;
      width: 100%;
      height: 100%; }
      @media (min-width: 1150px) {
        .shared-specs-cta .glide__slide .content {
          padding: 150px 83px; } }
      .shared-specs-cta .glide__slide .content .title {
        font-size: 32px;
        line-height: 24px;
        letter-spacing: 0.27px;
        margin-bottom: 26px;
        color: #ffffff; }
        @media (min-width: 1150px) {
          .shared-specs-cta .glide__slide .content .title {
            font-size: 40px;
            letter-spacing: 0.33px; } }
      .shared-specs-cta .glide__slide .content .caption {
        font-size: 16px;
        letter-spacing: -0.5px;
        line-height: 24px;
        white-space: pre-line;
        margin-bottom: 26px;
        color: #ffffff; }
      .shared-specs-cta .glide__slide .content .note {
        font-size: 10px;
        letter-spacing: -0.5px;
        line-height: 24px;
        white-space: pre-line;
        margin-top: 26px;
        color: #ffffff; }
      .shared-specs-cta .glide__slide .content .color-selector {
        justify-content: flex-start; }
        @media (min-width: 1150px) {
          .shared-specs-cta .glide__slide .content .color-selector {
            margin-bottom: 26px; } }
      .shared-specs-cta .glide__slide .content .learn-more {
        position: absolute;
        bottom: 95px;
        left: 30px; }
        @media (min-width: 1150px) {
          .shared-specs-cta .glide__slide .content .learn-more {
            position: relative;
            bottom: auto;
            left: auto; } }
      .shared-specs-cta .glide__slide .content .aside {
        position: absolute;
        bottom: 54px;
        left: 30px;
        padding: 0;
        margin: 0;
        color: #ffffff;
        font-size: 12px;
        line-height: 24px; }
        @media (min-width: 1150px) {
          .shared-specs-cta .glide__slide .content .aside {
            text-align: center;
            width: 563px;
            right: 263px;
            bottom: 90px;
            left: auto; } }
      .shared-specs-cta .glide__slide .content.black .title, .shared-specs-cta .glide__slide .content.black .caption, .shared-specs-cta .glide__slide .content.black .aside {
        color: #000000; }
    .shared-specs-cta .glide__slide img {
      display: block;
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      object-fit: cover;
      z-index: 1; }
  .shared-specs-cta .specs3-background {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 1; }
    .shared-specs-cta .specs3-background .background-carbon,
    .shared-specs-cta .specs3-background .background-mineral {
      transition: 500ms cubic-bezier(0.4, 0, 0.2, 1); }
    .shared-specs-cta .specs3-background.carbon {
      background: linear-gradient(to bottom, #2e2e2e, #171717);
      z-index: 0; }
      .shared-specs-cta .specs3-background.carbon .background-carbon {
        opacity: 1; }
      .shared-specs-cta .specs3-background.carbon .background-mineral {
        opacity: 0; }
    .shared-specs-cta .specs3-background.mineral {
      background: linear-gradient(to bottom, #edd8b9, #c3a17e);
      z-index: 0; }
      .shared-specs-cta .specs3-background.mineral .background-carbon {
        opacity: 0; }
      .shared-specs-cta .specs3-background.mineral .background-mineral {
        opacity: 1; }
  .shared-specs-cta .controls {
    height: 2px;
    overflow: visible;
    background-color: #939393;
    display: flex;
    align-items: center;
    position: absolute;
    transform: scaleX(0.85);
    bottom: 37px;
    width: 100%; }
    .shared-specs-cta .controls button {
      font-size: 0;
      margin: 0;
      padding: 0;
      border: 0;
      border-radius: 0;
      appearance: none;
      height: 10px;
      cursor: pointer;
      width: 100%; }
      .shared-specs-cta .controls button:hover {
        background-color: transparent; }
    .shared-specs-cta .controls .current-indicator {
      position: absolute;
      top: 0;
      left: 0;
      height: 2px;
      background-color: #fffc00;
      transition: transform 500ms cubic-bezier(0.4, 0, 0.2, 1);
      cursor: pointer; }
    @media (min-width: 1150px) {
      .shared-specs-cta .controls {
        width: 563px;
        right: 200px;
        bottom: 57px; } }

.video-background {
  width: 100%;
  height: 100%;
  display: block;
  position: fixed;
  top: 0;
  left: 0;
  object-fit: cover; }
  @media (min-width: 1150px) {
    .video-background {
      height: 90%; } }

.youtube-overlay {
  position: fixed;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  z-index: 10;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 0 20px; }
  @media (min-width: 1150px) {
    .youtube-overlay {
      padding: 0 100px; } }
  .youtube-overlay .close {
    background-color: rgba(0, 0, 0, 0.8);
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 11;
    cursor: url("/close-cursor.svg") 16 16, auto; }
  .youtube-overlay .video-box {
    overflow: hidden;
    position: relative;
    height: 0;
    z-index: 12;
    width: 90vw;
    padding-bottom: 50.634vw;
    background-color: #000000; }
    @media (min-width: 1150px) {
      .youtube-overlay .video-box {
        width: 70vw;
        padding-bottom: 39.382vw; } }
    .youtube-overlay .video-box iframe {
      left: 0;
      top: 0;
      height: 100%;
      width: 100%;
      position: absolute;
      cursor: default; }

.terms-modal {
  display: none;
  opacity: 0;
  will-change: opacity;
  cursor: pointer;
  position: fixed;
  top: 0;
  left: 0;
  height: 100vh;
  width: 100%;
  min-width: 100%;
  background: rgba(255, 255, 255, 0.55);
  z-index: -5;
  align-items: center;
  justify-content: center; }
  @media (min-width: 720px) {
    .terms-modal {
      top: 0; } }
  .terms-modal.active {
    display: flex;
    z-index: 999;
    -webkit-animation: fade 500ms linear 1 normal forwards; }

@-webkit-keyframes fade {
  from {
    opacity: 0; }
  to {
    opacity: 1; } }
  .terms-modal > div {
    cursor: default;
    background: #ffffff;
    width: 90%;
    max-width: 90%;
    padding: 50px 30px 40px 30px;
    position: relative; }
    .terms-modal > div p {
      color: #000000;
      font-family: 'Graphik';
      font-weight: 400;
      font-size: 15px;
      line-height: 19px;
      margin: 0;
      text-align: center; }
    .terms-modal > div .close {
      float: right;
      position: absolute;
      top: 4px;
      right: 4px;
      width: 40px;
      height: 40px; }
      .terms-modal > div .close:after {
        color: #000000;
        cursor: pointer;
        font-family: 'Graphik';
        font-weight: 400;
        content: 'X';
        display: block;
        top: 10px;
        right: 0;
        font-size: 20px;
        text-align: center;
        position: relative; }
    @media (min-width: 720px) {
      .terms-modal > div {
        max-width: 500px;
        padding: 70px 50px 60px 50px; }
        .terms-modal > div .close {
          top: 5px;
          right: 5px; } }

.paypalcredit--product-configurator {
  margin: -15px 0px 5px 0px;
  width: 100%; }

.paypalcredit--cart-popout {
  margin-top: 20px;
  margin-bottom: -10px; }

.iframe__wrapper {
  min-width: unset !important; }

.shopping-cart {
  background-color: #ffffff;
  display: flex;
  flex-direction: column;
  height: 100%;
  overflow-y: auto;
  pointer-events: none;
  position: fixed;
  right: -400px;
  top: 0;
  transition: all 300ms cubic-bezier(0.4, 0, 0.2, 1);
  z-index: 100; }
  .shopping-cart.active {
    opacity: 1;
    pointer-events: all;
    right: 0;
    width: 100%;
    z-index: 10;
    left: 0; }
    @media (min-width: 720px) {
      .shopping-cart.active {
        width: 400px;
        left: unset; } }
    .shopping-cart.active .shopping-cart-overlay {
      transition: all 300ms cubic-bezier(0.4, 0, 0.2, 1);
      opacity: 1;
      right: 400px; }
    .shopping-cart.active .shopping-cart-header {
      transition: all 300ms cubic-bezier(0.4, 0, 0.2, 1);
      left: 0; }
      @media (min-width: 720px) {
        .shopping-cart.active .shopping-cart-header {
          left: unset;
          right: 0; } }
  .shopping-cart .shopping-cart-header {
    align-items: center;
    display: flex;
    justify-content: flex-end;
    width: 100%;
    position: fixed;
    right: -400px; }
    .shopping-cart .shopping-cart-header .close-cart {
      padding: 20px; }
    @media (min-width: 720px) {
      .shopping-cart .shopping-cart-header {
        width: 400px;
        left: unset; } }
  .shopping-cart .shopping-cart-line-item {
    max-width: 80%; }
  .shopping-cart .shopping-cart-footer {
    margin: 0 auto;
    padding: 60px 20px 40px;
    text-align: center;
    width: 100%; }
    @media (min-width: 720px) {
      .shopping-cart .shopping-cart-footer {
        max-width: 80%;
        padding: 60px 0 40px; } }
    .shopping-cart .shopping-cart-footer .cta {
      width: 100%; }
    .shopping-cart .shopping-cart-footer .footer-note {
      color: #9e9e9e;
      font-size: 12px; }
    .shopping-cart .shopping-cart-footer .shopping-cart-total {
      text-align: center;
      margin-bottom: 20px; }
      .shopping-cart .shopping-cart-footer .shopping-cart-total h3 {
        color: #9e9e9e;
        margin-right: 6px;
        font-weight: 400;
        margin: 0 6px 0 0; }
      .shopping-cart .shopping-cart-footer .shopping-cart-total h3,
      .shopping-cart .shopping-cart-footer .shopping-cart-total span {
        display: inline-block;
        font-size: 22px; }
  .shopping-cart .shopping-cart-empty-msg {
    text-align: center;
    margin: 0 auto;
    width: 80%;
    padding-top: 20px; }
  .shopping-cart .shopping-cart-wrapper {
    width: 100%; }
  .shopping-cart .shopping-cart-overlay {
    background-color: rgba(255, 255, 255, 0.8);
    position: fixed;
    opacity: 0;
    top: 0;
    right: 0px;
    width: 100%;
    height: 150%;
    transition: all 300ms cubic-bezier(0.4, 0, 0.2, 1);
    display: none; }
    @media (min-width: 720px) {
      .shopping-cart .shopping-cart-overlay {
        display: unset; } }

.shopping-cart-line-item {
  border-bottom: 1px solid #e5e5e5;
  margin: 0 auto;
  width: 100%; }
  .shopping-cart-line-item .line-item-thumbnail {
    padding-top: 20px;
    height: 120px; }
    .shopping-cart-line-item .line-item-thumbnail .thumbnail-image {
      background-repeat: no-repeat;
      background-size: contain;
      background-position: center;
      height: 120px;
      width: 100%; }
  .shopping-cart-line-item .line-item-details {
    text-align: center; }
  .shopping-cart-line-item .line-item-title {
    font-size: 18px;
    font-weight: 400; }
  .shopping-cart-line-item .line-item-price {
    color: #9e9e9e; }
  .shopping-cart-line-item .quantity-container {
    align-items: center;
    padding: 20px 0;
    display: flex;
    justify-content: center; }
  .shopping-cart-line-item .quantifier-icon {
    align-items: center;
    border-radius: 44px;
    border: 1px solid #000000;
    font-size: 16px;
    display: flex;
    height: 24px;
    justify-content: center;
    padding: 0;
    width: 24px; }
  .shopping-cart-line-item .quantity {
    align-items: center;
    background-color: #000000;
    border-radius: 64px;
    color: #ffffff;
    display: flex;
    height: 32px;
    font-size: 14px;
    justify-content: center;
    margin: 0 10px;
    max-width: 32px;
    width: 32px; }
  .shopping-cart-line-item .tooltip-wrapper {
    position: relative; }
    .shopping-cart-line-item .tooltip-wrapper .tooltip {
      position: absolute;
      background-color: black;
      color: white;
      width: 186px;
      bottom: 32px;
      left: 50%;
      transform: translateX(-50%);
      text-align: center;
      padding: 10px 16px;
      border-radius: 4px; }
      .shopping-cart-line-item .tooltip-wrapper .tooltip::before {
        content: "";
        position: absolute;
        background-color: black;
        transform: translateX(-50%) rotate(-135deg);
        border-radius: 2px;
        left: 50%;
        height: 10px;
        width: 10px;
        bottom: -2px; }

.two-cameras {
  background-color: #000000;
  position: relative;
  z-index: 2;
  padding: 42px 0; }
  @media (min-width: 1150px) {
    .two-cameras {
      padding: 156px 83px 156px 83px; } }
  .two-cameras .headline, .two-cameras .sub-heading, .two-cameras .sub-heading2 {
    color: #ffffff;
    padding: 0 40px; }
    @media (min-width: 1150px) {
      .two-cameras .headline, .two-cameras .sub-heading, .two-cameras .sub-heading2 {
        padding: 0; } }
  .two-cameras .headline {
    font-size: 32px;
    line-height: 40px;
    letter-spacing: 0.4px; }
    @media (min-width: 1150px) {
      .two-cameras .headline {
        white-space: pre-line;
        font-size: 52px;
        line-height: 64px;
        letter-spacing: 0.5px;
        margin-bottom: 0px; } }
  .two-cameras .sub-heading {
    display: none; }
    @media (min-width: 1150px) {
      .two-cameras .sub-heading {
        display: block;
        font-size: 24px;
        line-height: 40px;
        letter-spacing: -0.67px;
        max-width: 562px;
        margin-bottom: 60px; } }
  .two-cameras .sub-heading2 {
    display: none; }
    @media (min-width: 1150px) {
      .two-cameras .sub-heading2 {
        display: block;
        font-size: 18px;
        line-height: 30px;
        letter-spacing: -0.67px;
        max-width: 562px;
        margin: 0; } }
  .two-cameras a.button {
    margin-left: 40px;
    margin-right: 40px;
    margin-bottom: 38px; }
    @media (min-width: 1150px) {
      .two-cameras a.button {
        margin-left: 0;
        margin-right: 0; } }
  @media (min-width: 1150px) {
    .two-cameras {
      display: flex;
      align-items: center; }
      .two-cameras > * {
        flex-grow: 1;
        flex-basis: 50%;
        width: 50%; } }

.home-hero {
  height: 86vh;
  width: 100%;
  position: relative;
  z-index: 2;
  background-attachment: scroll;
  background-size: cover;
  background-position: center center;
  will-change: opacity;
  transform: translateZ(0); }
  @media (min-width: 720px) {
    .home-hero {
      background-attachment: fixed; } }
  .home-hero::before {
    content: "";
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    background-color: black;
    opacity: var(--opacity);
    user-select: none;
    pointer-events: none; }
  .home-hero::after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 50%;
    background: linear-gradient(0deg, rgba(0, 0, 0, 0.5) 0%, transparent 100%);
    z-index: 2; }
  .home-hero img {
    position: absolute;
    z-index: 1;
    object-fit: cover;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%; }
  .home-hero .hero-content {
    position: absolute;
    z-index: 3;
    left: 20px;
    bottom: 80px; }
    @media (min-width: 720px) {
      .home-hero .hero-content {
        left: 83px;
        bottom: 264px; } }
  .home-hero h2 {
    white-space: pre-line;
    font-size: 32px;
    line-height: 1.25;
    letter-spacing: 0.5px;
    color: #ffffff;
    margin: 0;
    margin-bottom: 13px; }
    @media (min-width: 720px) {
      .home-hero h2 {
        width: auto;
        font-size: 52px;
        line-height: 64px;
        letter-spacing: 0.53px;
        line-height: 1;
        margin-bottom: 27px; } }
  .home-hero p {
    margin: 0;
    color: #ffffff;
    font-size: 16px;
    line-height: 1.5;
    width: 282px;
    margin-bottom: 35px; }
    @media (min-width: 720px) {
      .home-hero p {
        width: 420px; } }
    .home-hero p .subHeading {
      font-size: 13px;
      margin-bottom: 0px; }
      @media (min-width: 720px) {
        .home-hero p .subHeading {
          margin-bottom: 0px;
          font-size: 18px;
          line-height: 30px; } }

@media (min-width: 1150px) {
  .carousel .glide::before, .carousel .glide::after {
    content: "";
    width: 10%;
    height: 100%;
    position: absolute;
    top: 0;
    pointer-events: none;
    z-index: 2; }
  .carousel .glide::before {
    left: 0;
    background: linear-gradient(to right, black, transparent); }
  .carousel .glide::after {
    right: 0;
    background: linear-gradient(to left, black, transparent); } }

.carousel .videos {
  position: relative;
  width: 100%;
  display: block;
  height: 450px;
  overflow: hidden; }
  @media (min-width: 1150px) {
    .carousel .videos {
      overflow: unset;
      height: 38vw; } }
  .carousel .videos img, .carousel .videos video {
    position: relative;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vw;
    object-fit: cover;
    object-position: center center;
    border-radius: 50%;
    margin: 0;
    display: block; }
    @media (min-width: 1150px) {
      .carousel .videos img, .carousel .videos video {
        width: 80%;
        height: auto;
        left: 10%;
        margin: 0;
        display: block; } }
  .carousel .videos .carousel-enter {
    opacity: 0.01;
    transform: scale(0.8); }
  .carousel .videos .carousel-enter.carousel-enter-active {
    opacity: 1;
    transform: scale(1);
    transition: 800ms cubic-bezier(0.4, 0, 0.2, 1); }
  .carousel .videos .carousel-leave {
    opacity: 1;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    transform-origin: center center;
    transform: scale(1); }
  .carousel .videos .carousel-leave.carousel-leave-active {
    opacity: 0.01;
    transition: 800ms cubic-bezier(0.4, 0, 0.2, 1);
    transform: scale(1.2); }

.carousel .caption {
  color: #9e9e9e;
  text-align: center;
  white-space: pre-line;
  font-size: 12px;
  line-height: 24px;
  margin: 0;
  margin-top: 40px; }

.carousel .controls {
  height: 2px;
  overflow: visible;
  background-color: #939393;
  display: flex;
  align-items: center;
  position: relative;
  transform: scaleX(0.85); }
  .carousel .controls button {
    font-size: 0;
    margin: 0;
    padding: 0;
    border: 0;
    border-radius: 0;
    appearance: none;
    height: 10px;
    cursor: pointer;
    width: 100%; }
    .carousel .controls button:hover {
      background-color: transparent; }
  .carousel .controls .current-indicator {
    position: absolute;
    top: 0;
    left: 0;
    height: 2px;
    background-color: #fffc00;
    transition: transform 500ms cubic-bezier(0.4, 0, 0.2, 1);
    cursor: pointer; }

.holiday-hero {
  background-size: cover;
  background-position: center center;
  height: 100vh;
  width: 100%;
  position: relative;
  z-index: 2; }
  @media (min-width: 720px) {
    .holiday-hero {
      height: 94vh; } }
  .holiday-hero .glide {
    min-height: 100%;
    height: 100%;
    min-width: 100%; }
    .holiday-hero .glide .glide__track {
      min-height: 100%;
      height: 100%;
      min-height: 100%; }
      .holiday-hero .glide .glide__track .glide__slides {
        min-height: 100%;
        height: 100%;
        min-height: 100%;
        top: -18px;
        height: calc(100% + 18px); }
        .holiday-hero .glide .glide__track .glide__slides .glide__slide {
          min-height: 100%;
          height: 100%;
          background-size: cover;
          background-position: center center;
          position: relative; }
          .holiday-hero .glide .glide__track .glide__slides .glide__slide-background {
            min-height: 100%;
            height: 100%;
            background-color: #000000;
            background-size: cover;
            background-position: center center;
            background-repeat: no-repeat;
            min-width: 100%;
            position: absolute;
            top: 0;
            left: 0; }
            .holiday-hero .glide .glide__track .glide__slides .glide__slide-background-layer {
              min-height: 100%;
              height: 100%;
              min-width: 100%;
              position: absolute;
              top: 0;
              left: 0;
              z-index: 2;
              background: #000000;
              opacity: 0.25; }
          .holiday-hero .glide .glide__track .glide__slides .glide__slide:after {
            display: block;
            content: '';
            position: absolute;
            top: 0;
            left: 0;
            background: rgba(0, 0, 0, 0.15);
            min-height: 100%;
            min-width: 100%; }
          .holiday-hero .glide .glide__track .glide__slides .glide__slide-content {
            position: absolute;
            z-index: 3;
            left: 30px;
            bottom: 48px;
            width: calc(100% - 60px); }
            @media (min-width: 720px) {
              .holiday-hero .glide .glide__track .glide__slides .glide__slide-content {
                left: 83px;
                bottom: 11vh;
                width: calc(100% - 166px); } }
            .holiday-hero .glide .glide__track .glide__slides .glide__slide-content h2 {
              font-family: "Graphik";
              font-weight: 400;
              white-space: pre-line;
              font-size: 32px;
              line-height: 1.25;
              letter-spacing: 0.5px;
              color: #ffffff;
              margin: 0; }
              @media (min-width: 720px) {
                .holiday-hero .glide .glide__track .glide__slides .glide__slide-content h2 {
                  width: auto;
                  font-size: 52px;
                  line-height: 64px;
                  letter-spacing: 0.53px;
                  line-height: 1; } }
            .holiday-hero .glide .glide__track .glide__slides .glide__slide-content p {
              margin: 0;
              color: #ffffff;
              font-size: 16px;
              line-height: 1.5;
              width: 95%; }
              @media (min-width: 720px) {
                .holiday-hero .glide .glide__track .glide__slides .glide__slide-content p {
                  font-size: 18px;
                  line-height: 1.5;
                  width: 360px; } }
              @media (min-width: 720px) {
                .holiday-hero .glide .glide__track .glide__slides .glide__slide-content p:first-of-type {
                  margin-top: 27px; } }
              .holiday-hero .glide .glide__track .glide__slides .glide__slide-content p.caption {
                font-family: "Graphik";
                font-weight: 400;
                font-style: italic !important;
                margin-top: 27px !important; }
                .holiday-hero .glide .glide__track .glide__slides .glide__slide-content p.caption span {
                  cursor: pointer;
                  transition: 250ms ease;
                  margin-left: 6px;
                  color: rgba(255, 255, 255, 0.75);
                  text-decoration: underline; }
                  .holiday-hero .glide .glide__track .glide__slides .glide__slide-content p.caption span:hover {
                    color: white; }
            .holiday-hero .glide .glide__track .glide__slides .glide__slide-content .button {
              margin-top: 27px; }
              @media (min-width: 720px) {
                .holiday-hero .glide .glide__track .glide__slides .glide__slide-content .button {
                  margin-top: 35px; } }
    .holiday-hero .glide .controls {
      position: absolute;
      height: 2px;
      background-color: #939393;
      display: flex;
      align-items: center;
      transform: scaleX(0.85);
      z-index: 9;
      left: -33px;
      bottom: 0px;
      width: calc(100% + 66px); }
      .holiday-hero .glide .controls button {
        border: none;
        background: none;
        border-radius: 0;
        flex-grow: 1;
        height: 12px;
        margin-top: -3px; }
        .holiday-hero .glide .controls button:hover {
          background: none; }
      @media (min-width: 720px) {
        .holiday-hero .glide .controls {
          left: 70px;
          bottom: 6vh;
          width: 222px; } }
      .holiday-hero .glide .controls .current-indicator {
        position: absolute;
        top: 0;
        left: 0;
        height: 2px;
        background-color: #fffc00;
        transition: transform 500ms cubic-bezier(0.4, 0, 0.2, 1);
        cursor: none;
        z-index: 10; }

.harmony-hero {
  width: 100%;
  height: 100vh;
  position: relative;
  z-index: 2; }

@keyframes videoIn {
  0% {
    opacity: 0; }
  100% {
    opacity: 1; } }
  .harmony-hero-video {
    transition: 350ms ease-in-out;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 10;
    background-size: cover;
    background-position: center center;
    width: 100%;
    height: 100%;
    opacity: 0;
    display: none;
    min-width: 100%;
    min-height: 100%; }
    .harmony-hero-video.active {
      display: flex;
      align-items: center;
      justify-content: center;
      animation: videoIn 500ms ease-in forwards; }
    .harmony-hero-video video {
      max-width: 100%;
      height: auto;
      z-index: 11; }
      @media (min-width: 720px) {
        .harmony-hero-video video {
          width: auto;
          max-height: 85vh;
          height: auto; } }
    .harmony-hero-video .close {
      background-color: rgba(0, 0, 0, 0.8);
      position: absolute;
      min-width: 100%;
      min-height: 100%;
      width: 100%;
      height: 100%;
      top: 0;
      left: 0;
      z-index: 10;
      cursor: url(/close-cursor.svg) 16 16, auto; }
  .harmony-hero-background {
    transition: 350ms ease-in-out;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 0;
    background-size: cover;
    background-position: center center;
    width: 100%;
    height: 100%;
    opacity: 1;
    min-width: 100%;
    min-height: 100%; }
    .harmony-hero-background:after {
      display: block;
      content: '';
      position: absolute;
      top: 0;
      left: 0;
      z-index: 1;
      background: rgba(0, 0, 0, 0.25);
      min-width: 100%;
      width: 100%;
      min-height: 100%;
      height: 100%; }
  .harmony-hero-content {
    position: absolute;
    z-index: 3;
    left: 30px;
    bottom: 48px;
    width: calc(100% - 60px); }
    @media (min-width: 720px) {
      .harmony-hero-content {
        left: 83px;
        bottom: 11vh;
        width: calc(100% - 166px); } }
    .harmony-hero-content h2 {
      font-family: "Graphik";
      font-weight: 400;
      white-space: pre-line;
      font-size: 32px;
      line-height: 1.25;
      letter-spacing: 0.5px;
      color: #ffffff;
      margin: 0; }
      @media (min-width: 720px) {
        .harmony-hero-content h2 {
          width: auto;
          font-size: 52px;
          line-height: 64px;
          letter-spacing: 0.53px;
          line-height: 1; } }
    .harmony-hero-content p {
      margin: 0;
      color: #ffffff;
      font-size: 16px;
      line-height: 1.5;
      width: 95%; }
      @media (min-width: 720px) {
        .harmony-hero-content p {
          font-size: 18px;
          line-height: 1.5;
          width: 360px; } }
      @media (min-width: 720px) {
        .harmony-hero-content p:first-of-type {
          margin-top: 27px; } }
    .harmony-hero-content button {
      margin-right: 12px; }
    .harmony-hero-content .button {
      margin-top: 27px; }
      @media (min-width: 720px) {
        .harmony-hero-content .button {
          margin-top: 35px; } }
      .harmony-hero-content .button img {
        float: left;
        display: inline-block;
        max-height: 16px;
        width: auto;
        margin-right: 6px; }

.learn-video {
  position: relative;
  overflow: hidden;
  z-index: 4; }
  .learn-video::before {
    content: "";
    width: 100%;
    height: 100%;
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    opacity: 0.8;
    background-image: linear-gradient(to bottom, transparent, black);
    transition: opacity 150ms cubic-bezier(0.4, 0, 0.2, 1);
    z-index: 2; }
  .learn-video video {
    width: 100%;
    height: 100%;
    object-fit: cover; }
  .learn-video .poster {
    width: 100.1%;
    height: 100.1%;
    object-fit: cover;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 1;
    opacity: 1;
    transition: opacity 300ms cubic-bezier(0.4, 0, 0.2, 1), transform 150ms cubic-bezier(0.4, 0, 0.2, 1);
    transform-origin: center center;
    transform: scale(1);
    pointer-events: none;
    user-select: none; }
  .learn-video.half, .learn-video.third, .learn-video.full, .learn-video.full-left, .learn-video.full-right {
    height: 100vw;
    width: 100vw; }
  .learn-video .content {
    border-radius: 0;
    border: 0;
    bottom: 30px;
    color: #ffffff;
    font-size: 18px;
    left: 0;
    top: 0;
    line-height: 1.33;
    margin: 0 auto;
    opacity: 1;
    padding: 0 30px;
    position: absolute;
    text-align: center;
    transition: opacity 300ms cubic-bezier(0.4, 0, 0.2, 1);
    height: 100%;
    width: 100%;
    z-index: 2;
    top: 15%; }
    .learn-video .content .play {
      display: block;
      margin: 30px auto 0;
      width: 60px;
      height: 60px;
      display: flex;
      justify-content: center;
      align-items: center;
      border: 2px solid #ffffff;
      border-radius: 50%;
      transition: all 300ms cubic-bezier(0.4, 0, 0.2, 1); }
    .learn-video .content:hover {
      background-color: transparent; }
      .learn-video .content:hover .play {
        background-color: rgba(255, 255, 255, 0.2); }
      .learn-video .content:hover + .poster {
        transform: scale(1.05); }
    .learn-video .content .title {
      position: relative;
      margin-top: 32%;
      display: flex;
      flex-direction: column; }
  .learn-video.playing .content, .learn-video.playing::before, .learn-video.playing .poster {
    opacity: 0;
    pointer-events: none; }
  @media (min-width: 720px) {
    .learn-video .content {
      font-size: 24px;
      top: 65%;
      bottom: auto;
      transform: translateY(-50%); }
    .learn-video .title {
      margin-top: 30%; }
    .learn-video.half {
      flex-basis: 50vw;
      height: 50vw; }
      .learn-video.half .content {
        font-size: 32px; }
    .learn-video.third {
      flex-basis: calc(100vw / 3);
      height: calc(100vw / 3); }
      .learn-video.third .content {
        font-size: 24px; }
    .learn-video.full-left, .learn-video.full-right {
      flex-basis: 100vw;
      height: 50vw; }
      .learn-video.full-left .content, .learn-video.full-right .content {
        font-size: 48px;
        max-width: 550px; }
    .learn-video.full-left .content {
      width: 50%;
      max-width: none;
      margin: 0; }
    .learn-video.full-right .content {
      width: 50%;
      max-width: none;
      margin: 0;
      margin-left: 50%; } }

.shop-double-buttons {
  display: flex;
  justify-content: center;
  padding: 30px 0;
  width: 100%; }
  .shop-double-buttons .button {
    margin: 0 6px; }

.shop-accessory-product {
  display: flex;
  min-height: 375px;
  position: relative;
  width: 100%;
  height: 40vw; }
  @media (min-width: 720px) {
    .shop-accessory-product {
      max-height: 640px; } }
  .shop-accessory-product .overlay {
    background-color: rgba(0, 0, 0, 0.5);
    height: 100%;
    position: absolute;
    width: 100%;
    z-index: 1; }
  .shop-accessory-product .accessory-img {
    display: block;
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    object-fit: cover; }
  .shop-accessory-product .shop-accessory-product-content {
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    position: absolute;
    padding: 20px;
    text-align: center;
    width: 100%;
    z-index: 2; }
    @media (min-width: 720px) {
      .shop-accessory-product .shop-accessory-product-content {
        max-width: 80%; } }
    .shop-accessory-product .shop-accessory-product-content h1, .shop-accessory-product .shop-accessory-product-content h2,
    .shop-accessory-product .shop-accessory-product-content .price, .shop-accessory-product .shop-accessory-product-content .ATP {
      color: #ffffff; }
    .shop-accessory-product .shop-accessory-product-content h1 {
      font-size: 24px;
      margin-bottom: 10px; }
    .shop-accessory-product .shop-accessory-product-content h2 {
      font-size: 16px;
      margin-bottom: 20px; }
    .shop-accessory-product .shop-accessory-product-content .ATP {
      font-size: 12px; }
  .shop-accessory-product .accessory-product-buttons {
    display: flex;
    justify-content: center;
    margin: 30px auto;
    width: max-content; }
    .shop-accessory-product .accessory-product-buttons button + .button {
      margin-left: 12px; }

.shop-compare-cta {
  display: flex;
  min-height: 250px;
  position: relative; }
  .shop-compare-cta.mineral {
    background: linear-gradient(to bottom, #edd8b9, #c3a17e); }
  .shop-compare-cta.carbon {
    background: linear-gradient(to bottom, #2e2e2e, #171717); }
  .shop-compare-cta .shop-compare-cta-content {
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    position: absolute;
    align-items: center;
    display: flex;
    flex-direction: column;
    max-width: 256px;
    z-index: 2; }
    @media (min-width: 720px) {
      .shop-compare-cta .shop-compare-cta-content {
        max-width: none; } }
    .shop-compare-cta .shop-compare-cta-content h1 {
      color: #ffffff;
      font-size: 24px; }
      @media (min-width: 720px) {
        .shop-compare-cta .shop-compare-cta-content h1 {
          font-size: 48px; } }
  .shop-compare-cta .overlay {
    background-color: rgba(0, 0, 0, 0.5);
    height: 100%;
    position: absolute;
    width: 100%;
    z-index: 1; }
  .shop-compare-cta .shop-compare-image {
    align-self: flex-end;
    width: 100%; }
    @media (min-width: 720px) {
      .shop-compare-cta .shop-compare-image {
        padding-top: 100px; } }
    .shop-compare-cta .shop-compare-image img {
      display: none;
      width: 100%; }
      .shop-compare-cta .shop-compare-image img.active {
        display: block; }

.shop-landing {
  min-height: 300px;
  height: 86vh;
  position: relative; }
  @media (min-width: 1150px) {
    .shop-landing {
      height: 56vw;
      max-height: 86vh; } }
  .shop-landing img {
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    opacity: 0; }
    .shop-landing img.active {
      opacity: 1; }
    .shop-landing img.main {
      object-fit: contain;
      height: 80%; }
      @media (min-width: 1150px) {
        .shop-landing img.main {
          height: 100%; } }
    .shop-landing img.background {
      object-fit: cover;
      opacity: 0;
      transition: opacity 300ms cubic-bezier(0.4, 0, 0.2, 1); }
      .shop-landing img.background.hover {
        opacity: 1; }
  .shop-landing .shop-landing-content {
    position: absolute;
    bottom: 74px;
    left: 0;
    right: 0;
    margin: 0 auto;
    z-index: 2;
    text-align: center; }
    @media (min-width: 1150px) {
      .shop-landing .shop-landing-content {
        bottom: 40px; } }
    .shop-landing .shop-landing-content .spectacles3-heading {
      font-size: 40px;
      letter-spacing: 0.33px;
      line-height: 24px;
      margin: 0;
      color: #ffffff; }
    .shop-landing .shop-landing-content .price {
      font-size: 22px;
      letter-spacing: 0.18px;
      line-height: 24px;
      color: #ffffff; }
    .shop-landing .shop-landing-content .product-whats-inside, .shop-landing .shop-landing-content .ATP, .shop-landing .shop-landing-content .prescription {
      max-width: 216px;
      font-size: 12px;
      line-height: 18px;
      letter-spacing: 0.1px;
      margin: 0 auto;
      margin-bottom: 20px;
      color: #ffffff; }
      @media (min-width: 1150px) {
        .shop-landing .shop-landing-content .product-whats-inside, .shop-landing .shop-landing-content .ATP, .shop-landing .shop-landing-content .prescription {
          max-width: none; } }
    .shop-landing .shop-landing-content .ATP {
      margin-top: 10px;
      margin-bottom: 0px; }
      .shop-landing .shop-landing-content .ATP span {
        transition: 250ms ease;
        cursor: pointer;
        color: rgba(255, 255, 255, 0.65);
        text-decoration: underline; }
        .shop-landing .shop-landing-content .ATP span:hover {
          color: #ffffff; }
    .shop-landing .shop-landing-content .shop-landing-buttons {
      margin: 0 auto;
      margin-bottom: 20px;
      width: max-content; }
      .shop-landing .shop-landing-content .shop-landing-buttons button:first-child {
        margin-right: 12px; }
  .shop-landing.mineral {
    background: linear-gradient(to bottom, #edd8b9, #c3a17e); }
  .shop-landing.carbon {
    background: linear-gradient(to bottom, #2e2e2e, #171717); }

.shop-spectacles {
  position: relative;
  z-index: 2; }
  @media (min-width: 1150px) {
    .shop-spectacles {
      display: flex; }
      .shop-spectacles > * {
        flex-basis: 33vw;
        flex-grow: 1; } }
  .shop-spectacles .product {
    position: relative;
    width: 100vw;
    text-align: center;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    padding: 40px 0; }
    @media (min-width: 1150px) {
      .shop-spectacles .product {
        padding: 80px 0; } }
    .shop-spectacles .product img {
      display: block;
      margin: 0 auto;
      margin-bottom: 30px;
      height: 100px; }
    .shop-spectacles .product .title, .shop-spectacles .product .caption, .shop-spectacles .product .price {
      transition: color 300ms cubic-bezier(0.4, 0, 0.2, 1); }
    .shop-spectacles .product .title {
      font-size: 32px;
      line-height: 24px;
      letter-spacing: 0.27px;
      margin: 0;
      margin-bottom: 20px;
      position: relative;
      z-index: 3; }
    .shop-spectacles .product .caption {
      font-size: 12px;
      letter-spacing: 0.09px;
      line-height: 1;
      margin: 0;
      margin-bottom: 30px;
      position: relative;
      z-index: 3; }
    .shop-spectacles .product .price {
      color: #9e9e9e;
      font-size: 22px;
      line-height: 24px;
      letter-spacing: 0.18px;
      margin: 0;
      margin-bottom: 27px;
      position: relative;
      z-index: 3; }
    .shop-spectacles .product .bg-image {
      position: absolute;
      left: 0;
      top: 0;
      width: 100%;
      height: 100%;
      opacity: 0;
      pointer-events: none;
      background-repeat: none;
      background-size: cover;
      transition: opacity 300ms cubic-bezier(0.4, 0, 0.2, 1);
      background-position: center center;
      z-index: 1; }
    .shop-spectacles .product .buttons {
      display: block;
      margin: 0 auto;
      position: relative;
      z-index: 3; }
      .shop-spectacles .product .buttons > * + * {
        margin-left: 10px; }
    .shop-spectacles .product .color-picker {
      margin-top: 20px; }
      @media (min-width: 1150px) {
        .shop-spectacles .product .color-picker {
          margin: 0 auto;
          position: absolute;
          bottom: 25px;
          left: 0;
          right: 0; } }
      .shop-spectacles .product .color-picker button {
        border: 0;
        padding: 10px;
        appearance: none;
        display: inline-block;
        margin: 0; }
        .shop-spectacles .product .color-picker button span {
          display: block;
          border-radius: 50%;
          width: 8px;
          height: 8px; }
        .shop-spectacles .product .color-picker button.active span {
          box-shadow: 0 0 0 4px #ffffff, 0 0 0 6px #000000; }
        .shop-spectacles .product .color-picker button.onyx span {
          background-color: #000; }
        .shop-spectacles .product .color-picker button.ruby span {
          background-color: #FF4E4E; }
        .shop-spectacles .product .color-picker button.sapphire span {
          background-color: #0F3DFF; }
        .shop-spectacles .product .color-picker button.moonlight span {
          background: linear-gradient(-45deg, #606060 0%, #DCDCDC 100%); }
        .shop-spectacles .product .color-picker button.eclipse span {
          background: linear-gradient(-45deg, #282828 0%, #878787 100%); }
        .shop-spectacles .product .color-picker button.daybreak span {
          background: linear-gradient(-225deg, #FDDFCE 0%, #F7A47F 100%); }
        .shop-spectacles .product .color-picker button.sunset span {
          background: linear-gradient(-225deg, #FFBE87 0%, #EE3D25 98%); }
        .shop-spectacles .product .color-picker button.twilight span {
          background: linear-gradient(225deg, #004bff, #9392eb); }
        .shop-spectacles .product .color-picker button.midnight span {
          background: linear-gradient(45deg, #5f79b5, #002159); }
      .shop-spectacles .product .color-picker .divider {
        height: 22px;
        background-color: #e5e5e5;
        width: 1px;
        display: inline-block;
        margin: 0 10px;
        position: relative;
        top: 6px; }
    @media (min-width: 1150px) {
      .shop-spectacles .product.hover .bg-image {
        opacity: 1; }
      .shop-spectacles .product.hover .title, .shop-spectacles .product.hover .caption, .shop-spectacles .product.hover .price {
        color: #ffffff; }
      .shop-spectacles .product.hover button,
      .shop-spectacles .product.hover .button {
        border-color: #ffffff;
        background-color: #ffffff;
        color: #000000; }
        .shop-spectacles .product.hover button:hover,
        .shop-spectacles .product.hover .button:hover {
          border-color: #e5e5e5;
          background-color: rgba(255, 255, 255, 0.9); }
      .shop-spectacles .product.hover button.ghost, .shop-spectacles .product.hover .button.ghost {
        background-color: transparent;
        color: #ffffff; }
        .shop-spectacles .product.hover button.ghost:hover, .shop-spectacles .product.hover .button.ghost:hover {
          background-color: rgba(255, 255, 255, 0.2); } }

.product-image-box {
  position: relative;
  flex-basis: 100%;
  padding: 30px; }
  .product-image-box img {
    display: block; }
  .product-image-box video {
    display: block; }
  .product-image-box[data-portrait-order="1"] {
    order: 1; }
  .product-image-box[data-portrait-order="2"] {
    order: 2; }
  .product-image-box[data-portrait-order="3"] {
    order: 3; }
  .product-image-box[data-portrait-order="4"] {
    order: 4; }
  .product-image-box[data-portrait-order="5"] {
    order: 5; }
  .product-image-box[data-portrait-order="6"] {
    order: 6; }
  .product-image-box[data-portrait-order="7"] {
    order: 7; }
  .product-image-box[data-portrait-order="8"] {
    order: 8; }
  .product-image-box[data-portrait-order="9"] {
    order: 9; }
  .product-image-box[data-portrait-order="10"] {
    order: 10; }
  @media (min-width: 1150px) {
    .product-image-box[data-landscape-order="1"] {
      order: 1; }
    .product-image-box[data-landscape-order="2"] {
      order: 2; }
    .product-image-box[data-landscape-order="3"] {
      order: 3; }
    .product-image-box[data-landscape-order="4"] {
      order: 4; }
    .product-image-box[data-landscape-order="5"] {
      order: 5; }
    .product-image-box[data-landscape-order="6"] {
      order: 6; }
    .product-image-box[data-landscape-order="7"] {
      order: 7; }
    .product-image-box[data-landscape-order="8"] {
      order: 8; }
    .product-image-box[data-landscape-order="9"] {
      order: 9; }
    .product-image-box[data-landscape-order="10"] {
      order: 10; } }
  .product-image-box p {
    position: relative;
    z-index: 2;
    margin: 0;
    color: #ffffff; }
  .product-image-box span {
    display: block; }
  .product-image-box .social ul {
    padding: 0;
    margin: 0;
    list-style: none; }
    .product-image-box .social ul li {
      transition: opacity 150ms cubic-bezier(0.4, 0, 0.2, 1);
      opacity: 0.3; }
      .product-image-box .social ul li:hover {
        opacity: 1; }
    .product-image-box .social ul > * {
      display: inline-block;
      margin-left: 20px; }
  .product-image-box.main {
    padding: 0; }
    .product-image-box.main:before {
      content: "";
      position: absolute;
      bottom: 0;
      left: 0;
      right: 0;
      height: 50%;
      background: linear-gradient(0deg, rgba(0, 0, 0, 0.5) 0%, transparent 100%);
      z-index: 2; }
    .product-image-box.main img {
      width: 100%; }
    .product-image-box.main video {
      width: 100%; }
    .product-image-box.main p {
      position: absolute;
      bottom: 84px;
      left: 40px;
      font-size: 32px;
      line-height: 1.25; }
      @media (min-width: 1150px) {
        .product-image-box.main p {
          bottom: 250px;
          font-size: 64px;
          white-space: pre-line; } }
    .product-image-box.main p:empty {
      display: none; }
  .product-image-box.wide-1 {
    height: 100vw;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
    padding: 20px 0;
    padding-bottom: 0; }
    @media (min-width: 1150px) {
      .product-image-box.wide-1 {
        height: 50vw;
        max-height: 640px;
        flex-direction: row;
        padding: 50px 0;
        padding-bottom: 0; } }
    .product-image-box.wide-1 p {
      color: #000000; }
    .product-image-box.wide-1 .title {
      font-size: 32px;
      margin-bottom: 20px; }
    .product-image-box.wide-1 .subtitle {
      font-size: 14px;
      line-height: 1.5;
      margin-bottom: 60px; }
    .product-image-box.wide-1 .subtitle2 {
      font-size: 14px;
      line-height: 1.5;
      margin-bottom: 60px; }
    .product-image-box.wide-1 .note {
      font-size: 10px;
      line-height: 1.5;
      margin-bottom: 60px; }
    .product-image-box.wide-1 img {
      order: 2; }
      @media (min-width: 1150px) {
        .product-image-box.wide-1 img {
          height: 100%;
          order: 1;
          width: 50vw;
          object-position: bottom;
          object-fit: contain; } }
    @media (min-width: 1150px) {
      .product-image-box.wide-1 .copy {
        order: 2;
        width: 50vw; } }
  .product-image-box.wide-2 {
    height: 140vw;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center; }
    @media (min-width: 1150px) {
      .product-image-box.wide-2 {
        height: 50vw;
        flex-direction: row;
        padding: 0;
        text-align: left; } }
    .product-image-box.wide-2 img {
      max-width: 100%; }
    .product-image-box.wide-2 p {
      color: #000000; }
    .product-image-box.wide-2 .title {
      font-size: 32px;
      margin-bottom: 20px; }
    .product-image-box.wide-2 .subtitle {
      font-size: 14px;
      line-height: 1.5;
      margin: 0 auto;
      margin-bottom: 30px; }
      @media (min-width: 1150px) {
        .product-image-box.wide-2 .subtitle {
          margin: 0;
          margin-bottom: 30px;
          max-width: 100%; } }
    .product-image-box.wide-2 .subtitle2 {
      font-size: 14px;
      line-height: 1.5;
      max-width: 100%;
      margin: 0 auto; }
      @media (min-width: 1150px) {
        .product-image-box.wide-2 .subtitle2 {
          margin: 0; } }
    .product-image-box.wide-2 .note {
      font-size: 10px;
      line-height: 1.5;
      margin-bottom: 60px; }
    .product-image-box.wide-2 img {
      order: 2; }
      @media (min-width: 1150px) {
        .product-image-box.wide-2 img {
          height: 100%;
          order: 1;
          flex-grow: 2;
          object-position: center;
          object-fit: contain; } }
    @media (min-width: 1150px) {
      .product-image-box.wide-2 .copy {
        margin-left: 142px; } }
  .product-image-box.default, .product-image-box.default-video {
    height: 100vw;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center; }
    .product-image-box.default::before, .product-image-box.default-video::before {
      content: "";
      position: absolute;
      display: block;
      left: 0;
      top: 0;
      width: 100%;
      height: 100%;
      background-color: rgba(0, 0, 0, 0.4);
      z-index: 2; }
    @media (min-width: 1150px) {
      .product-image-box.default, .product-image-box.default-video {
        width: 50vw;
        height: 33vw;
        flex-basis: 50vw; } }
    .product-image-box.default .title, .product-image-box.default-video .title {
      font-size: 24px;
      margin-bottom: 20px; }
      @media (min-width: 1150px) {
        .product-image-box.default .title, .product-image-box.default-video .title {
          font-size: 32px;
          line-height: 1; } }
    .product-image-box.default .subtitle, .product-image-box.default-video .subtitle {
      font-size: 14px; }
      @media (min-width: 1150px) {
        .product-image-box.default .subtitle, .product-image-box.default-video .subtitle {
          font-size: 16px;
          line-height: 1; } }
    .product-image-box.default .subtitle2, .product-image-box.default-video .subtitle2 {
      font-size: 14px; }
      @media (min-width: 1150px) {
        .product-image-box.default .subtitle2, .product-image-box.default-video .subtitle2 {
          font-size: 16px;
          line-height: 1; } }
    .product-image-box.default .note, .product-image-box.default-video .note {
      font-size: 10px;
      line-height: 1.0;
      position: absolute;
      bottom: 10px;
      right: 10px; }
    .product-image-box.default img, .product-image-box.default-video img {
      position: absolute;
      left: 0;
      top: 0;
      width: 100%;
      height: 100%;
      object-fit: cover;
      z-index: 1; }
    .product-image-box.default video, .product-image-box.default-video video {
      position: absolute;
      left: 0;
      top: 0;
      width: 100%;
      height: 100%;
      object-fit: cover;
      z-index: 1; }

.whats-inside {
  border-top: 1px solid #e5e5e5;
  text-align: center;
  padding-top: 37px;
  position: relative;
  overflow: hidden; }
  @media (min-width: 900px) {
    .whats-inside {
      display: flex;
      text-align: left;
      align-items: center;
      min-height: 56vw;
      height: 90vh;
      max-height: 1000px; }
      .whats-inside > * {
        flex-grow: 1;
        width: 50vw;
        flex-basis: 50vw; } }
  .whats-inside.gray-bg {
    border-top: none;
    background: linear-gradient(to bottom, #ffffff, #C9C9CA); }
    @media (min-width: 900px) {
      .whats-inside.gray-bg {
        background: linear-gradient(to bottom, #E3E2E3, #CECDCE); } }
  @media (min-width: 900px) {
    .whats-inside .left {
      padding-left: 140px; } }
  .whats-inside .headline {
    font-size: 12px;
    line-height: 24px;
    margin: 0;
    margin-bottom: 3px; }
    @media (min-width: 900px) {
      .whats-inside .headline {
        font-size: 20px;
        letter-spacing: 0.17px;
        margin-bottom: 40px; } }
  .whats-inside .labels {
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    text-anchor: center;
    margin-bottom: 30px; }
    .whats-inside .labels > * {
      display: block;
      margin: 0 auto; }
    .whats-inside .labels button {
      color: #9e9e9e;
      border-radius: 0; }
      .whats-inside .labels button.active {
        color: #000000; }
      @media (min-width: 900px) {
        .whats-inside .labels button {
          margin: 0; }
          .whats-inside .labels button:hover {
            color: #000000; } }
      .whats-inside .labels button .name {
        font-size: 24px;
        line-height: 80px;
        letter-spacing: -0.67px;
        font-weight: 400;
        margin: 0 auto; }
        @media (min-width: 900px) {
          .whats-inside .labels button .name {
            font-size: 32px;
            letter-spacing: -1.33px;
            line-height: 80px;
            text-align: left;
            margin: 0; } }
      .whats-inside .labels button .copy {
        white-space: pre-line;
        font-size: 12px;
        letter-spacing: -0.05px;
        line-height: 20px;
        margin: 0 auto;
        height: 0;
        overflow: hidden;
        transition: 300ms cubic-bezier(0.4, 0, 0.2, 1);
        opacity: 0; }
        @media (min-width: 900px) {
          .whats-inside .labels button .copy {
            font-size: 18px;
            letter-spacing: -0.08px;
            line-height: 27px;
            margin-bottom: 32px;
            text-align: left; } }
      .whats-inside .labels button.active .copy {
        height: 60px;
        opacity: 1; }
  .whats-inside .image-group {
    width: 100vw;
    height: 100vw;
    display: block;
    position: relative; }
    @media (min-width: 900px) {
      .whats-inside .image-group {
        width: 50vw;
        height: 50vw; } }
    .whats-inside .image-group img {
      width: 100%;
      height: 100%;
      position: absolute;
      top: 0;
      left: 0;
      object-fit: cover;
      object-position: left center; }
  .whats-inside .image-enter {
    opacity: 0.01; }
  .whats-inside .image-enter.image-enter-active {
    opacity: 1;
    transition: 500ms cubic-bezier(0.4, 0, 0.2, 1); }
  .whats-inside .image-leave {
    opacity: 1; }
  .whats-inside .image-leave.image-leave-active {
    opacity: 0.01;
    transition: 500ms cubic-bezier(0.4, 0, 0.2, 1); }
  @media (min-width: 900px) {
    .whats-inside .to-top .image-enter {
      transform: translateY(100%); }
    .whats-inside .to-top .image-enter.image-enter-active {
      transform: translateY(0%);
      transition: 300ms cubic-bezier(0.4, 0, 0.2, 1); }
    .whats-inside .to-top .image-leave {
      transform: translateY(0%); }
    .whats-inside .to-top .image-leave.image-leave-active {
      transition: 300ms cubic-bezier(0.4, 0, 0.2, 1);
      transform: translateY(-100%); }
    .whats-inside .to-bottom .image-enter {
      transform: translateY(-100%); }
    .whats-inside .to-bottom .image-enter.image-enter-active {
      transform: translateY(0%);
      transition: 300ms cubic-bezier(0.4, 0, 0.2, 1); }
    .whats-inside .to-bottom .image-leave {
      transform: translateY(0%); }
    .whats-inside .to-bottom .image-leave.image-leave-active {
      transition: 300ms cubic-bezier(0.4, 0, 0.2, 1);
      transform: translateY(100%); } }

.variant-picker {
  text-align: center; }
  @media (min-width: 720px) {
    .variant-picker {
      text-align: left;
      width: 280px; } }
  .variant-picker .colors {
    width: 100%;
    display: flex;
    justify-content: space-around; }
    @media (min-width: 720px) {
      .variant-picker .colors {
        justify-content: space-between; } }
    .variant-picker .colors button {
      text-decoration: none;
      opacity: 0.4;
      border-radius: 0; }
      .variant-picker .colors button.active {
        opacity: 1; }
      .variant-picker .colors button img {
        margin-bottom: 10px; }
      .variant-picker .colors button > * {
        display: block;
        margin: auto; }
  .variant-picker .lenses {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    margin: 0px auto 20px auto; }
    @media (min-width: 720px) {
      .variant-picker .lenses {
        justify-content: flex-start; } }
    .variant-picker .lenses p {
      flex-basis: 100%;
      color: #9e9e9e;
      margin-bottom: 12px;
      font-size: 1rem; }
      @media (min-width: 720px) {
        .variant-picker .lenses p {
          font-size: 14px; } }
    .variant-picker .lenses button {
      display: flex;
      align-items: center;
      opacity: 0.4;
      text-decoration: none; }
      .variant-picker .lenses button + button {
        margin-left: 50px; }
      .variant-picker .lenses button.active {
        opacity: 1; }
  .variant-picker .color-preview {
    display: block;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: #000000;
    margin-right: 5px; }
    .variant-picker .color-preview.moonlight {
      background: linear-gradient(-45deg, #606060 0%, #DCDCDC 100%); }
    .variant-picker .color-preview.eclipse {
      background: linear-gradient(-45deg, #282828 0%, #878787 100%); }
    .variant-picker .color-preview.daybreak {
      background: linear-gradient(-225deg, #FDDFCE 0%, #F7A47F 100%); }
    .variant-picker .color-preview.sunset {
      background: linear-gradient(-225deg, #FFBE87 0%, #EE3D25 98%); }
    .variant-picker .color-preview.twilight {
      background: linear-gradient(225deg, #004bff, #9392eb); }
    .variant-picker .color-preview.midnight {
      background: linear-gradient(45deg, #5f79b5, #002159); }

.specs3-header {
  position: relative; }
  .specs3-header .top {
    height: 86vh;
    min-height: 300px;
    position: relative; }
  .specs3-header img.main {
    position: absolute;
    z-index: 1;
    top: 10vh;
    left: 0;
    width: 100%;
    height: auto;
    display: block;
    opacity: 0;
    transform: translateY(0px);
    animation: fade-in 1500ms cubic-bezier(0.4, 0, 0.2, 1) forwards;
    animation-delay: 500ms; }
    @media (min-width: 1150px) {
      .specs3-header img.main {
        top: 0; } }
  .specs3-header.carbon .main-carbon {
    display: block; }
  .specs3-header.carbon .main-mineral {
    display: none; }
  .specs3-header.mineral .main-mineral {
    display: block; }
  .specs3-header.mineral .main-carbon {
    display: none; }
  .specs3-header .content {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    text-align: center;
    padding-bottom: 20px;
    z-index: 2; }
    .specs3-header .content .title {
      font-size: 32px;
      line-height: 24px;
      letter-spacing: 0.27px;
      margin: 0;
      margin-bottom: 20px; }
    .specs3-header .content .description {
      margin: 0; }
      @media (min-width: 1150px) {
        .specs3-header .content .description {
          margin: 0; } }
    .specs3-header .content .price {
      font-size: 24px;
      letter-spacing: 0.2px;
      margin: 0;
      margin-bottom: 15px; }
    .specs3-header .content .ATP, .specs3-header .content .prescription {
      font-size: 12px;
      letter-spacing: 0.2px;
      margin: 0;
      line-height: 1.3; }
    .specs3-header .content .add-to-cart {
      display: block;
      width: max-content;
      margin: 20px auto; }
    .specs3-header .content svg {
      margin-top: 60px; }
    @media (min-width: 1150px) {
      .specs3-header .content {
        display: grid;
        grid-template-columns: repeat(20, 1fr);
        grid-gap: 15px;
        padding: 0 45px;
        text-align: left;
        position: relative;
        grid-auto-rows: min-content;
        align-content: end;
        height: 100%;
        padding-bottom: 14vh; }
        .specs3-header .content .title, .specs3-header .content .price, .specs3-header .content .description, .specs3-header .content .color-selector, .specs3-header .content .add-to-cart, .specs3-header .content .ATP, .specs3-header .content .prescription {
          grid-column: 15 / span 5; }
        .specs3-header .content .title {
          font-size: 32px;
          letter-spacing: 0.33px;
          line-height: 24px;
          margin-bottom: 10px; }
        .specs3-header .content .price {
          font-size: 20px;
          line-height: 24px;
          letter-spacing: 0.27px;
          margin-bottom: unset; }
        .specs3-header .content .ATP {
          font-size: 12px;
          margin-top: -15px; }
        .specs3-header .content .description {
          font-size: 14px;
          line-height: 20px;
          letter-spacing: -0.63px; }
        .specs3-header .content .color-selector {
          justify-content: flex-start; }
        .specs3-header .content .add-to-cart {
          margin: 20px 0; }
        .specs3-header .content svg {
          position: absolute;
          bottom: -40px;
          left: 0;
          right: 0;
          margin: 0 auto; } }
  .specs3-header.mineral {
    background: linear-gradient(to bottom, #edd8b9, #c3a17e); }
    .specs3-header.mineral svg path {
      stroke: #ffffff; }
    .specs3-header.mineral a {
      color: #000000; }
  .specs3-header.carbon {
    background: linear-gradient(to bottom, #2e2e2e, #171717); }
    .specs3-header.carbon .title, .specs3-header.carbon .description {
      color: #ffffff; }
    .specs3-header.carbon .price, .specs3-header.carbon .ATP, .specs3-header.carbon .prescription, .specs3-header.carbon a {
      color: #9e9e9e; }
    .specs3-header.carbon svg path {
      stroke: #ffffff; }

@keyframes fade-in {
  from {
    opacity: 0;
    transform: translateY(10vh); }
  to {
    opacity: 1;
    transform: translateY(0px); } }

.specs3-slides {
  display: flex;
  flex-direction: column;
  scroll-snap-type: y mandatory; }
  .specs3-slides.mineral {
    background-color: #C3A07D;
    color: #000000; }
  .specs3-slides.carbon {
    background-color: #171717;
    color: #ffffff; }
  .specs3-slides .title, .specs3-slides .caption, .specs3-slides .subtitle, .specs3-slides .note {
    color: currentColor;
    position: relative;
    z-index: 2; }
  .specs3-slides .art {
    position: -webkit-sticky;
    position: sticky;
    bottom: 112px;
    width: 100vw;
    height: 100vw;
    z-index: 3;
    pointer-events: none;
    user-select: none;
    order: 2;
    overflow-x: hidden; }
    @media (min-width: 720px) {
      .specs3-slides .art {
        left: 0;
        bottom: -20vh;
        height: 100vh; } }
    @media (min-width: 1150px) {
      .specs3-slides .art {
        overflow-x: visible;
        top: 0;
        left: 0;
        height: 100vh;
        bottom: auto;
        width: 100vh;
        order: -1;
        position: fixed;
        z-index: 1; } }
    .specs3-slides .art > * {
      transform: translate3d(0, 0, 0);
      position: absolute;
      max-width: 100%;
      animation-duration: 1s;
      animation-fill-mode: forwards;
      animation-play-state: paused;
      animation-delay: var(--delay);
      display: none;
      transform-origin: center center; }
      .specs3-slides .art > *.visible {
        display: block; }
    .specs3-slides .art .slide-0.glasses {
      top: 38.9%;
      width: 92%;
      left: 4%;
      animation-name: slide0Glasses;
      will-change: opacity; }
    .specs3-slides .art .slide-0.lens-1 {
      position: absolute;
      width: 7.3%;
      top: 41.5%;
      left: 13.1%;
      animation-name: slide0Lens;
      will-change: opacity; }
    .specs3-slides .art .slide-0.lens-2 {
      position: absolute;
      width: 7.3%;
      top: 41.5%;
      right: 13.1%;
      animation-name: slide0Lens;
      will-change: opacity; }
    .specs3-slides .art .slide-1.image-left {
      position: absolute;
      width: 7.3%;
      top: 41.5%;
      left: 13.1%;
      animation-name: slide1ImgLeft;
      will-change: scale, opacity, rotateY, translateX; }
    .specs3-slides .art .slide-1.image-right {
      position: absolute;
      width: 7.3%;
      top: 41.5%;
      right: 13.1%;
      animation-name: slide1ImgRight;
      will-change: scale, opacity, rotateY, translateX; }
    .specs3-slides .art .slide-2.video-left, .specs3-slides .art .slide-2.video-mid, .specs3-slides .art .slide-2.video-right {
      width: 45%;
      height: auto;
      border-radius: 50%;
      top: 23%;
      overflow: hidden;
      height: 45%;
      will-change: opacity, translateY; }
      .specs3-slides .art .slide-2.video-left video, .specs3-slides .art .slide-2.video-mid video, .specs3-slides .art .slide-2.video-right video {
        width: 110%;
        top: -5%;
        left: -5%;
        position: relative; }
    .specs3-slides .art .slide-2.video-left {
      left: -25%;
      animation-name: slide2VidLeft; }
    .specs3-slides .art .slide-2.video-mid {
      left: 0;
      right: 0;
      margin: 0 auto;
      animation-name: slide2VidMid; }
    .specs3-slides .art .slide-2.video-right {
      right: -25%;
      animation-name: slide2VidRight; }
    .specs3-slides .art .slide-3 {
      animation-name: slide3mobile;
      width: 100%;
      height: 100%;
      will-change: opacity, translateX; }
      @media (min-width: 1150px) {
        .specs3-slides .art .slide-3 {
          animation-name: slide3; } }
      .specs3-slides .art .slide-3 img {
        bottom: 17%;
        position: absolute;
        right: 15%;
        width: 300px; }
        .specs3-slides .art .slide-3 img.fixed {
          position: absolute;
          left: 10%;
          bottom: 5%;
          width: 100%; }
      .specs3-slides .art .slide-3 .image-1 {
        width: 185px;
        right: 10%;
        bottom: 20%; }
        @media (min-width: 1150px) {
          .specs3-slides .art .slide-3 .image-1 {
            width: 55%;
            right: -6%;
            bottom: 20%; } }
      .specs3-slides .art .slide-3 .image-2 {
        width: 140px; }
        @media (min-width: 1150px) {
          .specs3-slides .art .slide-3 .image-2 {
            width: 300px; } }
      .specs3-slides .art .slide-3 .image-3 {
        width: 170px; }
        @media (min-width: 1150px) {
          .specs3-slides .art .slide-3 .image-3 {
            width: 360px;
            right: 10%; } }
      .specs3-slides .art .slide-3 .image-4 {
        width: 140px; }
        @media (min-width: 1150px) {
          .specs3-slides .art .slide-3 .image-4 {
            width: 300px; } }
      .specs3-slides .art .slide-3 .slide3-enter {
        opacity: 0;
        transform: translateX(50%); }
      .specs3-slides .art .slide-3 .slide3-enter.slide3-enter-active {
        opacity: 1;
        transition: 300ms cubic-bezier(0.4, 0, 0.2, 1);
        transform: translateX(0%); }
      .specs3-slides .art .slide-3 .slide3-leave {
        transform: translateX(0%);
        position: absolute;
        left: 0;
        width: 300px;
        opacity: 1; }
      .specs3-slides .art .slide-3 .slide3-leave.slide3-leave-active {
        transition: 300ms cubic-bezier(0.4, 0, 0.2, 1);
        opacity: 0;
        transform: translateX(-50%); }
  .specs3-slides.mineral .art {
    background: linear-gradient(0deg, #C3A07D 0%, #C3A07D 70%, rgba(192, 160, 125, 0) 100%); }
    @media (min-width: 1150px) {
      .specs3-slides.mineral .art {
        background: transparent; } }
  .specs3-slides.carbon .art {
    background: linear-gradient(0deg, #171717 70%, transparent 100%); }
    @media (min-width: 1150px) {
      .specs3-slides.carbon .art {
        background: transparent; } }
  .specs3-slides .slide {
    height: 100vh;
    width: 100vw;
    padding: 20px;
    text-align: center;
    display: flex;
    flex-direction: column;
    justify-content: center;
    scroll-snap-align: start; }
    .specs3-slides .slide button.basic {
      padding: 0;
      margin: 0;
      display: inline-block;
      color: currentColor;
      font-size: 1rem;
      width: max-content; }
      .specs3-slides .slide button.basic + button {
        margin-left: 10px; }
      .specs3-slides .slide button.basic.active {
        text-decoration: underline; }
    @media (min-width: 1150px) {
      .specs3-slides .slide {
        text-align: left;
        padding-left: 66.66666667vw;
        padding-right: 4vw; } }
    @media (min-width: 720px) {
      .specs3-slides .slide .title {
        margin-bottom: 0; } }
    @media (min-width: 1150px) {
      .specs3-slides .slide .title {
        font-size: 28px;
        line-height: 42px;
        letter-spacing: -0.89px; } }
    .specs3-slides .slide .subtitle {
      font-size: 32px;
      line-height: 35px;
      margin: 0; }
      @media (min-width: 1150px) {
        .specs3-slides .slide .subtitle {
          font-size: 28px;
          line-height: 35px;
          letter-spacing: -0.89px; } }
    .specs3-slides .slide .caption {
      font-size: 18px;
      line-height: 32px;
      letter-spacing: -0.05px; }
      @media (min-width: 720px) {
        .specs3-slides .slide .caption {
          font-size: 16px;
          line-height: 30px; } }
      @media (min-width: 1150px) {
        .specs3-slides .slide .caption {
          font-size: 15px;
          width: 97%; } }
    .specs3-slides .slide .note {
      font-size: 10px;
      line-height: 32px;
      letter-spacing: -0.05px; }

@keyframes slide0Glasses {
  0%, 30% {
    transform-origin: top right;
    transform: scale(2);
    opacity: 0; }
  44% {
    transform: scale(1);
    opacity: 1; }
  60% {
    opacity: 1; }
  75%, 100% {
    opacity: 0; } }

@keyframes slide0Lens {
  0%, 44% {
    opacity: 0; }
  60% {
    opacity: 1; }
  70% {
    opacity: 1; }
  80%, 100% {
    opacity: 0; } }

@keyframes slide1ImgLeft {
  0%, 20% {
    opacity: 0; }
  30% {
    opacity: 1;
    transform: scale(1) rotateY(0deg) translateX(0%); }
  38% {
    transform: scale(6) rotateY(55deg) translateX(100%); }
  44% {
    transform: scale(6) rotateY(55deg) translateX(100%); }
  55% {
    transform: scale(6) rotateY(0deg) translateX(75%); }
  70% {
    opacity: 1; }
  80% {
    opacity: 0; }
  100% {
    transform: scale(6) rotateY(0deg) translateX(75%);
    opacity: 0; } }

@keyframes slide1ImgRight {
  0%, 20% {
    opacity: 0; }
  30% {
    opacity: 1;
    transform: scale(1) rotateY(0deg) translateX(0%); }
  38% {
    transform: scale(6) rotateY(55deg) translateX(-100%); }
  44% {
    transform: scale(6) rotateY(55deg) translateX(-100%); }
  55% {
    transform: scale(6) rotateY(0deg) translateX(-75%); }
  70% {
    opacity: 1; }
  80% {
    opacity: 0; }
  100% {
    transform: scale(6) rotateY(0deg) translateX(-75%);
    opacity: 0; } }

@keyframes slide2VidLeft {
  0% {
    opacity: 0; }
  30% {
    opacity: 0;
    transform: translateY(100px); }
  50% {
    opacity: 1;
    transform: translateY(0px); }
  60% {
    transform: translateY(0px);
    opacity: 1; }
  80%, 100% {
    transform: translateY(-300px);
    opacity: 0; } }

@keyframes slide2VidMid {
  0% {
    opacity: 0; }
  5% {
    opacity: 1; }
  60% {
    transform: translateY(0px);
    opacity: 1; }
  80%, 100% {
    transform: translateY(-500px);
    opacity: 0; } }

@keyframes slide2VidRight {
  0% {
    opacity: 0; }
  30% {
    opacity: 0;
    transform: translateY(200px); }
  50% {
    opacity: 1;
    transform: translateY(0px); }
  60% {
    transform: translateY(0px);
    opacity: 1; }
  80%, 100% {
    transform: translateY(-700px);
    opacity: 0; } }

@keyframes slide3 {
  0%, 20% {
    opacity: 0;
    transform: translateX(-100%); }
  40%, 50% {
    opacity: 1;
    transform: translateX(0%); }
  60%, 100% {
    opacity: 0; } }

@keyframes slide3mobile {
  0%, 20% {
    opacity: 0;
    transform: translateX(-100%); }
  60%, 70% {
    opacity: 1;
    transform: translateX(0%); }
  80%, 100% {
    opacity: 0; } }

.spectacles-3-personality {
  padding-bottom: 64px; }
  .spectacles-3-personality .title {
    font-size: 24px;
    text-align: center;
    margin: 72px 28px; }
    @media (min-width: 720px) {
      .spectacles-3-personality .title {
        font-size: 32px;
        margin: 75px auto;
        white-space: pre-line;
        padding-bottom: 0px; } }
  .spectacles-3-personality .images {
    user-select: none;
    font-size: 0;
    white-space: nowrap;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 80px;
    cursor: grab; }
    .spectacles-3-personality .images.dragging {
      cursor: grabbing; }
    .spectacles-3-personality .images img {
      display: inline-block;
      height: 350px;
      pointer-events: none;
      user-select: none; }
      @media (min-width: 720px) {
        .spectacles-3-personality .images img {
          height: 600px; } }

.try-virtual {
  text-align: center;
  padding: 20px;
  flex-basis: 100%; }
  .try-virtual[data-portrait-order="1"] {
    order: 1; }
  .try-virtual[data-portrait-order="2"] {
    order: 2; }
  .try-virtual[data-portrait-order="3"] {
    order: 3; }
  .try-virtual[data-portrait-order="4"] {
    order: 4; }
  .try-virtual[data-portrait-order="5"] {
    order: 5; }
  .try-virtual[data-portrait-order="6"] {
    order: 6; }
  .try-virtual[data-portrait-order="7"] {
    order: 7; }
  .try-virtual[data-portrait-order="8"] {
    order: 8; }
  .try-virtual[data-portrait-order="9"] {
    order: 9; }
  .try-virtual[data-portrait-order="10"] {
    order: 10; }
  @media (min-width: 720px) {
    .try-virtual[data-landscape-order="1"] {
      order: 1; }
    .try-virtual[data-landscape-order="2"] {
      order: 2; }
    .try-virtual[data-landscape-order="3"] {
      order: 3; }
    .try-virtual[data-landscape-order="4"] {
      order: 4; }
    .try-virtual[data-landscape-order="5"] {
      order: 5; }
    .try-virtual[data-landscape-order="6"] {
      order: 6; }
    .try-virtual[data-landscape-order="7"] {
      order: 7; }
    .try-virtual[data-landscape-order="8"] {
      order: 8; }
    .try-virtual[data-landscape-order="9"] {
      order: 9; }
    .try-virtual[data-landscape-order="10"] {
      order: 10; } }
  @media (min-width: 720px) {
    .try-virtual {
      padding: 100px 0; } }
  .try-virtual img {
    height: 106px; }
  .try-virtual .headline {
    font-size: 32px;
    line-height: 36px;
    letter-spacing: -0.89px;
    margin: 0 auto;
    margin-bottom: 24px; }
    @media (min-width: 720px) {
      .try-virtual .headline {
        font-size: 32px;
        letter-spacing: -1.33px;
        line-height: 72px;
        margin-bottom: 10px; } }
  .try-virtual .copy {
    font-size: 16px;
    line-height: 24px;
    letter-spacing: -0.5px;
    max-width: 330px;
    margin: 0 auto;
    margin-bottom: 40px; }
    @media (min-width: 720px) {
      .try-virtual .copy {
        font-size: 18px;
        max-width: 373px; } }

.try-store {
  padding: 170px 0px;
  text-align: center;
  background-size: cover;
  background-position: center center;
  position: relative;
  z-index: 2; }
  .try-store::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 1;
    background-color: #292929;
    opacity: 0.62; }
  .try-store .headline, .try-store .copy, .try-store .button {
    position: relative;
    z-index: 2; }
  .try-store .headline, .try-store .copy {
    color: #ffffff; }
  .try-store .headline {
    font-size: 32px;
    letter-spacing: -0.89px;
    line-height: 72px;
    margin: 0; }
    @media (min-width: 720px) {
      .try-store .headline {
        font-size: 32px;
        line-height: 72px;
        letter-spacing: -1.33px;
        margin-bottom: 15px; } }
  .try-store .copy {
    max-width: 300px;
    margin: 0 auto;
    font-size: 16px;
    line-height: 24px;
    letter-spacing: -0.44px;
    margin-bottom: 28px; }
    @media (min-width: 720px) {
      .try-store .copy {
        font-size: 18px;
        line-height: 24px;
        letter-spacing: -0.05px;
        max-width: none;
        margin-bottom: 40px; } }

.creators-cta {
  background-color: #000000;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center; }
  .creators-cta .title, .creators-cta .caption, .creators-cta p, .creators-cta a {
    color: #ffffff; }
  .creators-cta .button {
    color: #000000; }
  .creators-cta .title {
    white-space: pre-line; }
  .creators-cta .caption {
    width: 290px;
    margin: 5px auto 32px; }
  .creators-cta .images {
    overflow-x: auto;
    overflow-y: hidden;
    white-space: nowrap;
    width: 100%; }
    @media (min-width: 720px) {
      .creators-cta .images {
        overflow-x: unset;
        overflow-y: unset; } }
  .creators-cta .creator {
    display: inline-block; }
    .creators-cta .creator a {
      display: block;
      text-decoration: none;
      display: flex;
      justify-content: center;
      align-items: center;
      flex-direction: column; }
    .creators-cta .creator img {
      order: 3;
      width: 178px;
      height: 251px;
      object-fit: cover;
      object-position: center; }
    .creators-cta .creator p {
      order: 2;
      font-size: 14px; }
  .creators-cta .button {
    margin-bottom: 79px; }
  @media (min-width: 720px) {
    .creators-cta {
      padding-top: 77px;
      padding-bottom: 230px; }
      .creators-cta .title {
        font-size: 32px;
        letter-spacing: 0.4px;
        line-height: 1;
        margin-bottom: 10px; }
      .creators-cta .caption {
        font-size: 16px;
        line-height: 1.5;
        width: 470px; }
      .creators-cta .subcaption {
        font-size: 16px;
        line-height: 1.5;
        width: 470px; }
      .creators-cta .images {
        order: 3;
        height: 230px;
        margin-bottom: 0; }
      .creators-cta .creator a {
        transition: opacity 150ms cubic-bezier(0.4, 0, 0.2, 1); }
      .creators-cta .creator p {
        transition: all 150ms cubic-bezier(0.4, 0, 0.2, 1);
        color: #9e9e9e;
        font-size: 16px; }
      .creators-cta .creator img {
        width: 20vw;
        height: auto; }
      .creators-cta .creator:hover p {
        color: #ffffff; }
      .creators-cta .button {
        margin-bottom: 60px; } }

.buy-bar {
  transition: 250ms cubic-bezier(0.4, 0, 0.2, 1);
  background-color: #fffc00;
  position: -webkit-sticky;
  position: sticky;
  bottom: 0;
  width: 100%;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  z-index: 10;
  padding-top: 7px;
  transform: translate3d(0, 92px, 0);
  will-change: translate3d; }
  .buy-bar.active {
    transform: translate3d(0, 0, 0); }
  @media (min-width: 1150px) {
    .buy-bar {
      padding-top: 0px;
      padding-bottom: 0px; } }
  .buy-bar .name {
    font-size: 12px;
    line-height: 12px;
    flex-grow: 1;
    margin-left: 20px;
    flex-basis: 100px; }
    @media (min-width: 1150px) {
      .buy-bar .name {
        font-size: 18px;
        margin-left: 30px;
        line-height: 12px; } }
  .buy-bar .price {
    font-size: 12px;
    line-height: 12px;
    margin-right: 20px; }
    @media (min-width: 1150px) {
      .buy-bar .price {
        font-size: 12px; } }
  .buy-bar button {
    margin-right: 20px; }
    @media (min-width: 1150px) {
      .buy-bar button {
        font-size: 12px;
        height: 35px;
        padding: 10px 28px; } }
  .buy-bar .prescription {
    font-size: 10px;
    line-height: 24px;
    color: #000000;
    flex-basis: 100%;
    background-color: #ffffff;
    text-align: center;
    margin: 0;
    margin-top: 20px; }
    .buy-bar .prescription a {
      color: currentColor; }
    @media (min-width: 1150px) {
      .buy-bar .prescription {
        flex-basis: auto;
        background-color: transparent;
        margin: 0;
        margin-right: 30px;
        font-size: 18px; } }
  .buy-bar .ATP {
    font-size: 10px;
    line-height: 24px;
    color: #000000;
    flex-basis: 100%;
    background-color: #ffffff;
    text-align: center;
    margin: 0;
    margin-top: 7px; }
    @media (min-width: 1150px) {
      .buy-bar .ATP {
        flex-basis: auto;
        background-color: transparent;
        margin: 0;
        margin-right: 30px;
        font-size: 12px; } }
    .buy-bar .ATP.holiday span {
      transition: 250ms ease;
      color: #999999;
      cursor: pointer;
      padding-left: 5px;
      text-decoration: underline; }
      .buy-bar .ATP.holiday span:hover {
        color: #000000; }

.creators-spectacles-3-cta {
  padding-top: 83px;
  padding-bottom: 41px;
  text-align: center; }
  .creators-spectacles-3-cta h2, .creators-spectacles-3-cta a {
    color: currentColor; }
  .creators-spectacles-3-cta img {
    margin-bottom: 42px;
    width: 100%; }
  .creators-spectacles-3-cta.mineral {
    background: linear-gradient(to bottom, #edd8b9, #c3a17e);
    color: #000000; }
  .creators-spectacles-3-cta.carbon {
    background: linear-gradient(to bottom, #2e2e2e, #171717);
    color: #ffffff; }
  @media (min-width: 720px) {
    .creators-spectacles-3-cta {
      position: relative;
      display: flex;
      flex-direction: column;
      justify-content: flex-end;
      padding: 80px; }
      .creators-spectacles-3-cta h2 {
        font-size: 32px; }
      .creators-spectacles-3-cta img {
        position: absolute;
        left: 0;
        top: 0;
        width: 100%;
        height: 80%;
        object-fit: cover; }
      .creators-spectacles-3-cta .button {
        width: max-content;
        margin: 0 auto;
        display: block; } }

.creators-form {
  background-color: #000000;
  text-align: center; }
  .creators-form h2, .creators-form p, .creators-form label, .creators-form input {
    color: #ffffff;
    margin: 0;
    display: block; }
  .creators-form h2 {
    margin-bottom: 10px; }
  .creators-form p {
    font-size: 16px;
    line-height: 1.5;
    color: #999999; }
  .creators-form img {
    margin: 40px auto; }
  .creators-form .field {
    position: relative;
    margin-bottom: 25px; }
    .creators-form .field label {
      position: absolute;
      top: 50%;
      left: 0;
      transform: translateY(-50%);
      pointer-events: none;
      user-select: none;
      font-size: 12px;
      opacity: 0;
      user-select: none; }
    .creators-form .field input {
      border-radius: 0;
      border: 0;
      background-color: transparent;
      width: 100%;
      padding: 15px 0;
      border-bottom: 1px solid #333333; }
    .creators-form .field.select {
      border-bottom: 1px solid #333333;
      text-align: left; }
      .creators-form .field.select label {
        position: relative;
        padding: 15px 0;
        transform: none;
        left: auto;
        top: auto;
        opacity: 1; }
      .creators-form .field.select select {
        appearance: none;
        width: 100%;
        height: 100%;
        position: absolute;
        opacity: 0;
        top: 0;
        left: 0; }
      .creators-form .field.select::after {
        content: '\25BC';
        color: #ffffff;
        position: absolute;
        top: 50%;
        transform: translateY(-76%) scaleY(0.5);
        right: 0;
        font-size: 13px; }
  .creators-form .newsletter input {
    opacity: 0;
    position: absolute;
    left: -999px; }
  .creators-form .newsletter label {
    display: flex;
    text-align: left;
    color: #999999;
    font-size: 10px;
    line-height: 2;
    position: relative; }
    .creators-form .newsletter label::before {
      content: "";
      display: block;
      width: 16px;
      height: 16px;
      border: 2px solid #ffffff;
      border-radius: 50%;
      flex-shrink: 0;
      margin-right: 20px;
      position: relative;
      top: 3px; }
  .creators-form .newsletter input:checked + label::after {
    content: "";
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background-color: #ffffff;
    display: block;
    position: absolute;
    left: 6px;
    top: 9px; }
  .creators-form button {
    margin-top: 37px; }
  @media (min-width: 720px) {
    .creators-form h2 {
      font-size: 32px; }
    .creators-form p {
      max-width: 493px;
      margin: 0 auto; }
    .creators-form img {
      margin: 25px auto 7px; }
    .creators-form form {
      max-width: 320px;
      margin: 0 auto; } }

.creators-content {
  position: relative;
  z-index: 2;
  background-color: #000000;
  color: #ffffff; }
  @media (min-width: 720px) {
    .creators-content {
      padding-top: 32px; } }
  .creators-content .selector {
    white-space: nowrap;
    overflow-x: auto;
    padding: 30px;
    width: 100%; }
    @media (min-width: 720px) {
      .creators-content .selector {
        display: flex;
        justify-content: space-around; } }
    .creators-content .selector button {
      display: inline-block;
      color: #9e9e9e;
      font-size: 12px;
      letter-spacing: -0.05px;
      line-height: 32px;
      padding: 0;
      margin: 0;
      transition: color 150ms cubic-bezier(0.4, 0, 0.2, 1); }
      .creators-content .selector button:hover {
        color: #ffffff; }
      .creators-content .selector button.active {
        color: #fffc00; }
      .creators-content .selector button + button {
        margin-left: 54px; }
        @media (min-width: 720px) {
          .creators-content .selector button + button {
            margin-left: 0; } }
  .creators-content .creator-container {
    position: relative;
    display: block;
    width: 100%; }
    .creators-content .creator-container .creator-enter {
      opacity: 0; }
    .creators-content .creator-container .creator-enter.creator-enter-active {
      opacity: 1;
      transition: 500ms cubic-bezier(0.4, 0, 0.2, 1);
      transform: translateX(0%); }
    .creators-content .creator-container .creator-leave {
      transform: translateX(0%);
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      opacity: 1; }
    .creators-content .creator-container .creator-leave.creator-leave-active {
      transition: 500ms cubic-bezier(0.4, 0, 0.2, 1);
      opacity: 0; }
  .creators-content .to-left .creator-enter {
    transform: translateX(100%); }
  .creators-content .to-left .creator-leave.creator-leave-active {
    transform: translateX(-100%); }
  .creators-content .to-right .creator-enter {
    transform: translateX(-100%); }
  .creators-content .to-right .creator-leave.creator-leave-active {
    transform: translateX(100%); }
  .creators-content .creator {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-around;
    align-items: center;
    padding: 46px 46px 0; }
    .creators-content .creator > * {
      flex-basis: 400px;
      flex-grow: 1;
      max-width: 500px; }
  .creators-content .video-player {
    margin-bottom: 80px;
    height: 400px; }
  @media (min-width: 1000px) {
    .creators-content .video-player {
      margin-bottom: 0;
      height: 600px; } }
  @media (min-width: 720px) {
    .creators-content .content {
      order: 2; } }
  .creators-content .content img {
    width: 246px;
    height: 246px;
    border-radius: 50%;
    object-fit: cover;
    display: block;
    margin: 0 auto 32px; }
  .creators-content .content p {
    margin: 0; }
  .creators-content .content blockquote {
    margin: 0; }
    @media (min-width: 720px) {
      .creators-content .content blockquote {
        margin: auto;
        max-width: 75%; } }
    .creators-content .content blockquote p {
      color: #9e9e9e;
      font-size: 18px;
      letter-spacing: -0.11px;
      line-height: 30px;
      margin-bottom: 32px; }
    .creators-content .content blockquote .subintro {
      margin: 0; }
  .creators-content .content small, .creators-content .content blockquote footer {
    color: #fffc00;
    font-size: 14px;
    letter-spacing: -0.07px;
    line-height: 24px; }

.creators-community {
  background-color: #ffffff;
  position: relative;
  z-index: 2;
  padding-top: 70px; }
  @media (min-width: 720px) {
    .creators-community {
      padding-bottom: 70px; } }
  .creators-community .title {
    font-size: 32px;
    line-height: 64px;
    text-align: center;
    margin: 0 25px 10px; }
  .creators-community .caption {
    font-size: 16px;
    line-height: 24px;
    text-align: center;
    white-space: pre-line;
    max-width: 270px;
    margin: 0 auto; }
    @media (min-width: 720px) {
      .creators-community .caption {
        max-width: none; } }
  .creators-community .social {
    margin: 20px auto; }
    @media (min-width: 720px) {
      .creators-community .social {
        margin: 50px auto; } }
    .creators-community .social ul {
      margin: 0;
      padding: 0;
      list-style: none;
      display: flex;
      justify-content: center;
      align-items: center; }
      .creators-community .social ul a {
        transition: 300ms cubic-bezier(0.4, 0, 0.2, 1);
        padding: 10px; }
        .creators-community .social ul a:hover img {
          transform: scale(1.1);
          transform-origin: center center;
          transition: 150ms cubic-bezier(0.4, 0, 0.2, 1); }
      .creators-community .social ul img {
        width: 30px; }
  .creators-community .videos img, .creators-community .videos video {
    width: 100%;
    border-radius: 50%;
    object-fit: cover; }
  .creators-community .videos .glide__slide {
    opacity: 0.7;
    transform: scale(0.85);
    transform-origin: center center;
    transition: 500ms cubic-bezier(0.4, 0, 0.2, 1); }
    .creators-community .videos .glide__slide .video-caption {
      opacity: 0;
      text-align: center;
      font-size: 16px;
      color: #9e9e9e;
      line-height: 24px; }
  .creators-community .videos .glide__slide--active {
    opacity: 1;
    transform: scale(1); }
    .creators-community .videos .glide__slide--active .video-caption {
      opacity: 1; }

.video-player {
  width: 100%; }
  .video-player .video-container {
    position: relative; }
    .video-player .video-container:hover .play {
      background-color: rgba(255, 255, 255, 0.2); }
    .video-player .video-container::after {
      content: '';
      position: absolute;
      width: 100%;
      height: 100%;
      top: 0;
      left: 0;
      background-color: rgba(0, 0, 0, 0.5);
      z-index: 3;
      pointer-events: none; }
    .video-player .video-container::after, .video-player .video-container .play {
      opacity: 1;
      transition: opacity 0.25s cubic-bezier(0.4, 0, 0.2, 1); }
    .video-player .video-container video {
      position: relative;
      border-radius: 50%;
      width: 100%;
      height: auto;
      z-index: 2;
      cursor: pointer; }
    .video-player .video-container .play {
      transition: all 150ms cubic-bezier(0.4, 0, 0.2, 1);
      position: absolute;
      left: 0;
      right: 0;
      margin: 0 auto;
      top: 50%;
      transform: translateY(-50%);
      z-index: 4;
      border-radius: 50%;
      border: 2px solid #ffffff;
      display: flex;
      justify-content: center;
      align-items: center;
      width: 60px;
      height: 60px; }
    .video-player .video-container.playing::after {
      opacity: 0; }
    .video-player .video-container.playing .play {
      opacity: 0; }
  .video-player .controls {
    display: flex;
    align-items: center;
    margin-top: 75px; }
    .video-player .controls .play {
      margin-right: 8px;
      font-size: 0;
      padding: 0;
      border-radius: 0; }
      .video-player .controls .play path {
        fill: #fffc00; }
    .video-player .controls .progress {
      flex-grow: 1;
      height: 2px;
      background-color: #9e9e9e;
      position: relative; }
      .video-player .controls .progress div {
        transform: scaleX(0);
        background-color: #fffc00;
        width: 100%;
        height: 100%;
        position: absolute;
        top: 0;
        left: 0;
        transform-origin: left; }

.creators-lens-studio {
  background-color: #F4F4F4;
  position: relative; }
  @media (min-width: 320px) {
    .creators-lens-studio {
      flex-direction: column-reverse !important;
      display: flex;
      padding: 60px 30px; } }
  @media (min-width: 720px) {
    .creators-lens-studio {
      display: flex;
      align-items: center;
      flex-direction: row !important;
      padding: 70px; }
      .creators-lens-studio .content {
        flex-basis: 46%;
        width: 46%; }
      .creators-lens-studio .video {
        flex-basis: 54%;
        width: 54%;
        margin-top: 45px; }
      .creators-lens-studio > * {
        flex-grow: 1; } }
    @media (min-width: 720px) and (min-width: 720px) and (max-width: 930px) {
      .creators-lens-studio > * {
        flex-basis: 100% !important;
        width: 100% !important; } }
  @media (min-width: 720px) and (max-width: 930px) {
    .creators-lens-studio {
      flex-direction: column !important; } }
  @media (min-width: 1150px) {
    .creators-lens-studio {
      display: flex;
      align-items: center;
      padding: 156px 110px 156px 140px; }
      .creators-lens-studio > * {
        flex-grow: 1; }
      .creators-lens-studio .content {
        flex-basis: 46%;
        width: 46%; }
      .creators-lens-studio .video {
        flex-basis: 54%;
        width: 54%;
        margin-top: 45px; } }
  .creators-lens-studio .headline, .creators-lens-studio .sub-heading {
    color: #000000;
    padding: 0 40px; }
    @media (min-width: 320px) {
      .creators-lens-studio .headline, .creators-lens-studio .sub-heading {
        padding: 0;
        text-align: center; } }
    @media (min-width: 720px) {
      .creators-lens-studio .headline, .creators-lens-studio .sub-heading {
        padding: 0;
        text-align: left; } }
    @media (min-width: 720px) and (max-width: 930px) {
      .creators-lens-studio .headline, .creators-lens-studio .sub-heading {
        text-align: center; } }
    @media (min-width: 1150px) {
      .creators-lens-studio .headline, .creators-lens-studio .sub-heading {
        padding: 0; } }
  .creators-lens-studio .headline {
    font-size: 32px;
    line-height: 35px;
    margin: 0 0 38px 0; }
    @media (min-width: 1150px) {
      .creators-lens-studio .headline {
        font-size: 28px;
        line-height: 35px;
        letter-spacing: -0.89px; } }
  .creators-lens-studio .sub-heading {
    font-size: 18px;
    line-height: 32px;
    letter-spacing: -0.05px;
    margin: 0; }
    @media (min-width: 720px) {
      .creators-lens-studio .sub-heading {
        font-size: 16px;
        line-height: 30px; } }
    @media (min-width: 1150px) {
      .creators-lens-studio .sub-heading {
        font-size: 15px;
        line-height: 28px;
        letter-spacing: -0.05px;
        max-width: 80%; } }
  .creators-lens-studio .icon {
    display: block;
    margin: 0 auto 60px auto; }
    @media (min-width: 320px) {
      .creators-lens-studio .icon {
        max-width: 120px;
        margin: 70px auto 30px auto; } }
    @media (min-width: 720px) {
      .creators-lens-studio .icon {
        margin: 0 auto 60px auto;
        max-width: 100px; } }
    @media (min-width: 1150px) {
      .creators-lens-studio .icon {
        max-width: 125px;
        margin: 0 0 60px 128px; } }
  @media (min-width: 320px) {
    .creators-lens-studio .content {
      padding: 0; } }
  @media (min-width: 720px) {
    .creators-lens-studio .content {
      padding: 0 60px 0 0; } }
  @media (min-width: 720px) and (max-width: 930px) {
    .creators-lens-studio .content {
      padding: 0 !important; } }
  .creators-lens-studio .video video {
    width: 100%;
    height: auto; }
  .creators-lens-studio .links {
    display: inline-block; }
    @media (min-width: 320px) {
      .creators-lens-studio .links {
        display: flex;
        flex-direction: row;
        margin-top: 30px;
        justify-content: center; }
        .creators-lens-studio .links a {
          margin: 0 8px 0 0 !important; }
          .creators-lens-studio .links a.two {
            margin-right: 0 !important; } }
    @media (min-width: 720px) {
      .creators-lens-studio .links {
        justify-content: flex-start; }
        .creators-lens-studio .links a {
          margin: 0 8px 0 0 !important; }
          .creators-lens-studio .links a.two {
            margin-right: 0 !important; } }
    @media (min-width: 720px) and (max-width: 930px) {
      .creators-lens-studio .links {
        display: flex;
        flex-direction: row;
        justify-content: center; } }
    @media (min-width: 320px) {
      .creators-lens-studio .links a.button {
        margin: 0 auto 15px auto; } }
    @media (min-width: 720px) {
      .creators-lens-studio .links a.button {
        margin-left: 15px;
        margin-top: 38px; }
        .creators-lens-studio .links a.button.one {
          margin-left: 0; } }

.harmony-sub {
  padding-bottom: 64px; }
  .harmony-sub .title {
    font-size: 24px;
    text-align: center;
    margin: 72px 28px; }
    @media (min-width: 720px) {
      .harmony-sub .title {
        font-size: 32px;
        margin: 75px auto;
        white-space: pre-line;
        padding-bottom: 0px; } }
    .harmony-sub .title span {
      display: inline-block;
      font-size: 50%;
      margin-top: 32px; }
  .harmony-sub .images {
    user-select: none;
    font-size: 0;
    white-space: nowrap;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 0px;
    cursor: grab; }
    .harmony-sub .images.dragging {
      cursor: grabbing; }
    .harmony-sub .images img {
      display: inline-block;
      height: 350px;
      pointer-events: none;
      user-select: none; }
      @media (min-width: 720px) {
        .harmony-sub .images img {
          height: 600px; } }
  .harmony-sub .yellow-bar {
    background: #fffc00;
    width: 100%;
    padding: 54px 28px 36px 28px;
    text-align: center; }
    .harmony-sub .yellow-bar p {
      font-family: "Graphik";
      color: #000000;
      font-size: 13px;
      margin: 0; }
      .harmony-sub .yellow-bar p.caption {
        margin-bottom: 4px; }
      .harmony-sub .yellow-bar p.headline {
        font-size: 24px;
        margin-bottom: 12px; }
      .harmony-sub .yellow-bar p.detail {
        margin: 0;
        line-height: 22px; }
