.flex-grow {
  -ms-flex-positive: 1;
  flex-grow: 1;
}

.flex-shrink-0 {
  -ms-flex-negative: 0;
  flex-shrink: 0;
}

.flex-gap-xxxs {
  margin-bottom: -0.25em;
  margin-right: -0.25em;
}

.flex-gap-xxxs > * {
  margin-bottom: 0.25em;
  margin-right: 0.25em;
}

.flex-gap-xxs {
  margin-bottom: -0.375em;
  margin-right: -0.375em;
}

.flex-gap-xxs > * {
  margin-bottom: 0.375em;
  margin-right: 0.375em;
}

.flex-gap-xs {
  margin-bottom: -0.5em;
  margin-right: -0.5em;
}

.flex-gap-xs > * {
  margin-bottom: 0.5em;
  margin-right: 0.5em;
}

.flex-gap-sm {
  margin-bottom: -0.75em;
  margin-right: -0.75em;
}

.flex-gap-sm > * {
  margin-bottom: 0.75em;
  margin-right: 0.75em;
}

.flex-gap-md {
  margin-bottom: -1.25em;
  margin-right: -1.25em;
}

.flex-gap-md > * {
  margin-bottom: 1.25em;
  margin-right: 1.25em;
}

.flex-gap-lg {
  margin-bottom: -2em;
  margin-right: -2em;
}

.flex-gap-lg > * {
  margin-bottom: 2em;
  margin-right: 2em;
}

.flex-gap-xl {
  margin-bottom: -3.25em;
  margin-right: -3.25em;
}

.flex-gap-xl > * {
  margin-bottom: 3.25em;
  margin-right: 3.25em;
}

.flex-gap-xxl {
  margin-bottom: -5.25em;
  margin-right: -5.25em;
}

.flex-gap-xxl > * {
  margin-bottom: 5.25em;
  margin-right: 5.25em;
}

.margin-xxxxs {
  margin: 0.125em;
}

.margin-xxxs {
  margin: 0.25em;
}

.margin-xxs {
  margin: 0.375em;
}

.margin-xs {
  margin: 0.5em;
}

.margin-sm {
  margin: 0.75em;
}

.margin-md {
  margin: 1.25em;
}

.margin-lg {
  margin: 2em;
}

.margin-xl {
  margin: 3.25em;
}

.margin-xxl {
  margin: 5.25em;
}

.margin-xxxl {
  margin: 8.5em;
}

.margin-xxxxl {
  margin: 13.75em;
}

.margin-auto {
  margin: auto;
}

.margin-top-xxxxs {
  margin-top: 0.125em;
}

.margin-top-xxxs {
  margin-top: 0.25em;
}

.margin-top-xxs {
  margin-top: 0.375em;
}

.margin-top-xs {
  margin-top: 0.5em;
}

.margin-top-sm {
  margin-top: 0.75em;
}

.margin-top-md {
  margin-top: 1.25em;
}

.margin-top-lg {
  margin-top: 2em;
}

.margin-top-xl {
  margin-top: 3.25em;
}

.margin-top-xxl {
  margin-top: 5.25em;
}

.margin-top-xxxl {
  margin-top: 8.5em;
}

.margin-top-xxxxl {
  margin-top: 13.75em;
}

.margin-top-auto {
  margin-top: auto;
}

.margin-bottom-xxxxs {
  margin-bottom: 0.125em;
}

.margin-bottom-xxxs {
  margin-bottom: 0.25em;
}

.margin-bottom-xxs {
  margin-bottom: 0.375em;
}

.margin-bottom-xs {
  margin-bottom: 0.5em;
}

.margin-bottom-sm {
  margin-bottom: 0.75em;
}

.margin-bottom-md {
  margin-bottom: 1.25em;
}

.margin-bottom-lg {
  margin-bottom: 2em;
}

.margin-bottom-xl {
  margin-bottom: 3.25em;
}

.margin-bottom-xxl {
  margin-bottom: 5.25em;
}

.margin-bottom-xxxl {
  margin-bottom: 8.5em;
}

.margin-bottom-xxxxl {
  margin-bottom: 13.75em;
}

.margin-bottom-auto {
  margin-bottom: auto;
}

.margin-right-xxxxs {
  margin-right: 0.125em;
}

.margin-right-xxxs {
  margin-right: 0.25em;
}

.margin-right-xxs {
  margin-right: 0.375em;
}

.margin-right-xs {
  margin-right: 0.5em;
}

.margin-right-sm {
  margin-right: 0.75em;
}

.margin-right-md {
  margin-right: 1.25em;
}

.margin-right-lg {
  margin-right: 2em;
}

.margin-right-xl {
  margin-right: 3.25em;
}

.margin-right-xxl {
  margin-right: 5.25em;
}

.margin-right-xxxl {
  margin-right: 8.5em;
}

.margin-right-xxxxl {
  margin-right: 13.75em;
}

.margin-right-auto {
  margin-right: auto;
}

.margin-left-xxxxs {
  margin-left: 0.125em;
}

.margin-left-xxxs {
  margin-left: 0.25em;
}

.margin-left-xxs {
  margin-left: 0.375em;
}

.margin-left-xs {
  margin-left: 0.5em;
}

.margin-left-sm {
  margin-left: 0.75em;
}

.margin-left-md {
  margin-left: 1.25em;
}

.margin-left-lg {
  margin-left: 2em;
}

.margin-left-xl {
  margin-left: 3.25em;
}

.margin-left-xxl {
  margin-left: 5.25em;
}

.margin-left-xxxl {
  margin-left: 8.5em;
}

.margin-left-xxxxl {
  margin-left: 13.75em;
}

.margin-left-auto {
  margin-left: auto;
}

.margin-x-xxxxs {
  margin-left: 0.125em;
  margin-right: 0.125em;
}

.margin-x-xxxs {
  margin-left: 0.25em;
  margin-right: 0.25em;
}

.margin-x-xxs {
  margin-left: 0.375em;
  margin-right: 0.375em;
}

.margin-x-xs {
  margin-left: 0.5em;
  margin-right: 0.5em;
}

.margin-x-sm {
  margin-left: 0.75em;
  margin-right: 0.75em;
}

.margin-x-md {
  margin-left: 1.25em;
  margin-right: 1.25em;
}

.margin-x-lg {
  margin-left: 2em;
  margin-right: 2em;
}

.margin-x-xl {
  margin-left: 3.25em;
  margin-right: 3.25em;
}

.margin-x-xxl {
  margin-left: 5.25em;
  margin-right: 5.25em;
}

.margin-x-xxxl {
  margin-left: 8.5em;
  margin-right: 8.5em;
}

.margin-x-xxxxl {
  margin-left: 13.75em;
  margin-right: 13.75em;
}

.margin-x-auto {
  margin-left: auto;
  margin-right: auto;
}

.margin-y-xxxxs {
  margin-top: 0.125em;
  margin-bottom: 0.125em;
}

.margin-y-xxxs {
  margin-top: 0.25em;
  margin-bottom: 0.25em;
}

.margin-y-xxs {
  margin-top: 0.375em;
  margin-bottom: 0.375em;
}

.margin-y-xs {
  margin-top: 0.5em;
  margin-bottom: 0.5em;
}

.margin-y-sm {
  margin-top: 0.75em;
  margin-bottom: 0.75em;
}

.margin-y-md {
  margin-top: 1.25em;
  margin-bottom: 1.25em;
}

.margin-y-lg {
  margin-top: 2em;
  margin-bottom: 2em;
}

.margin-y-xl {
  margin-top: 3.25em;
  margin-bottom: 3.25em;
}

.margin-y-xxl {
  margin-top: 5.25em;
  margin-bottom: 5.25em;
}

.margin-y-xxxl {
  margin-top: 8.5em;
  margin-bottom: 8.5em;
}

.margin-y-xxxxl {
  margin-top: 13.75em;
  margin-bottom: 13.75em;
}

.margin-y-auto {
  margin-top: auto;
  margin-bottom: auto;
}
.text-replace {
  overflow: hidden;
  color: transparent;
  text-indent: 100%;
  white-space: nowrap;
}
.text-replace:hover {
  color: transparent;
}

.cd-cart::before {
  content: "";
  position: fixed;
  z-index: 1;
  height: 100%;
  width: 100%;
  top: 0;
  left: 0;
  background: rgba(0, 0, 0, 0.5);
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.4s, visibility 0.4s;
}

.cd-cart--open::before {
  opacity: 1;
  visibility: visible;
}

.cd-cart__trigger,
.cd-cart__content {
  position: fixed;
  bottom: 20px;
  right: 5%;
  transition: -webkit-transform 0.2s;
  transition: transform 0.2s;
  transition: transform 0.2s, -webkit-transform 0.2s;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  will-change: transform;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}

.cd-cart--empty .cd-cart__trigger,
.cd-cart--empty .cd-cart__content {
  -webkit-transform: translateY(150px);
  -ms-transform: translateY(150px);
  transform: translateY(150px);
}

@media (min-width: 80rem) {
  .cd-cart__trigger,
  .cd-cart__content {
    bottom: 40px;
  }
}

.cd-cart__trigger {
  z-index: 3;
  height: 72px;
  width: 72px;
  overflow: visible;
}

.cd-cart__trigger::after,
.cd-cart__trigger::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translateY(-50%) translateX(-50%);
  -ms-transform: translateY(-50%) translateX(-50%);
  transform: translateY(-50%) translateX(-50%);
  height: 100%;
  width: 100%;
  background: url(../img/icon/cd-icons-cart-close.svg) no-repeat 0 0;
  transition: opacity 0.2s, -webkit-transform 0.2s;
  transition: opacity 0.2s, transform 0.2s;
  transition: opacity 0.2s, transform 0.2s, -webkit-transform 0.2s;
}

.cd-cart__trigger::after {
  background-position: -72px 0;
  opacity: 0;
  -webkit-transform: translateX(-50%) translateY(-50%) rotate(90deg);
  -ms-transform: translateX(-50%) translateY(-50%) rotate(90deg);
  transform: translateX(-50%) translateY(-50%) rotate(90deg);
}

.cd-cart--open .cd-cart__trigger::before {
  opacity: 0;
}

.cd-cart--open .cd-cart__trigger::after {
  opacity: 1;
  -webkit-transform: translateX(-50%) translateY(-50%);
  -ms-transform: translateX(-50%) translateY(-50%);
  transform: translateX(-50%) translateY(-50%);
}

.cd-cart__trigger:hover + .cd-cart__content .cd-cart__layout {
  box-shadow: 0 6px 40px rgba(0, 0, 0, 0.3);
}

.cd-cart--open .cd-cart__trigger:hover + .cd-cart__content .cd-cart__layout {
  box-shadow: 0 4px 30px rgba(0, 0, 0, 0.17);
}

.cd-cart__count {
  position: absolute;
  top: -10px;
  right: -10px;
  height: 28px;
  width: 28px;
  background: hsl(7, 80%, 56%);
  color: hsl(0, 0%, 100%);
  font-size: 0.83333em;
  font-weight: bold;
  border-radius: 50%;
  text-indent: 0;
  transition: -webkit-transform 0.2s 0.5s;
  transition: transform 0.2s 0.5s;
  transition: transform 0.2s 0.5s, -webkit-transform 0.2s 0.5s;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.cd-cart__count li {
  position: absolute;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  left: 50%;
  top: 50%;
  -webkit-transform: translateX(-50%) translateY(-50%);
  -ms-transform: translateX(-50%) translateY(-50%);
  transform: translateX(-50%) translateY(-50%);
  -webkit-animation-fill-mode: forwards;
  animation-fill-mode: forwards;
  -webkit-animation-duration: 0.15s;
  animation-duration: 0.15s;
}

.cd-cart__count li:last-of-type {
  visibility: hidden;
}

.cd-cart__count--update li:last-of-type {
  -webkit-animation-name: cd-qty-enter;
  animation-name: cd-qty-enter;
}

.cd-cart__count--update li:first-of-type {
  -webkit-animation-name: cd-qty-leave;
  animation-name: cd-qty-leave;
}

.cd-cart--open .cd-cart__count {
  transition: -webkit-transform 0.2s 0s;
  transition: transform 0.2s 0s;
  transition: transform 0.2s 0s, -webkit-transform 0.2s 0s;
  -webkit-transform: scale(0);
  -ms-transform: scale(0);
  transform: scale(0);
}

.cd-cart--empty .cd-cart__count {
  -webkit-transform: scale(1);
  -ms-transform: scale(1);
  transform: scale(1);
}

.cd-cart__content {
  z-index: 2;
  width: 90%;
  max-width: 440px;
  height: 400px;
  max-height: 90%;
  pointer-events: none;
}

.cd-cart__layout {
  position: absolute;
  bottom: 0;
  right: 0;
  z-index: 2;
  overflow: hidden;
  height: 72px;
  width: 72px;
  border-radius: 0.25em;
  transition: height 0.4s 0.1s, width 0.4s 0.1s, box-shadow 0.3s;
  transition-timing-function: cubic-bezier(0.67, 0.17, 0.32, 0.95);
  background: hsl(0, 0%, 100%);
  box-shadow: 0 4px 30px rgba(0, 0, 0, 0.17);
  pointer-events: auto;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-direction: column;
  flex-direction: column;
}

.cd-cart--open .cd-cart__layout {
  height: 100%;
  width: 100%;
  transition-delay: 0s;
}

.cd-cart__header,
.cd-cart__body {
  opacity: 0;
  padding-left: 0.825em;
  padding-right: 0.825em;
}

.cd-cart--open .cd-cart__header,
.cd-cart--open .cd-cart__body {
  opacity: 1;
}

.cd-cart__header {
  position: relative;
  z-index: 1;
  -ms-flex-negative: 0;
  flex-shrink: 0;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -ms-flex-align: center;
  align-items: center;
  border-radius: 0.25em 0.25em 0 0;
  height: 40px;
  line-height: 40px;
  background-color: hsl(0, 0%, 100%);
  transition: opacity 0.2s 0s;
  border-bottom: 1px solid hsl(0, 0%, 90%);
}

.cd-cart__header h2 {
  text-transform: uppercase;
  display: inline-block;
  font-size: 0.76388em;
  font-weight: 700;
  letter-spacing: 0.1em;
}

.cd-cart--open .cd-cart__header {
  transition: opacity 0.2s 0.2s;
}

.cd-cart__undo {
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.2s, visibility 0.2s;
  color: hsl(210, 31%, 28.8%);
  font-size: 0.69444em;
}

.cd-cart__undo a {
  text-decoration: underline;
  color: hsl(210, 31%, 24%);
}

.cd-cart__undo a:hover {
  color: hsl(204, 73%, 52%);
}

.cd-cart__undo--visible {
  opacity: 1;
  visibility: visible;
}

.cd-cart__body {
  -ms-flex-positive: 1;
  flex-grow: 1;
  padding-top: 0.75em;
  padding-bottom: 0.75em;
  overflow: auto;
  -webkit-overflow-scrolling: touch;
  transition: opacity 0.2s;
}

.cd-cart__body ul {
  position: relative;
  padding-bottom: 60px;
}

@media (min-width: 64rem) {
  .cd-cart__body ul {
    padding-bottom: 90px;
  }
}

.cd-cart--open .cd-cart__body {
  transition: opacity 0s;
}

.cd-cart--open .cd-cart__body li {
  transition: opacity 0.3s 0.2s, -webkit-transform 0.3s 0.2s;
  transition: transform 0.3s 0.2s, opacity 0.3s 0.2s;
  transition: transform 0.3s 0.2s, opacity 0.3s 0.2s,
    -webkit-transform 0.3s 0.2s;
  opacity: 1;
  -webkit-transform: translateX(0);
  -ms-transform: translateX(0);
  transform: translateX(0);
}

.cd-cart--open .cd-cart__body li:nth-of-type(2) {
  transition-duration: 0.4s;
}

.cd-cart--open .cd-cart__body li:nth-of-type(3) {
  transition-duration: 0.5s;
}

.cd-cart--open .cd-cart__body li:nth-of-type(4),
.cd-cart--open .cd-cart__body li:nth-of-type(5) {
  transition-duration: 0.55s;
}

.cd-cart__product {
  position: relative;
  opacity: 0;
  -webkit-transform: translateX(80px);
  -ms-transform: translateX(80px);
  transform: translateX(80px);
  transition: opacity 0s 0.2s, -webkit-transform 0s 0.2s;
  transition: opacity 0s 0.2s, transform 0s 0.2s;
  transition: opacity 0s 0.2s, transform 0s 0.2s, -webkit-transform 0s 0.2s;
  display: -ms-flexbox;
  display: flex;
}

.cd-cart__product:not(:last-of-type) {
  margin-bottom: 12px;
}

.cd-cart__product a {
  text-decoration: none;
}

.cd-cart__product--deleted {
  position: absolute;
  left: 0;
  width: 100%;
  opacity: 0;
  -webkit-animation: cd-item-slide-out 0.3s forwards;
  animation: cd-item-slide-out 0.3s forwards;
}

.cd-cart__product--deleted.cd-cart__product--undo {
  -webkit-animation: cd-item-slide-in 0.3s forwards;
  animation: cd-item-slide-in 0.3s forwards;
}

.cd-cart__product--deleted + .cd-cart__product {
  -webkit-animation: cd-item-move-up-mobile 0.3s;
  animation: cd-item-move-up-mobile 0.3s;
  -webkit-animation-fill-mode: forwards;
  animation-fill-mode: forwards;
}

@media (min-width: 64rem) {
  .cd-cart__product--deleted + .cd-cart__product {
    -webkit-animation: cd-item-move-up 0.3s;
    animation: cd-item-move-up 0.3s;
  }
}

.cd-cart__product--undo + .cd-cart__product {
  -webkit-animation: cd-item-move-down-mobile 0.3s;
  animation: cd-item-move-down-mobile 0.3s;
  -webkit-animation-fill-mode: forwards;
  animation-fill-mode: forwards;
}

@media (min-width: 64rem) {
  .cd-cart__product--undo + .cd-cart__product {
    -webkit-animation: cd-item-move-down 0.3s;
    animation: cd-item-move-down 0.3s;
  }
}

.cd-cart__image {
  display: inline-block;
  width: 50px;
  -ms-flex-negative: 0;
  flex-shrink: 0;
}

.cd-cart__image img {
  display: block;
}

@media (min-width: 64rem) {
  .cd-cart__image {
    width: 90px;
  }
}

.cd-cart__details {
  position: relative;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-line-pack: start;
  align-content: flex-start;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -ms-flex-positive: 1;
  flex-grow: 1;
  padding-top: 0.825em;
  padding-left: 0.6em;
}

.cd-cart__details h3 {
  font-weight: bold;
  width: 70%;
  font-size: 0.95833em;
}

.cd-cart__details h3 a {
  color: hsl(210, 31%, 24%);
}

.cd-cart__details h3 a:hover {
  color: hsl(204, 73%, 52%);
}

.cd-cart__price {
  width: 30%;
  text-align: right;
  font-size: 0.91666em;
  font-weight: bold;
}

.cd-cart__actions {
  display: -ms-flexbox;
  display: flex;
  font-size: 0.76388em;
}

.cd-cart__delete-item,
.cd-cart__quantity {
  color: hsl(210, 31%, 28.8%);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}

.cd-cart__delete-item {
  margin-right: 0.75em;
}

.cd-cart__delete-item:hover {
  color: hsl(7, 80%, 56%);
}

.cd-cart__quantity {
  display: -ms-flexbox;
  display: flex;
}

.cd-cart__quantity label {
  margin-right: 0.375em;
}

.cd-cart__select {
  position: relative;
}

.cd-cart__select select {
  position: relative;
  padding: 0 1.25em 0 0;
  cursor: pointer;
  color: currentColor;
}

.cd-cart__select select:focus {
  outline: none;
  color: hsl(210, 31%, 24%);
  box-shadow: 0 1px 0 currentColor;
}

.cd-cart__select select::-ms-expand {
  display: none;
}

.cd-cart__select .icon {
  position: absolute;
  z-index: 1;
  right: 0;
  top: 50%;
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  transform: translateY(-50%);
  display: block;
  width: 12px;
  height: 12px;
  color: currentColor;
  pointer-events: none;
}

@media (min-width: 64rem) {
  .cd-cart__select select {
    padding-right: 0.75em;
  }
}

.cd-cart__footer {
  position: absolute;
  bottom: 0;
  width: 100%;
  border-radius: 0 0 0.25em 0.25em;
  box-shadow: 0 -2px 20px rgba(0, 0, 0, 0.15);
  background: hsl(0, 0%, 100%);
}

.cd-cart__checkout {
  display: block;
  height: 72px;
  line-height: 72px;
  margin-right: 72px;
  background: hsl(204, 73%, 52%);
  color: hsla(0, 0%, 100%, 0);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-align: center;
  font-size: 1.2em;
  font-weight: 600;
  transition: all 0.2s 0s;
}

.cd-cart__checkout:hover {
  background: hsl(204, 73%, 56.16%);
}

.cd-cart__checkout em {
  position: relative;
  display: inline-block;
  -webkit-transform: translateX(40px);
  -ms-transform: translateX(40px);
  transform: translateX(40px);
  transition: -webkit-transform 0s 0.2s;
  transition: transform 0s 0.2s;
  transition: transform 0s 0.2s, -webkit-transform 0s 0.2s;
}

.cd-cart__checkout .icon {
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  transform: translateY(-50%);
  right: 0;
  opacity: 0;
  transition: opacity 0.2s;

  display: inline-block;
  color: inherit;
  fill: currentColor;
  height: 1em;
  width: 1em;
  line-height: 1;
  -ms-flex-negative: 0;
  flex-shrink: 0;
}

.cd-cart--open .cd-cart__checkout {
  color: hsl(0, 0%, 100%);
  transition: color 0.2s 0.3s;
}

.cd-cart--open .cd-cart__checkout em {
  -webkit-transform: translateX(0);
  -ms-transform: translateX(0);
  transform: translateX(0);
  transition: padding 0.2s 0s, -webkit-transform 0.2s 0.3s;
  transition: transform 0.2s 0.3s, padding 0.2s 0s;
  transition: transform 0.2s 0.3s, padding 0.2s 0s, -webkit-transform 0.2s 0.3s;
}

.cd-cart--open .cd-cart__checkout:hover em {
  padding-right: 30px;
}

.cd-cart--open .cd-cart__checkout:hover .icon {
  opacity: 1;
}

@-webkit-keyframes cd-qty-enter {
  0% {
    opacity: 0;
    visibility: hidden;
    -webkit-transform: translateX(-50%) translateY(0);
    transform: translateX(-50%) translateY(0);
  }

  100% {
    opacity: 1;
    visibility: visible;
    -webkit-transform: translateX(-50%) translateY(-50%);
    transform: translateX(-50%) translateY(-50%);
  }
}

@keyframes cd-qty-enter {
  0% {
    opacity: 0;
    visibility: hidden;
    -webkit-transform: translateX(-50%) translateY(0);
    transform: translateX(-50%) translateY(0);
  }

  100% {
    opacity: 1;
    visibility: visible;
    -webkit-transform: translateX(-50%) translateY(-50%);
    transform: translateX(-50%) translateY(-50%);
  }
}

@-webkit-keyframes cd-qty-leave {
  0% {
    opacity: 1;
    visibility: visible;
    -webkit-transform: translateX(-50%) translateY(-50%);
    transform: translateX(-50%) translateY(-50%);
  }

  100% {
    opacity: 0;
    visibility: hidden;
    -webkit-transform: translateX(-50%) translateY(-100%);
    transform: translateX(-50%) translateY(-100%);
  }
}

@keyframes cd-qty-leave {
  0% {
    opacity: 1;
    visibility: visible;
    -webkit-transform: translateX(-50%) translateY(-50%);
    transform: translateX(-50%) translateY(-50%);
  }

  100% {
    opacity: 0;
    visibility: hidden;
    -webkit-transform: translateX(-50%) translateY(-100%);
    transform: translateX(-50%) translateY(-100%);
  }
}

@-webkit-keyframes cd-item-move-up-mobile {
  0% {
    padding-top: 62px;
  }

  100% {
    padding-top: 0px;
  }
}

@keyframes cd-item-move-up-mobile {
  0% {
    padding-top: 62px;
  }

  100% {
    padding-top: 0px;
  }
}

@-webkit-keyframes cd-item-move-up {
  0% {
    padding-top: 102px;
  }

  100% {
    padding-top: 0px;
  }
}

@keyframes cd-item-move-up {
  0% {
    padding-top: 102px;
  }

  100% {
    padding-top: 0px;
  }
}

@-webkit-keyframes cd-item-move-down-mobile {
  0% {
    padding-top: 0px;
  }

  100% {
    padding-top: 62px;
  }
}

@keyframes cd-item-move-down-mobile {
  0% {
    padding-top: 0px;
  }

  100% {
    padding-top: 62px;
  }
}

@-webkit-keyframes cd-item-move-down {
  0% {
    padding-top: 0px;
  }

  100% {
    padding-top: 102px;
  }
}

@keyframes cd-item-move-down {
  0% {
    padding-top: 0px;
  }

  100% {
    padding-top: 102px;
  }
}

@-webkit-keyframes cd-item-slide-out {
  0% {
    -webkit-transform: translateX(0);
    transform: translateX(0);
    opacity: 1;
  }

  100% {
    -webkit-transform: translateX(80px);
    transform: translateX(80px);
    opacity: 0;
  }
}

@keyframes cd-item-slide-out {
  0% {
    -webkit-transform: translateX(0);
    transform: translateX(0);
    opacity: 1;
  }

  100% {
    -webkit-transform: translateX(80px);
    transform: translateX(80px);
    opacity: 0;
  }
}

@-webkit-keyframes cd-item-slide-in {
  100% {
    -webkit-transform: translateX(0);
    transform: translateX(0);
    opacity: 1;
  }

  0% {
    -webkit-transform: translateX(80px);
    transform: translateX(80px);
    opacity: 0;
  }
}

@keyframes cd-item-slide-in {
  100% {
    -webkit-transform: translateX(0);
    transform: translateX(0);
    opacity: 1;
  }

  0% {
    -webkit-transform: translateX(80px);
    transform: translateX(80px);
    opacity: 0;
  }
}

.cd-main h1 {
  color: hsl(210, 31%, 24%);
}

.cd-add-to-cart,
.cd-article-link {
  display: inline-block;
  padding: 0.75em 1.25em;
  border-radius: 50em;
  text-transform: uppercase;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-decoration: none;
  font-size: 0.83333em;
  transition: all 0.2s;
}

.cd-add-to-cart {
  background: hsl(204, 73%, 52%);
  color: hsl(0, 0%, 100%);
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.2);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.cd-add-to-cart:hover {
  background: hsl(204, 73%, 57.2%);
}

.cd-add-to-cart:active {
  -webkit-transform: scale(0.9);
  -ms-transform: scale(0.9);
  transform: scale(0.9);
}

.cd-article-link {
  color: hsl(210, 31%, 24%);
  background-color: hsl(192, 15%, 84.6%);
}

.cd-article-link:hover {
  background-color: hsl(192, 15%, 89.3%);
}
