:root {
  --gray-100: #F2F4F7;
  --gray-200: #E4E7EC;
  --gray-300: #D0D5DD;
  --gray-400: #98A2B3;
  --gray-500: #667085;
  --gray-600: #475467;
  --gray-700: #344054;
  --gray-800: #28323D;
  --gray-900: #101828;
}

:root {
  --font-size-base: 1rem;
  --font-size-lg: 1.125rem;
  --font-size-sm: font-size-sm;
  --font-size-xs: 0.75rem;
  --font-size-h1: 2.25rem;
  --font-size-h2: 2rem;
  --font-size-h3: 1.75rem;
  --font-size-h4: 1.5rem;
  --font-size-h5: 1.25rem;
  --font-size-h6: 1rem;
}

.attribute-radio__label {
  position: relative;
  margin: 0;
}
.attribute-radio__input {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%;
  cursor: pointer;
  opacity: 0;
}
.attribute-radio__input:checked ~ .attribute-radio__text {
  color: #fff;
  background-color: #101828;
  border-color: #101828;
}
.attribute-radio__text {
  display: block;
  min-width: 2.1875rem;
  padding: 4px 8px;
  font-size: 0.875rem;
  font-weight: 700;
  text-align: center;
  border: 1px solid #D0D5DD;
  border-radius: 0.4rem;
}

.product-combinations {
  margin-top: 0;
  display: flex;
  flex-flow: column nowrap;
  gap: 1rem;
}
.product-combinations-item__header {
  font-size: 0.75rem;
  margin-bottom: 0.5rem;
  color: #000;
}
.product-combinations-item__header strong {
  font-weight: 600;
}
.product-combinations-item__header.accordion-header {
  display: flex;
  gap: 4px;
  align-items: center;
}
.product-combinations-item__header.accordion-header::after {
  margin-left: auto;
  width: 0.875rem;
  height: 0.375rem;
  content: "";
  display: block;
  background: url("data:image/svg+xml,%3Csvg width='15' height='8' viewBox='0 0 15 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M14.5 0.556335L7.49991 6.55634L0.5 0.556335' stroke='black'/%3E%3C/svg%3E%0A") center center no-repeat;
  transition: transform 0.5s;
}
.product-combinations-item input[type=checkbox]:checked ~ .product-combinations-collapse .product-combinations-grid-item:not(.first-row) {
  display: flex;
}
.product-combinations-item input[type=checkbox]:checked ~ .accordion-header::after {
  transform: rotate(180deg);
}
.product-combinations-grid {
  gap: 8px;
  grid-template-columns: repeat(4, minmax(0, 1fr));
}
.product-combinations-grid .product-combinations-grid-item {
  border: 1px solid #E4E7EC;
  border-radius: 0.25rem !important;
  padding: 0.5rem 0.75rem;
  gap: 0.25rem;
  font-size: 0.75rem;
}
@media (max-width: 767.98px) {
  .product-combinations-grid .product-combinations-grid-item {
    aspect-ratio: unset;
  }
}
.product-combinations-grid .product-combinations-grid-item.selected {
  border: 2px solid #101828;
  position: relative;
}
.product-combinations-grid .product-combinations-grid-item.selected__label {
  font-weight: 700;
}
.product-combinations-grid .product-combinations-grid-item.selected::after {
  display: block;
  position: absolute;
  top: 0;
  right: 0;
  content: "";
  width: 0.75rem;
  height: 0.75rem;
  background: #101828 url("data:image/svg+xml,%3Csvg width='9' height='7' viewBox='0 0 9 7' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M3.49985 5.58545L8.09605 0.989258L8.80315 1.69636L3.49985 6.99965L0.317871 3.8177L1.02498 3.1106L3.49985 5.58545Z' fill='white'/%3E%3C/svg%3E%0A") center center no-repeat;
  border-bottom-left-radius: 0.25rem;
}
.product-combinations-grid .product-combinations-grid-item:not(.first-row) {
  display: none;
}
.product-combinations-grid .product-combinations-grid-item__img-wrapper {
  width: 3.125rem;
  height: 3.125rem;
  flex: unset;
  aspect-ratio: 1/1;
}
.product-combinations-grid .product-combinations-grid-item__img-wrapper img {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}
.product-combinations-grid .product-combinations-grid-item__label {
  max-height: 1.125rem;
  overflow: hidden;
}

.product-customization {
  margin: 24px 0;
}
.product-customization .product-customization-item {
  margin: 12px 0;
}
.product-customization .product-message {
  width: 100%;
  height: 3.125rem;
  padding: 0.625rem;
  resize: none;
  background: #F2F4F7;
  border: none;
}
.product-customization .product-message:focus {
  background-color: #fff;
  outline: 0.1875rem solid #101828;
}
.product-customization .file-input {
  position: absolute;
  left: 0;
  z-index: 1;
  width: 100%;
  height: 2.625rem;
  overflow: hidden;
  cursor: pointer;
  opacity: 0;
}
.product-customization .customization-message {
  margin-top: 20px;
}
.product-customization .custom-file {
  position: relative;
  display: block;
  width: 100%;
  height: 2.625rem;
  margin-top: 12px;
  line-height: 2.625rem;
  color: #475467;
  text-indent: 0.625rem;
  background: #F2F4F7;
}
.product-customization .custom-file button {
  position: absolute;
  top: 0;
  right: 0;
  z-index: 0;
}
.product-customization small {
  color: #475467;
}

.customization-fields {
  border: 1px solid #E4E7EC;
  border-radius: 0.5rem;
  padding: 0.75rem;
  display: flex;
  flex-flow: column nowrap;
  gap: 1rem;
  margin-bottom: 1rem;
}
.customization-fields .h2 {
  font-size: 1.25rem;
  margin: 0;
}
.customization-fields__row {
  display: flex;
  flex-flow: row wrap;
  align-items: center;
  gap: 0.5rem;
}
.customization-fields__row .adv-cust-toggle:checked ~ .adv-cust-wrap {
  display: flex;
}
.customization-fields__row label {
  font-size: 0.875rem;
  margin: 0;
}
.customization-fields__row .adv-cust-wrap {
  display: none;
  flex: 1 1 100%;
}

.product-main-images {
  position: relative;
}
.product-main-images__modal-trigger-layer {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 2;
  width: 100%;
  height: 100%;
  padding: 0;
  border: 0;
}

.product-prices {
  border: 1px solid #E4E7EC;
  border-radius: 0.5rem;
  padding: 0.75rem;
  display: flex;
  flex-flow: column nowrap;
  gap: 0.125rem;
  margin-bottom: 1rem;
}
.product-prices .tax-shipping-delivery-label {
  order: 1;
  color: #344054;
  font-size: 0.75rem;
}
.product-prices .product-price {
  order: 2;
}
.product-prices .product-price .price {
  font-size: 2.25rem;
  color: #101828;
  font-weight: 700;
  line-height: 2.75rem;
}

.product-add-to-cart .product-quantity {
  display: flex;
  gap: 0.5rem;
}
.product-add-to-cart .product-quantity .add {
  flex: 1;
}
.product-add-to-cart .product-quantity .add .btn {
  padding: 1rem 1.5rem;
  font-size: 1rem;
  max-height: unset;
}

#product-availability {
  display: flex;
  flex-flow: column nowrap;
}
#product-availability .badge {
  margin-top: 1rem;
  width: 100%;
  padding: 0.5rem 1rem;
  text-align: left;
  font-size: 0.875rem;
}

.product-container__left {
  flex: 2;
  max-width: 57.8125rem;
}
.product-container__left-top {
  grid-area: left-top;
  border: 1px solid #E4E7EC;
  border-radius: 0.75rem;
  padding: 0.625rem;
  display: flex;
  flex-flow: row nowrap;
  gap: 0.625rem;
  justify-content: space-between;
  order: 1;
}
@media (max-width: 767.98px) {
  .product-container__left-top {
    flex-flow: column-reverse nowrap;
    border: none;
    padding: 0;
  }
}
.product-container__left-top .js-product-images {
  position: relative;
  flex: 1;
  display: flex;
  justify-content: center;
}
.product-container__left-top .js-product-images .product-flags {
  top: 0;
  left: 0;
}
.product-container__left-top .product-thumbs__list {
  display: flex;
  flex-flow: column nowrap;
  gap: 0.5rem;
}
@media (max-width: 767.98px) {
  .product-container__left-top .product-thumbs__list {
    flex-flow: row nowrap;
  }
}
.product-container__left-top .product-thumbs__elem {
  width: 80px;
  height: 100%;
  aspect-ratio: 1/1;
  border: 2px solid #F2F4F7;
  border-radius: 0.5rem;
  padding: 0.5rem 0.75rem;
  display: flex;
  justify-content: center;
  align-items: center;
  cursor: pointer;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
}
@media (max-width: 767.98px) {
  .product-container__left-top .product-thumbs__elem {
    width: auto;
    flex: 1;
    max-width: calc(25% - 0.375rem);
  }
}
.product-container__left-top .product-thumbs__elem img {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}
.product-container__left-top .product-thumbs__elem p {
  margin: 0;
  color: #101828;
}
.product-container__left-top .product-thumbs__elem:hover, .product-container__left-top .product-thumbs__elem:focus {
  border-color: #D0D5DD;
}
.product-container__left-top .product-thumbs__elem.active {
  border-color: #101828;
}
.product-container__left-top .product-main-images {
  max-width: 500px;
  aspect-ratio: 1/1;
}
@media (max-width: 767.98px) {
  .product-container__left-top .product-main-images {
    max-width: 100%;
  }
  .product-container__left-top .product-main-images__list .swiper-slide {
    aspect-ratio: 1/1;
    overflow: hidden;
  }
  .product-container__left-top .product-main-images__list .swiper-slide img {
    width: 100%;
    height: 100%;
    max-width: unset;
    -o-object-fit: contain;
       object-fit: contain;
  }
}
.product-container__left-top .js-product-actions-buttons {
  width: 3.5rem;
}
.product-container__left-bottom {
  grid-area: left-bottom;
  order: 3;
}
.product-container__left-bottom #pi-banner-1 {
  margin-top: 4rem;
  padding-top: 4rem;
  border-top: 1px solid #E4E7EC;
}
@media (max-width: 767.98px) {
  .product-container__left-bottom #pi-banner-1 {
    padding-top: 0;
    border-top: 0;
    margin-top: 5rem;
  }
}

@media (max-width: 767.98px) {
  .product-tabs {
    margin-top: 3rem;
  }
}

.product-description * {
  font-size: 1rem !important;
  line-height: 1.5 !important;
}
.product-description .MsoNormal {
  margin-bottom: 40px !important;
}

.product-parameters {
  border: 1px solid #E4E7EC;
  border-radius: 0.75rem;
  padding: 1.5rem;
  margin-top: 4rem;
}
@media (max-width: 767.98px) {
  .product-parameters {
    margin-top: 5rem;
  }
}
.product-parameters__title {
  font-size: 1.125rem;
  font-weight: 600;
  line-height: 1.75rem;
  margin-bottom: 1.5rem;
}
.product-parameters__row {
  display: flex;
  flex-flow: row wrap;
  align-items: flex-start;
  gap: 2rem;
}
.product-parameters__item {
  width: 100%;
  max-width: calc(33.333% - 1.3333333333rem);
  display: flex;
  flex-flow: column nowrap;
  gap: 4px;
}
.product-parameters__item:empty {
  display: none !important;
}
.product-parameters__item .label {
  margin: 0;
}

#product-modal .js-modal-gallery {
  width: auto;
  height: 100%;
  aspect-ratio: 1/1;
  -o-object-fit: contain;
     object-fit: contain;
  margin: 0 auto;
  padding: 0;
}
#product-modal .js-modal-gallery img {
  width: 100%;
  height: 100%;
  aspect-ratio: 1/1;
  -o-object-fit: contain;
     object-fit: contain;
}

.product-container {
  display: grid;
  grid-template-columns: 1fr minmax(auto, 450px);
  grid-template-rows: auto auto;
  gap: 24px 25px;
  grid-template-areas: "left-top  right" "left-bottom right";
}
@media (max-width: 767.98px) {
  .product-container {
    display: flex;
    flex-flow: column nowrap;
    gap: 32px 0;
  }
}
.product-container__right {
  order: 2;
  grid-area: right;
}
.product-container__details {
  border: 1px solid #E4E7EC;
  background-color: #fff;
  box-shadow: 0px 12px 16px -4px rgba(16, 24, 40, 0.0784313725);
  border-radius: 0.75rem;
  padding: 1.5rem;
  margin-bottom: 1.5rem;
  gap: 1rem;
}
@media (max-width: 767.98px) {
  .product-container__details {
    padding: 0;
    box-shadow: none;
    border: none;
  }
}
.product-container__details h1 {
  font-size: 2rem;
}
.product-container__details .psi-dot-text {
  font-size: 0.75rem;
  margin-bottom: 0.25rem;
}

#product section#wrapper {
  margin-top: 0 !important;
}
