/*
 *  Copyright 2016 Adobe Systems Incorporated
 *
 *  Licensed under the Apache License, Version 2.0 (the "License");
 *  you may not use this file except in compliance with the License.
 *  You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 *  Unless required by applicable law or agreed to in writing, software
 *  distributed under the License is distributed on an "AS IS" BASIS,
 *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 *  See the License for the specific language governing permissions and
 *  limitations under the License.
 */

.xf-content-height {
  min-height: 46px;
  margin: 0 -12px;
}
#__next {
  min-block-size: 100vh;
}

#S02Footer {
  --container-max-width: 100%;
  --container-padding: 25px;
  --light-spruce: 242, 246, 245;
  --sustainability-spruce: 0, 74, 58;
  --aloe: 128, 222, 154;
  --squid-ink: 22, 29, 38;
  --pistachio: 213, 240, 216;
  --white: 255, 255, 255;

  --ember-modern-display: "Ember Modern Display", sans-serif;
  --amazon-ember: "Amazon Ember", sans-serif;

  font-family: var(--ember-modern-display-standard, var(--ember-modern-display));
  position: relative;
  z-index: 7;
}

#S02Footer svg {
  display: block;
  height: 100%;
  width: 100%;
}

#S02Footer .visually-hidden {
  clip-path: inset(50%);
  block-size: 1px;
  overflow: hidden;
  position: absolute;
  white-space: nowrap;
  inline-size: 1px;
}

#S02Footer .footer-content {
  background-color: rgb(var(--squid-ink));
}

#S02Footer .container {
  padding-top: 48px;
  padding-bottom: 56px;
  max-width: var(--container-max-width);
  padding-inline: var(--container-padding);
  margin: 0 auto;
}

#S02Footer .links-wrapper {
  display: flex;
  justify-content: space-between;
  flex-direction: column;
  padding-right: 24px;
}

#S02Footer .main-links {
  margin-bottom: 48px;
}

#S02Footer .main-links .main-links-list {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

#S02Footer .main-links .main-link-list-item {
  padding-right: 28px;
}

#S02Footer .main-links .main-link-item {
  position: relative;
  color: rgb(var(--light-spruce));
  transition: color 0.4s ease-in-out;
  text-decoration: none;
  font-size: 1.125rem;
  font-weight: 400;
  line-height: 1.33;
  letter-spacing: .015em;
}

#S02Footer .link-icon [data-component="icon"] {
  display: inline-block;
  vertical-align: middle;
  width: 24px;
  height: 24px;
  pointer-events: none;
}

#S02Footer .main-links .main-link-item .link-icon [data-component="icon"] {
  position: absolute;
  bottom: 0;
  margin-bottom: -2px;
  right: -28px;
}

#S02Footer .main-links .main-link-item:focus-visible {
  outline: 2px solid rgb(var(--aloe));
  outline-offset: 2px;
  border-radius: 2px;
}

#S02Footer .main-links .main-link-item:focus-visible .link-icon [data-component="icon"] {
  outline: 2px solid rgb(var(--aloe));
  outline-offset: 2px;
  border-radius: 2px;
}

#S02Footer .main-links .main-link-item:hover {
  color: rgb(var(--aloe));
}

#S02Footer .secondary-links {
  display: flex;
  flex-direction: column;
  width: 100%;
  gap: 40px;
}

#S02Footer .secondary-links .links-column .secondary-links-list {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

#S02Footer .secondary-links .links-column .secondary-link-item {
  position: relative;
  color: rgba(var(--light-spruce), 0.8);
  transition: color 0.4s ease-in-out;
  text-decoration: none;
  font-size: 1.125rem;
  font-weight: 400;
  line-height: .89;
  letter-spacing: .03em;
}

#S02Footer .secondary-links .links-column .secondary-link-item .link-icon [data-component="icon"] {
  position: absolute;
  margin-bottom: -3px;
  bottom: 0;
  right: -28px;
}

#S02Footer .secondary-links .links-column .secondary-link-item:focus-visible {
  outline: 2px solid rgb(var(--aloe));
  outline-offset: 2px;
  border-radius: 2px;
}

#S02Footer .secondary-links .links-column .secondary-link-item:focus-visible .link-icon [data-component="icon"] {
  outline: 2px solid rgb(var(--aloe));
  outline-offset: 2px;
  border-radius: 2px;
}

#S02Footer .secondary-links .links-column .secondary-link-item:hover {
  color: rgb(var(--aloe));
}

#S02Footer .logo-and-copyright {
  display: flex;
  flex-direction: column;
  border-top: 1px solid rgba(var(--white), 0.15);
  margin-top: 48px;
  padding-top: 32px;
  align-items: baseline;
}

#S02Footer .logo-wrapper {
  width: 100%;
  height: 28px;
  margin-bottom: 28px;
  display: flex;
  justify-content: space-between;
}

#S02Footer .logo-wrapper .logo [data-component="icon"] {
  width: 68px;
  height: 40px;
  color: rgb(var(--white));
  display: inline-block;
}

#S02Footer .logo-wrapper svg {
  width: 100%;
  height: 100%;
}

#S02Footer .copyright-mobile,
#S02Footer .copyright-desktop {
  font-family: var(--amazon-ember);
  font-size: 14px;
  line-height: 1.4;
  color: rgba(var(--light-spruce), 0.7);
}

#S02Footer .copyright-mobile {
  color: rgba(var(--light-spruce), 0.7);
}

#S02Footer .copyright-desktop {
  display: none;
}

#S02Footer .left-content-wrapper {
  display: flex;
  align-items: center;
}

#S02Footer .left-content-wrapper > a:focus-visible {
  outline: 2px solid rgb(var(--aloe));
  outline-offset: 2px;
  border-radius: 2px;
}

#S02Footer .sustainability-label {
  color: rgb(var(--light-spruce));
  font-size: 18px;
  font-weight: 700;
  line-height: 1.33;
}

#S02Footer .sustainability-label:focus-visible {
  outline: 2px solid rgb(var(--aloe));
  outline-offset: 2px;
  border-radius: 2px;
}

@media (min-width: 768px) {
  #S02Footer .main-links .main-links-list {
    gap: 32px;
  }

  #S02Footer .main-links .main-link-item .link-icon [data-component="icon"] {
    margin-bottom: unset;
  }

  #S02Footer .secondary-links {
    flex-direction: row;
    gap: 24px;
  }

  #S02Footer .links-column {
    width: 100%;
    max-width: 280px;
  }

  #S02Footer .logo-and-copyright {
    flex-direction: column;
    justify-content: space-between;
    width: 100%;
  }

  #S02Footer .logo-wrapper {
    margin-bottom: 0;
  }

  #S02Footer .copyright-mobile {
    display: none;
  }

  #S02Footer .copyright-desktop {
    display: flex;
    align-self: end;
    margin-left: 26px;
  }

  #S02Footer .copyright-mobile {
    padding-left: 75px;
    max-width: 100%;
  }
}

@media (min-width: 1280px) {
  #S02Footer {
    --container-max-width: 1920px;
    --container-padding: 60px;
  }

  #S02Footer .sustainability-label {
    font-size: clamp(1.25rem,.25rem + 1.25vw,1.75rem);
    line-height: 1.143;
  }

  #S02Footer .container {
    padding-top: 88px;
    padding-bottom: 48px;
  }

  #S02Footer .main-links {
    min-width: 584px;
    margin-bottom: 0;
  }

  #S02Footer .main-links .main-link-item {
    font-size: clamp(1rem, 1.25vw, 1.5rem);
    line-height: 1.37;
  }

  #S02Footer .secondary-links .links-column .secondary-link-item {
    font-size: clamp(.875rem, .375rem + .625vw, 1.125rem);
  }

  #S02Footer .secondary-links {
    justify-content: flex-end;
  }

  #S02Footer .links-wrapper {
    flex-direction: row;
    justify-content: space-between;
    padding-right: unset;
  }

  #S02Footer .logo-and-copyright {
    margin-top: 88px;
  }

  #S02Footer .logo-wrapper {
    width: 100%;
    height: 32px;
    margin-bottom: 0;
  }

  #S02Footer .logo-wrapper .logo [data-component="icon"] {
    width: 110px;
    height: 49px;
  }

  #S02Footer .copyright-desktop {
    margin-left: 56px;
    font-size: clamp(.75rem, .25rem + .625vw, 1rem);
    line-height: 1.5;
  }

  #S02Footer .copyright-mobile {
    padding-left: 150px;
  }
}

@media (min-width: 1680px) {
  #S02Footer .main-links .main-link-item {
    line-height: 1.33;
  }
}

@media (min-width: 1920px) {
  #S02Footer .extra-large-wrapper {
    background-color: rgb(var(--squid-ink));
  }
}

body .xf-content-height {
  min-height: unset;
  margin: unset;
}

body:has([data-component="c02-2-secondary-hero"])
  #S01NavigationWrapper
  #S01Navigation.closed {
  background: rgb(229, 237, 235);
}

#S01NavigationWrapper {
  --grid-columns: 12;
  --grid-gap: 24px;
  --container-padding: 60px;
  --grid-padding: var(--container-padding);
  --grid-width: calc(100vw - var(--grid-padding) * 2);
  --grid-column-width: calc(
    (var(--grid-width) - (var(--grid-gap) * (var(--grid-columns) - 1))) /
      var(--grid-columns)
  );
  display: flex;
}

#S01NavigationOverlay {
  background: transparent;
  transition: background 0.4s ease-in-out;
}

#S01Navigation.opened + #S01NavigationOverlay {
  position: fixed;
  width: 100%;
  height: 100%;
  z-index: 2;
  top: 0;
  left: 0;
}

#S01Navigation.opened + #S01NavigationOverlay {
  @media screen and (min-width: 1279px) {
    background: rgba(242, 246, 245, 0.3);
  }
}

.skipToContentWrapper {
  --squid-ink: #161d26;
  --pistachio: #d5f0d8;
  position: fixed;
  top: 132px;
  z-index: 10;
  margin-inline-start: 4px;
}

.skipToContent {
  clip-path: inset(50%);
  block-size: 1px;
  overflow: hidden;
  position: absolute;
  white-space: nowrap;
  inline-size: 1px;
}

.skipToContent:focus-visible {
  position: relative;
  block-size: unset;
  inline-size: unset;
  clip-path: unset;

  font-family: "Ember Modern Display Standard", sans-serif;
  padding: 24px;
  border-radius: 4px;
  background: var(--squid-ink);
  color: var(--pistachio);
  font-size: calc(1rem * 18 / 16);
  line-height: 1.33;
  font-weight: 500;
  display: inline-block;
}

@media screen and (max-width: 768px) {
  .skipToContentWrapper {
    position: relative;
    top: 0;
    width: 100%;
    margin-inline-start: 0;
  }

  .skipToContent:focus-visible {
    width: 100%;
    display: block;
    padding: 16px 25px;
  }
}

#S01Navigation .visually-hidden {
  clip-path: inset(50%);
  block-size: 1px;
  overflow: hidden;
  position: absolute;
  white-space: nowrap;
  inline-size: 1px;
}

#S01Navigation button:focus-visible {
  outline: 2px solid var(--focus-color);
  outline-offset: 2px;
}

body:not(.dark) #S01Navigation.closed[data-theme="light"],
body.light #S01Navigation.closed {
  background: var(--light-spruce);
}

body:not(.light) #S01Navigation[data-theme="dark"],
body.dark #S01Navigation {
  background: var(--squid-ink);
}

#S01Navigation {
  --light-spruce: #f2f6f5;
  --sustainability-spruce: #004a3a;
  --aloe: #80de9a;
  --squid-ink: #161d26;
  --pistachio: #d5f0d8;

  --ember-modern-display: "Ember Modern Display", sans-serif;
  --amazon-ember: "Amazon Ember", sans-serif;

  font-family: var(
    --ember-modern-display-standard,
    var(--ember-modern-display)
  );

  position: fixed;
  top: 0;
  display: flex;
  flex-direction: row;
  width: 100%;
  height: calc(1rem * 128 / 16);
  font-size: calc(1rem * 18 / 16);
  color: white;
  padding: 0 60px;
  align-items: center;
  justify-content: space-between;
  overflow: hidden;
  z-index: 8;
  transition: background 0.4s ease-in-out, height 0.4s, color 0.4s ease-in-out,
    transform 0.4s ease-in-out;
}

#S01Navigation {
  @media screen and (min-width: 1280px) and (max-width: 1679px) {
    height: calc(1rem * 86 / 16);
    font-size: clamp(calc(1rem * 14 / 16), 1.2vw, calc(1rem * 18 / 16));
    padding: 0 40px;
  }
}

#S01Navigation.hidden {
  transform: translateY(-100%);
}

#S01Navigation::after {
  width: 100%;
  height: 1px;
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  opacity: 0.15;
}

body:not(.light) #S01Navigation.closed[data-theme="dark"]::after,
body.dark #S01Navigation.closed::after {
  background: white;
}

body:not(.dark) #S01Navigation.closed[data-theme="light"]::after,
body.light #S01Navigation.closed::after {
  background: var(--sustainability-spruce);
}

#S01Navigation.opened::after {
  background: white;
}

#S01Navigation {
  @media screen and (max-width: 1279px) {
    flex-direction: column;
    height: 100%;
    padding: 0;
    align-items: flex-start;
    justify-content: flex-start;
    overflow: hidden;
    transition: transform 0.4s ease-in-out;
  }
}

body:not(.light) #S01Navigation.closed[data-theme="dark"],
body.dark #S01Navigation.closed {
  background: var(--squid-ink);
  color: var(--light-spruce);
}

body:not(.dark) #S01Navigation.closed[data-theme="light"],
body.light #S01Navigation.closed.green,
#S01Navigation.closed.white {
  color: var(--squid-ink);
  background: var(--light-spruce);
}

body:not(.light) #S01Navigation.closed.white[data-theme="dark"],
body.dark #S01Navigation.closed.white,
#S01Navigation.closed.green {
  background: var(--light-spruce);
}

#S01Navigation.closed {
  @media screen and (max-width: 1279px) {
    height: 72px;
    overflow: hidden;
  }
}

#S01Navigation.opened {
  background: var(--squid-ink);
  overflow: visible;
}

#S01Navigation.opened {
  @media screen and (max-width: 1279px) {
    height: 100%;
    overflow: auto;
  }
}

#S01Navigation.opened::after {
  @media screen and (max-width: 1279px) {
    background: transparent;
  }
}

#S01Navigation .navigationHeaderWrapper {
  @media screen and (max-width: 1279px) {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 10px 0 25px;
  }
}

#S01Navigation .openMenuButton {
  @media screen and (max-width: 1279px) {
    width: 45px;
    height: 45px;
    flex-direction: column;
    gap: 6px;
    align-items: center;
    justify-content: center;
  }
}

#S01Navigation .openMenuButton span {
  @media screen and (max-width: 1279px) {
    width: 20px;
    height: 2px;
    background: var(--sustainability-spruce);
    display: block;
  }
}

body:not(.light) #S01Navigation.closed[data-theme="dark"] .openMenuButton span,
body.dark #S01Navigation.closed .openMenuButton span {
  @media screen and (max-width: 1279px) {
    background: var(--light-spruce);
  }
}

#S01Navigation .closeMenuButton {
  @media screen and (max-width: 1279px) {
    align-items: center;
    justify-content: center;
    width: 80px;
    height: 56px;
    border-radius: 32px;
    background: rgba(255, 255, 255, 0.05);
  }
}

#S01Navigation .openMenuButton,
#S01Navigation .closeMenuButton {
  @media screen and (max-width: 1279px) {
    display: none;
  }
}

#S01Navigation .openMenuButton.visible,
#S01Navigation .closeMenuButton.visible {
  @media screen and (max-width: 1279px) {
    display: flex;
  }
}

#S01Navigation .navigationHeaderMobile {
  display: none;
}

#S01Navigation .navigationHeaderMobile {
  @media screen and (max-width: 1279px) {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 72px;
    gap: 10px;
  }
}

#S01Navigation .sustainabilityCopy {
  font-size: calc(1rem * 28 / 16);
  line-height: 1.14;
  font-weight: 700;
  color: var(--sustainability-spruce);
  position: relative;
  transition: opacity 0.2s ease, left 0.2s ease, color 0.4s ease-in-out;
}

#S01Navigation .sustainabilityCopy {
  @media screen and (max-width: 1279px) {
    font-size: calc(1rem * 18 / 16);
  }
}

#S01Navigation .sustainabilityCopy {
  @media screen and (min-width: 1280px) and (max-width: 1679px) {
    font-size: calc(1rem * 22 / 16);
  }
}

body:not(.light) #S01Navigation.closed[data-theme="dark"] .sustainabilityCopy,
body.dark #S01Navigation.closed .sustainabilityCopy,
#S01Navigation.opened .sustainabilityCopy {
  color: var(--light-spruce);
}

#S01Navigation.opened .sustainabilityCopy {
  @media screen and (max-width: 1279px) {
    display: none;
  }
}

body:not(.light) #S01Navigation.closed[data-theme="dark"] .amazonLogo,
body.dark #S01Navigation.closed .amazonLogo {
  color: white;
}

body:not(.dark) #S01Navigation.closed[data-theme="light"] .amazonLogo,
body.light #S01Navigation.closed .amazonLogo {
  color: var(--squid-ink);
}

#S01Navigation .amazonLogo {
  display: flex;
  align-items: center;
  transition: color 0.4s ease-in-out;
}

#S01Navigation .amazonLogo {
  @media screen and (max-width: 1279px) {
    width: 64px;
    height: 40px;
  }
}

#S01Navigation .amazonLogo {
  @media screen and (min-width: 1280px) and (max-width: 1679px) {
    width: 80px;
    height: 41px;
  }
}

#S01Navigation .amazonLogo svg {
  @media screen and (max-width: 1279px) {
    width: 100%;
    height: 100%;
  }
}

#S01Navigation .backMobileWrapper {
  display: none;
}

#S01Navigation .backMobileWrapper {
  @media screen and (max-width: 1279px) {
    display: flex;
    margin: 0 0 26px;
  }
}

#S01Navigation .backMobileCopy {
  @media screen and (max-width: 1279px) {
    display: flex;
    align-items: center;
    gap: 4px;
    font-weight: 500;
    margin-inline-start: -3px;
  }
}

#S01Navigation .backMobileCopy:hover {
  @media screen and (max-width: 1279px) {
    color: var(--aloe);
  }
}

#S01Navigation .backMobileCopy .arrow {
  @media screen and (max-width: 1279px) {
    height: 24px;
    display: inline-block;
  }
}

#S01Navigation .backMobileCopy .arrow svg {
  @media screen and (max-width: 1279px) {
    transform: translateY(1px) rotate(90deg);
  }
}

#S01Navigation .firstLevelWrapper {
  height: 100%;
  display: flex;
}

#S01Navigation .firstLevelWrapper {
  @media screen and (max-width: 1279px) {
    width: 100%;
    height: 100%;
  }
}

#S01Navigation .firstLevelListWrapper {
  @media screen and (max-width: 1279px) {
    width: 100%;
    height: 100%;
    position: relative;
    padding: 0 25px;
  }
}

#S01Navigation .firstLevelList {
  height: 100%;
  flex: 1;
  display: flex;
  flex-direction: row;
  list-style: none;
  justify-content: center;
  padding: 0;
  gap: 40px;
}

#S01Navigation .firstLevelList {
  @media screen and (max-width: 1279px) {
    top: 168px;
    flex-direction: column;
    justify-content: flex-start;
    align-items: flex-start;
    width: 100%;
    font-weight: 700;
    gap: 0;
  }
}

#S01Navigation .firstLevelCopy {
  position: relative;
  color: var(--sustainability-spruce);
  transition: color 0.4s ease-in-out;
  line-height: 0.89;
  text-align: left;
}

#S01Navigation .firstLevelCopy {
  @media screen and (max-width: 1279px) {
    transition: none;
  }
}

body:not(.light) #S01Navigation.closed[data-theme="dark"] .firstLevelCopy,
body.dark #S01Navigation.closed .firstLevelCopy,
#S01Navigation.opened .firstLevelCopy {
  color: var(--light-spruce);
}

#S01Navigation.opened .firstLevelCopy:hover {
  color: var(--aloe);
}

body:not(.light)
  #S01Navigation.closed[data-theme="dark"]
  .firstLevelCopy:not(:has(+ .secondLevelList.active)):hover::after,
body.dark
  #S01Navigation.closed
  .firstLevelCopy:not(:has(+ .secondLevelList.active)):hover::after {
  background: var(--aloe);
}

#S01Navigation:not(.opened)
  .firstLevelCopy:not(:has(+ .secondLevelList.active)):hover::after {
  background: var(--sustainability-spruce);
}

#S01Navigation .firstLevelCopy .linkCopy {
  display: flex;
  align-items: center;
  gap: 4px;
}

#S01Navigation .firstLevelItem,
#S01Navigation .firstLevelCopy {
  display: flex;
  flex-direction: row;
  align-items: center;
  height: 100%;
}

#S01Navigation .firstLevelItem,
#S01Navigation .firstLevelCopy {
  @media screen and (max-width: 1279px) {
    height: auto;
  }
}

#S01Navigation .firstLevelCopy {
  @media screen and (max-width: 1279px) {
    word-break: break-word;
  }
}

#S01Navigation .firstLevelCopy::after {
  content: "";
  position: absolute;
  bottom: 0;
  width: 0;
  height: 2px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--aloe);
  transition: background 0.2s, width 0.2s;
}

#S01Navigation
  .firstLevelCopy:not(:has(+ .secondLevelList.active)):hover::after,
#S01Navigation .firstLevelCopy[aria-current="page"]::after {
  width: 100%;
  background: var(--aloe);
}

body.light #S01Navigation.closed .firstLevelCopy[aria-current="page"]::after,
#S01Navigation.closed[data-theme="light"]
  .firstLevelCopy[aria-current="page"]::after {
  background: var(--sustainability-spruce);
}

#S01Navigation .firstLevelCopy::after {
  @media screen and (max-width: 1279px) {
    display: none;
  }
}

#S01Navigation .firstLevelItem,
#S01Navigation .firstLevelCopy {
  @media screen and (max-width: 1279px) {
    width: 100%;
  }
}

#S01Navigation .firstLevelItem {
  @media screen and (max-width: 1279px) {
    border-bottom: 1px solid rgba(255, 255, 255, 0.2);
  }
}

#S01Navigation .firstLevelCopy:has(+ .secondLevelList.active) {
  color: var(--aloe);
}

#S01Navigation .firstLevelCopy:has(+ .secondLevelList.active) svg {
  @media screen and (min-width: 1279px) {
    transform: rotate(180deg);
  }
}

#S01Navigation .firstLevelCopy:has(+ .secondLevelList.active)::after {
  width: 100%;
}

#S01Navigation .firstLevelCopy {
  @media screen and (max-width: 1279px) {
    justify-content: space-between;
    padding: 24px 0;
    font-size: calc(1rem * 32 / 16);
    line-height: 1.0625;
    letter-spacing: 0.16px;
    font-weight: 700;
  }
}

#S01Navigation .firstLevelCopy .linkCopy {
  @media screen and (max-width: 1279px) {
    font-size: calc(1rem * 32 / 16);
    line-height: 1.0625;
    letter-spacing: 0.16px;
    font-weight: 700;
    flex: 1;
  }
}

#S01Navigation .firstLevelCopy .linkCopy span:not(:has(+ .tag)):first-of-type {
  @media screen and (max-width: 1279px) {
    flex: 1;
  }
}

#S01Navigation .firstLevelCopy svg {
  @media screen and (max-width: 1279px) {
    transform: rotate(-90deg);
  }
}

#S01Navigation .secondLevelList {
  width: 100%;
  position: absolute;
  top: 100%;
  left: 0;
  height: 480px;
  display: flex;
  background: var(--squid-ink);
  display: none;
  padding: 40px 0 60px 60px;
  border-radius: 0 0 24px 24px;
  z-index: 1;
  transform: translate3d(
    0,
    0,
    0
  ); /* fix SOME rendering issues on MacOS Safari */
}

#S01Navigation .secondLevelList a.secondLevelCopy:hover,
#S01Navigation .secondLevelList .thirdLevelCopy:hover {
  color: var(--aloe);
  opacity: 1;
}

#S01Navigation .secondLevelList.active {
  display: flex;
}

#S01Navigation .secondLevelList {
  @media screen and (max-width: 1279px) {
    height: 100%;
    flex-direction: column;
    top: 0;
    left: 100%;
    padding: 24px 25px 0;
    border-radius: 0;
    overflow: hidden;
  }
}

#S01Navigation .secondLevelCopy {
  display: inline-block;
  white-space: nowrap;
  padding-inline-end: 24px;
  margin-block-end: 24px;
}

#S01Navigation .secondLevelCopy span:first-child {
  white-space: normal;
}

#S01Navigation .secondLevelCopy span:nth-child(2) {
  display: inline;
  white-space: nowrap;
}

#s01Navigation .secondLevelCopy span:nth-child(2)::before {
  content: "\200B";
}

#S01Navigation .secondLevelCopy .secondLevelLabel {
  font-size: clamp(calc(1rem * 16 / 16), 1.3vw, calc(1rem * 24 / 16));
  line-height: 1.33;
  letter-spacing: 0.2px;
  font-weight: 400;
}

#S01Navigation .thirdLevelCopy .linkCopy {
  font-size: clamp(calc(1rem * 14 / 16), 1.2vw, calc(1rem * 18 / 16));
  line-height: 0.89;
  letter-spacing: 0.018em;
  font-weight: 400;
}

#S01Navigation .secondLevelCopy .arrow,
#S01Navigation .thirdLevelCopy .arrow {
  display: inline;
  opacity: 0;
  top: 6px;
  left: -18px;
  position: relative;
  transition: opacity 0.2s, left 0.2s;
  white-space: nowrap;
}

#S01Navigation .thirdLevelCopy .arrow {
  top: 0;
}

#S01Navigation .thirdLevelCopy .arrow {
  @media screen and (max-width: 1279px) {
    display: inline-block;
    opacity: 1;
    position: static;
    margin-inline-start: 13px;
  }
}

#S01Navigation .secondLevelCopy:hover .arrow,
#S01Navigation .thirdLevelCopy:hover .arrow {
  @media screen and (min-width: 1279px) {
    opacity: 1;
    left: 0;
  }
}

#S01Navigation .thirdLevelCopy:hover .arrow {
  @media screen and (min-width: 1279px) {
    left: 9px;
  }
}

#S01Navigation .secondLevelCopy .arrow::before,
#S01Navigation .thirdLevelCopy .arrow::before {
  @media screen and (min-width: 1279px) {
    content: "\200B";
  }
}

#S01Navigation .secondLevelCopy .arrow svg {
  transform: rotate(-90deg);
}

#S01Navigation .secondLevelCopy .arrow {
  @media screen and (min-width: 1280px) and (max-width: 1679px) {
    top: 5px;
  }
}

#S01Navigation .thirdLevelCopy .arrow {
  @media screen and (min-width: 1280px) and (max-width: 1679px) {
    top: 1px;
  }
}

#S01Navigation .secondLevelCopy .arrow svg {
  @media screen and (min-width: 1280px) and (max-width: 1679px) {
    width: 18px;
    height: 18px;
  }
}

#S01Navigation .thirdLevelCopy .arrow svg {
  @media screen and (min-width: 1280px) and (max-width: 1679px) {
    width: 6px;
    height: 10px;
  }
}

#S01Navigation .thirdLevelCopy .tag-wrapper + .arrow {
  @media screen and (max-width: 1279px) {
    margin-inline-start: 56px;
  }
}

#S01Navigation .thirdLevelCopy .tag-wrapper + .arrow {
  @media screen and (min-width: 1280px) {
    display: none;
  }
}

#S01Navigation .secondLevelCopy {
  @media screen and (max-width: 1279px) {
    display: flex;
    align-items: center;
    justify-content: space-between;
    font-size: calc(1rem * 18 / 16);
    line-height: 1.33;
    letter-spacing: 0.2px;
    font-weight: 400;
    display: none;
  }
}

#S01Navigation .secondLevelItem {
  width: calc(var(--grid-column-width) * 2.8 + var(--grid-gap));
  margin-inline-end: 8px;
  padding: 0 0 16px 8px;
}

#S01Navigation .secondLevelItem:last-of-type {
  margin-inline-end: 0;
}

@media (min-width: 1440px) {
  #S01Navigation .secondLevelItem {
    width: calc(var(--grid-column-width) * 2.6 + var(--grid-gap));
  }
}

@media (min-width: 1680px) {
  #S01Navigation .secondLevelItem {
    width: calc(var(--grid-column-width) * 2 + var(--grid-gap));
    margin-inline-end: var(--grid-gap);
    padding: 0 0 16px 16px;
  }

  #S01Navigation .secondLevelItem:last-of-type {
    margin-inline-end: var(--grid-gap);
  }
}

#S01Navigation .secondLevelItem {
  @media screen and (max-width: 1279px) {
    width: 100%;
    margin-inline-end: 0;
    display: flex;
    flex-wrap: wrap;
    padding: 24px 0;
    gap: 0;
  }
}

#S01Navigation .secondLevelMobileToggle {
  display: none;
  visibility: hidden; /* VO MacOS bug */
}

#S01Navigation .secondLevelMobileToggle {
  @media screen and (max-width: 1279px) {
    display: flex;
    visibility: initial; /* VO MacOS bug */
    text-align: left;
    width: 100%;
  }
}

#S01Navigation .secondLevelItem:not(:last-child) {
  @media screen and (max-width: 1279px) {
    border-bottom: 1px solid rgba(255, 255, 255, 0.2);
  }
}

#S01Navigation .thirdLevelItem {
  margin-block-end: 13px;
}

#S01Navigation .thirdLevelItem {
  @media screen and (max-width: 1279px) {
    margin-block-end: 0;
  }
}

#S01Navigation .thirdLevelItem {
  @media screen and (max-width: 1279px) {
    flex: none;
  }
}

#S01Navigation .thirdLevelItemFirst {
  @media screen and (min-width: 1279px) {
    display: none;
  }
}

#S01Navigation .thirdLevelItem:first-child {
  @media screen and (max-width: 1279px) {
    margin-block-start: 23px;
  }
}

#S01Navigation .secondLevelCopy:has(+ .thirdLevelList.active) {
  @media screen and (max-width: 1279px) {
    color: var(--aloe);
  }
}

#S01Navigation .secondLevelCopy span:first-child {
  @media screen and (max-width: 1279px) {
    display: inline-block;
    white-space: normal;
  }
}

#S01Navigation .plusIcon {
  @media screen and (max-width: 1279px) {
    width: 24px;
    height: 24px;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    margin-inline-start: auto;
  }
}

#S01Navigation .plusIcon span {
  @media screen and (max-width: 1279px) {
    width: 12px;
    height: 2px;
    background: white;
    display: block;
  }
}

#S01Navigation .secondLevelMobileToggle:hover {
  @media screen and (max-width: 1279px) {
    color: var(--aloe);
  }
}

#S01Navigation .secondLevelMobileToggle:hover .plusIcon span {
  @media screen and (max-width: 1279px) {
    background: var(--aloe);
  }
}

#S01Navigation .plusIcon .vertical {
  @media screen and (max-width: 1279px) {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%) rotate(90deg);
    transition: transform 0.15s, background 0.2s;
  }
}

#S01Navigation
  .secondLevelMobileToggle:has(+ .thirdLevelList.active)
  .plusIcon
  .vertical {
  @media screen and (max-width: 1279px) {
    transform: translate(-50%, -50%) rotate(0deg);
    background: var(--aloe);
  }
}

#S01Navigation .secondLevelCopy,
#S01Navigation .thirdLevelCopy {
  font-size: 0; /* remove DOM whitespaces */
  white-space: nowrap;
}

#S01Navigation .thirdLevelCopy {
  @media screen and (max-width: 1279px) {
    display: flex;
    align-items: center;
    padding-block-end: 24px;
  }
}

#S01Navigation .thirdLevelItem:last-child .thirdLevelCopy {
  @media screen and (max-width: 1279px) {
    padding-block-end: 0;
  }
}

#S01Navigation .thirdLevelCopy .linkCopy {
  white-space: normal;
  opacity: 0.85;
}

#S01Navigation .thirdLevelCopy .linkCopy {
  @media screen and (max-width: 1279px) {
    letter-spacing: 0.015em;
  }
}

#S01Navigation .thirdLevelCopy .linkCopy:has(+ .tag-wrapper) {
  padding-inline-end: 40px;
}

#S01Navigation .thirdLevelCopy .tag-wrapper {
  position: relative;
  margin-inline-start: -40px;
  padding-block-start: 24px;
}

#S01Navigation .thirdLevelCopy .tag {
  white-space: normal;
  position: absolute;
  top: 6px;
  left: 8px;
}

#S01Navigation .thirdLevelCopy .tag {
  @media screen and (max-width: 1279px) {
    top: -1px;
    left: 5px;
  }
}

#S01Navigation .thirdLevelCopy .tag {
  @media screen and (min-width: 1280px) and (max-width: 1679px) {
    font-size: calc(1rem * 10 / 16);
    border-radius: 16px;
    height: 20px;
    top: 9px;
  }
}

#S01Navigation .thirdLevelCopy .externalLinkIcon,
#S01Navigation .thirdLevelCopy .downloadIcon {
  white-space: nowrap;
  opacity: 0.85;
  position: relative;
  padding-inline-start: 28px;
  padding-block-start: 24px;
}

#S01Navigation .thirdLevelCopy .externalLinkIcon::before,
#S01Navigation .thirdLevelCopy .downloadIcon::before {
  content: "\200B";
}

#S01Navigation .thirdLevelCopy:hover .linkCopy,
#S01Navigation .thirdLevelCopy:hover .externalLinkIcon,
#S01Navigation .thirdLevelCopy:hover .downloadIcon {
  opacity: 1;
}

#S01Navigation .thirdLevelCopy .externalLinkIcon svg,
#S01Navigation .thirdLevelCopy .downloadIcon svg {
  position: absolute;
  top: 6px;
  left: 4px;
}

#S01Navigation .thirdLevelCopy .externalLinkIcon svg,
#S01Navigation .thirdLevelCopy .downloadIcon svg {
  @media screen and (max-width: 1279px) {
    top: -1px;
    left: 5px;
  }
}

#S01Navigation .thirdLevelCopy .externalLinkIcon svg,
#S01Navigation .thirdLevelCopy .downloadIcon svg {
  @media screen and (min-width: 1280px) and (max-width: 1679px) {
    top: 8px;
    left: 3px;
    height: 20px;
    width: 20px;
  }
}

#S01Navigation .thirdLevelList {
  @media screen and (max-width: 1279px) {
    height: 0;
    overflow: hidden;
    width: 100%;
  }
}

#S01Navigation .thirdLevelList.active {
  @media screen and (max-width: 1279px) {
    height: auto;
  }
}

#S01Navigation .thirdLevelList:not(.active) {
  @media screen and (max-width: 1279px) {
    display: none;
  }
}

#S01Navigation .image {
  position: absolute;
  bottom: 50px;
  right: 60px;
  border-radius: 20px;
  width: clamp(100px, 17.5vw, 304px);
  aspect-ratio: 304 / 172;
  opacity: 0;
  transition: opacity 0.2s ease, bottom 0.2s ease;
}

#S01Navigation .image.active {
  opacity: 1;
  bottom: 60px;
}

#S01Navigation .image {
  @media screen and (max-width: 1279px) {
    display: none;
  }
}

#S01Navigation .linkCopy {
  @media screen and (max-width: 1279px) {
    display: flex;
    align-items: center;
    gap: 4px;
    font-size: calc(1rem * 18 / 16);
    line-height: 1.33;
    letter-spacing: 0.007em;
    font-weight: 400;
  }
}

#S01Navigation .tag {
  font-family: "Amazon Ember Mono", monospace;
  color: var(--squid-ink);
  border-radius: 20px;
  background: var(--aloe);
  padding: 0 8px;
  font-size: calc(1rem * 12 / 16);
  line-height: 2;
  font-weight: 500;
  height: 24px;
  display: inline-block;
  transition: background 0.4s ease-in-out, color 0.4s ease-in-out;
}

#S01Navigation.opened .firstLevelCopy .tag {
  @media screen and (min-width: 1279px) {
    background: rgba(255, 255, 255, 0.1);
    color: var(--aloe);
  }
}

#S01Navigation .card {
  width: clamp(300px, 23vw, 432px);
  aspect-ratio: 432 / 288;
  background: var(--aloe);
  border-radius: 20px;
  position: absolute;
  bottom: clamp(20px, 1.5vw, 60px);
  right: clamp(20px, 1.5vw, 60px);
  padding: 14px;
  color: var(--sustainability-spruce);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  transition: background 0.2s ease;
  gap: 8px
}

@media (min-width: 1440px) {
  #S01Navigation .card {
    gap: 0;
    padding: 18px;
  }
}

@media (min-width: 1680px) {
  #S01Navigation .card {
    width: clamp(350px, 26vw, 432px);
    bottom: clamp(30px, 2vw, 60px);
    right: clamp(30px, 2vw, 60px);
    padding: 24px;
  }
}

#S01Navigation .card.cardVariant1:hover {
  background: #70c189;
  cursor: pointer;
}

#S01Navigation .card.cardVariant2:hover {
  background: #74cb8e;
}

#S01Navigation .card {
  @media screen and (max-width: 1279px) {
    display: none;
  }
}

#S01Navigation .cardImage {
  border-radius: 8px;
  width: 80px;
  height: 80px;
}

#S01Navigation .card .top {
  display: flex;
  align-items: flex-start;
  gap: 14px;
}

#S01Navigation .card .top .copy {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

#S01Navigation .cardTitle {
  font-size: clamp(calc(1rem * 30 / 20), 2vw, calc(1rem * 42 / 16));
  line-height: 1.047;
  font-weight: 700;
}

@media (min-width: 1440px) {
  #S01Navigation .cardTitle {
    font-size: clamp(calc(1rem * 30 / 16), 2.2vw, calc(1rem * 42 / 16));
  }
}

#S01Navigation .card .bottom {
  padding: 16px 0 0;
  display: flex;
  flex-direction: row;
  align-items: center;
  border-top: 1px solid rgba(0, 74, 58, 0.2);
}

#S01Navigation .card.cardVariant1 .bottom {
  justify-content: space-between;
}

#S01Navigation .card.cardVariant2 .bottom {
  justify-content: flex-end;
}

#S01Navigation .card .downloadOptions {
  display: flex;
  align-items: center;
  gap: 8px;
}

#S01Navigation .card .downloadSelectorButtonWrapper {
  position: relative;
}

#S01Navigation .card .downloadSelectorButton {
  font-size: clamp(calc(1rem * 16 / 16), 1vw, calc(1rem * 18 / 16));
  background: #75cf91;
  color: var(--sustainability-spruce);
  border-radius: 32px;
  padding: 16px 20px;
  align-items: center;
  display: flex;
  gap: 4px;
  font-weight: 500;
  transition: background 0.2s ease;
}

#S01Navigation .card .downloadSelectorButton span {
  font-family: var(
    --ember-modern-display-standard,
    var(--ember-modern-display)
  );
}

#S01Navigation .card .downloadSelector {
  position: absolute;
  width: 100%;
  top: calc(100% + 8px);
  left: 0;
  background: #75cf91;
  border-radius: 20px;
  padding: 16px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  transition: background 0.2s ease;
  opacity: 0;
  visibility: hidden;
}

#S01Navigation .card:hover .downloadSelectorButton,
#S01Navigation .card:hover .downloadSelector {
  background: #65b481;
}

#S01Navigation .card:hover .downloadSelectorButton:hover {
  background: #5eaa78;
}

#S01Navigation .card .downloadButton {
  background: var(--sustainability-spruce);
  color: var(--pistachio);
  border-radius: 32px;
  padding: 16px 20px;
  position: relative;
  overflow: hidden;
  font-size: clamp(calc(1rem * 16 / 16), 1vw, calc(1rem * 18 / 16));
}

#S01Navigation .card .downloadButton .contentOverflow {
  overflow: hidden;
  position: relative;
  pointer-events: none;
}

#S01Navigation .card .downloadButton .content {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
  transition: transform 0.6s cubic-bezier(0.3, 1, 0.2, 1);
}

#S01Navigation .card .downloadButton:hover .content,
#S01Navigation .card.cardVariant1:hover .downloadButton .content {
  transform: translateY(-150%);
}

#S01Navigation .card .downloadButton .hoverContent,
#S01Navigation .card.cardVariant1:hover .downloadButton .hoverContent {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
  position: absolute;
  inset: 0;
  transform: translateY(250%);
  transition: transform 0.6s cubic-bezier(0.3, 1, 0.2, 1);
}

#S01Navigation .card .downloadButton:hover .hoverContent,
#S01Navigation .card.cardVariant1:hover .downloadButton .hoverContent {
  transform: translateY(0%);
}

#S01Navigation .card .downloadButton::before {
  content: "";
  display: block;
  position: absolute;
  inset: 0;
  clip-path: ellipse(100% 125% at 50% 125%);
  background-color: var(--squid-ink);
  transform: translateY(176%) scale(2.03, 2.5);
  transition: transform 0.8s cubic-bezier(0.3, 1, 0.2, 1);
  inline-size: 100%;
  block-size: 100%;
}

#S01Navigation .card .downloadButton:hover::before,
#S01Navigation .card.cardVariant1:hover .downloadButton::before {
  transform: translateY(0) scale(2.03, 2.5);
}

#S01Navigation .card .downloadButton span {
  font-family: var(
    --ember-modern-display-standard,
    var(--ember-modern-display)
  );
  font-weight: 500;
}

#S01Navigation .card .fileDescription {
  font-family: "Amazon Ember Mono", monospace;
  font-size: 14px;
  line-height: 16px;
  letter-spacing: -0.07px;
}

#S01Navigation .itemSelectorButton {
  width: 100%;
  display: flex;
  align-items: center;
  gap: 4px;
  line-height: 24px;
  font-weight: 500;
  font-size: clamp(calc(1rem * 16 / 16), 1vw, calc(1rem * 18 / 16));
}

#S01Navigation .itemSelectorButton span {
  font-family: var(
    --ember-modern-display-standard,
    var(--ember-modern-display)
  );
}

#S01Navigation .itemSelectorButton:not(.active) .icon {
  display: none;
}

#S01Navigation .itemSelectorButton.active .icon {
  display: block;
}

*,
*::before,
*::after {
  box-sizing: border-box;
  -webkit-tap-highlight-color: rgba(0 0 0 / 0);
  font-kerning: none;
}

html,
body {
  margin: 0;
  padding: 0;
  font-size: 100%;
  line-height: 1.15;
  -webkit-text-size-adjust: 100%;
  -webkit-font-smoothing: antialiased;
}

button,
a {
  color: currentColor;
  appearance: none;
  border: none;
  background: none;
  padding: 0;
  text-decoration: none;
  cursor: pointer;
}

ul,
ol {
  margin: 0;
  padding: 0;
  list-style: none;
}

img {
  display: block;
}

h1,
h2,
h3,
h4,
h5,
h6,
p {
  font-weight: normal;
  margin: 0;
  font-kerning: none;
}

