@layer page {
  #page-title {
    font-size: 1.5rem;
    @media( width >= 782px ) {
      font-size: 3rem;
    }
  }
  .cart-page {
    margin-block: 1.25rem 3rem;
     
    header {
      margin-block-end: 1.5rem;
    }
 
  }

  @media( width >= 1024px) {
    .cart-page {
      margin-block-end: 5.5rem;
    }
  }

  .woocommerce-cart-form {
    display: grid;
    grid-template-columns: 1fr minmax(auto, 16.125rem);
    column-gap: 2.1875rem;
    row-gap: 1.5rem;

    .cart__summary {
      grid-column: 2;
      grid-row: 1 / span 2;
    }
  }

  @media( width <= 781px) {
    .woocommerce-cart-form {
      display: flex;
      flex-direction: column;
      row-gap: 2rem;
    }
  }

  .cart__pickup-date-handler {
    font-weight: 500;
    font-size: 1rem;     
    line-height: 1.5;
    display: flex;
    align-items: center;
    gap: .625rem;
    margin-block-start: 2.5rem;

    &:first-letter {
      text-transform: uppercase;
    }
  }

 

  @media( width >= 781px) {
    .cart__pickup-date-handler {
      margin-block-start: 2.125rem;
    }
  }

  .cart__pickup-date {
    font-weight: 400;
    font-size: 1.3125rem;
    border: none;
    background: transparent;
    padding: 0;
    width: 7.5rem;
    text-align: center;

    &:focus-visible {
      outline: none;
    }
  }

  .cart__pickup-date-wrapper {
    position: relative;
    
    &::after {
      content: '';
      background: var(--color-accent);
      position: absolute;
      width: 100%;
      height: 4px;
      z-index: -1;
      border-radius: 1rem;
      left: 0;
      bottom: 7px;
    }

  }

  .cart__edit-pickup-date span {
    text-decoration: underline;
    cursor: pointer;
  }

  .cart__options-heading,
  .cart__extras-heading,
  .cart__summary-heading {
    font-size: 1.5rem;
    line-height: 1.5;
    font-weight: 400;
    margin-block-end: .9375rem;

    &:first-letter {
      text-transform: uppercase;
    }
  }
}

.cart__extras {
  margin-block-start: 1.4375rem;
}

.cart__options-options,
.cart__extra-extra {
  padding-left: 0;
  list-style-type: none;
  display: flex;
  flex-direction: column;
  gap: .625rem;
}

.cart__option,
.cart__extra {
  position: relative;
  background: var(--color-neutral-lighter);
  padding: 1.25rem;
  display: flex;
  gap: .9375rem; 
  align-items: flex-start;
  border: 0.1rem solid color-mix(in srgb, var(--color-neutral), transparent 85%);
  border-inline-start: 0.3125rem solid color-mix(in srgb, var(--color-neutral), transparent 85%);
  transition: all 0.3s ease-out;
  filter: drop-shadow(0.2rem 0.2rem 0rem color-mix(in srgb, var(--color-blue-light) 0%, transparent));


  label {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    inline-size: 100%;
    cursor: pointer; 
    align-self: stretch;
    justify-content: space-between;
  }

  input[type="radio"],
  input[type="checkbox"] {
    width: 1.5625rem;
    height: 1.5625rem;
    position: relative;
    appearance: none;
    -webkit-appearance: none;
    outline: none;
    border: 1px solid var(--color-neutral-dark);
    border-radius: 50%;
    cursor: pointer;
    background-color: #fff;
    transition: all 0.3s ease;
    flex-shrink: 0;
  }

  input[type="checkbox"] {
    border-radius: 0;
  }


  input[type="radio"]:checked::after,
  input[type="checkbox"]:checked::after {
    content: '✔';
    display: block;
    font-size: 1rem;
    color: var(--color-blue-light);
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}
}

:is(.cart__option, .cart__extra):hover {
  filter: drop-shadow(0.2rem 0.2rem 0rem color-mix(in srgb, var(--color-blue-light) 20%, transparent));
}

.cart__option:has(input:checked),
.cart__extra:has(input:checked) {
  border-inline-start-color: var(--color-blue-light);
  background: color-mix(in srgb, var(--color-blue-light), white 90%);

  .cart__option-title,
  .cart__extra-title {
    font-weight: 700;
}
}

.cart__option-title,
.cart__extra-title {
  font-size: 1rem;
  line-height: 1.5;
}

.cart__option-price {
  display: flex;
  flex-direction: column;
}
.cart__option-price-total,
.cart__extra-price-total {
  font-size: 1.5rem;
}

.cart__option-price-string {
  font-size: 0.85rem;
}

.cart__summary {
  font-weight: 600;
  font-size: .875rem;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  .cart__summary-heading {
    margin-block-end: .3rem;
  }
}

.cart__summary-heading {
  margin-block-end: -.4375rem;
}

.cart__summary-thumb {
  @media (width <= 781px) {
    display: none;
  }
}

.cart__summary-thumb img {
    width: 100%;
    height: 150px;
    max-width: 350px;
    object-fit: cover;
}

.cart__summary-back-to-product-page a {
  color: #000;
  font-size: .8125rem;
  font-weight: 500;
  margin-block-end: 1.375rem;
}

.wc-proceed-to-checkout {
  width: 100%;
  text-align: center;
}

.cart__summary-total-price-price {
  display: block;
  font-size: 1.5rem;
  line-height: 1.5;
  font-weight: 400;
}

.cart__back-to-product {
  display: flex;
  align-items: center;
  gap: .625rem;
  margin-block-start: 5rem;

  a {
    text-transform: uppercase;
    font-size: .8125rem;
    line-height: 1.5;
    text-decoration: none;
    color: #000;
    display: inline-block
  }

  &::before {
    content: '';
    width: 5px;
    height: 5px;
    border-left: 2px solid #000;
    border-bottom: 2px solid #000;
    transform: rotate(45deg);
  }
}

.cart__back-to-product.cart__desktop {
  display: none;
}

@media( width >= 782px) {
  .cart__back-to-product.cart__desktop {
    display: flex;
  }
}

@media( width >= 782px) {
  .cart__back-to-product.cart__mobile {
    display: none;
  }
}

.cart__summary-terms-and-conditions {
  display: flex;
  padding-inline-start: .375rem;
  gap: 1.1875rem;
  align-items: center;
  font-weight: 400;
  line-height: 1.1;

  input {
    width: 1.125rem;
    height: 1.125rem;
    position: relative;
    appearance: none;
    -webkit-appearance: none;
    outline: none;
    border: 2px solid #000;
    cursor: pointer;
    background-color: #fff;
    transition: all .3s ease;
    flex-shrink: 0;
    border-radius: .2rem;
  }

  input:checked::after {
    content: '✔';
    display: block;
    font-size: .75rem;
    color: var(--color-blue-light);
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
  }
}