.handy-variation-form {
  --handykech-primary-color: #234c6a;

  .variations {
    display: flex;
    flex-direction: column;
    gap: 2rem;

    .variation-dropdown {
      position: relative;

      button {
        padding: 2rem;
        width: 100%;
        background-color: #f9f9f9;
        color: #000;
        border-radius: 1rem;
        border: none;
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 2rem;
        cursor: pointer;

        span {
          display: flex;
          align-items: center;
          gap: 1rem;
        }

        svg {
          width: 2rem;
          height: 2rem;
        }
      }

      .variation-options {
        position: absolute;
        top: 100%;
        left: 0;
        width: 100%;
        background-color: #fff;
        border-radius: 1.5rem;
        padding: 1rem;
        box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
        z-index: 10;
        margin-top: 0.5rem;
        transform: translateY(5px);
        opacity: 0;
        pointer-events: none;
        will-change: transform, opacity;
        transition: transform 0.3s, opacity 0.2s;

        &.open {
          pointer-events: auto;
          opacity: 1;
          transform: translateY(0);
        }

        .variation-option {
          label {
            border-radius: 1rem;
            padding: 1rem;
            display: flex;
            justify-content: space-between;
            align-items: center;
            gap: 1rem;
            width: 100%;
            color: #000;
            cursor: pointer;
            transition: background-color 0.2s ease;

            &:hover {
              background-color: #f1f1f1;
              color: #000;
            }
            &:has(input[type="radio"]:checked) {
              background-color: #f1f1f1;
            }
            > span {
              display: flex;
              align-items: center;
              gap: 1rem;

              .option-price {
                font-weight: 600;
                color: #555;
                background-color: #f1f1f1;
                padding: 0.25rem 0.5rem;
                border-radius: 0.5rem;
                font-size: 0.95rem;
              }
            }
          }
        }
      }
    }
  }

  ul {
    list-style: none;
    padding: 0;
    margin: 0;
  }

  input[type="radio"] {
    display: none;

    /* Hide checkmark by default */
    ~ svg {
      opacity: 0;
      color: var(--handykech-primary-color);
      width: 2rem;
      height: 2rem;
      transition: opacity 0.2s ease;
      flex-shrink: 0;
    }

    /* Show checkmark when checked */
    &:checked ~ svg {
      opacity: 1;
    }
  }

  [x-cloak] {
    display: none;
  }

  .quantity {
    position: relative;
    margin-top: 2rem;

    .quantity-info {
      padding: 2rem;
      width: 100%;
      background-color: #f9f9f9;
      color: #000;
      border-radius: 1rem;
      border: none;
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 2rem;
      cursor: pointer;

      > span {
        display: flex;
        align-items: center;
        gap: 1rem;
      }
      button {
        background-color: transparent;
        text-decoration: underline;
        border: none;
        border-radius: 1rem;
        cursor: pointer;
      }
    }

    .quantity-dropdown {
      position: absolute;
      top: 0;
      left: 0;
      height: 100%;
      width: 100%;
      display: flex;
      align-items: center;
      justify-content: space-between;
      background-color: #f9f9f9;
      border-radius: 1.5rem;
      padding: 1rem 2rem;
      z-index: 10;
      transform: translateY(10px);
      opacity: 0;
      pointer-events: none;
      will-change: transform, opacity;
      transition: transform 0.3s, opacity 0.2s;

      &.open {
        pointer-events: auto;
        opacity: 1;
        transform: translateY(0);
      }
      .quantity-input {
        display: flex;
        align-items: center;
        gap: 1rem;

        input {
          border: none;
          outline: none;
          width: 50px;
          height: 100%;
          background-color: transparent;
          text-align: center;
          font-size: 1.5rem;
          font-weight: 600;
          color: #000;
          box-shadow: none;

          /* Hide arrows for number input */
          &[type="number"] {
            -moz-appearance: textfield;
            /* Firefox */
          }

          &[type="number"]::-webkit-outer-spin-button,
          &[type="number"]::-webkit-inner-spin-button {
            -webkit-appearance: none;
            margin: 0;
            /* Important for Safari */
          }
        }

        span {
          cursor: pointer;
          border-radius: 50%;
          background-color: #fff;
          color: #000;
          box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
          font-size: 2rem;
          font-weight: 600;
          aspect-ratio: 1;
          height: 4rem;
          display: flex;
          align-items: center;
          justify-content: center;
          transition: all 0.3s ease;

          &:hover {
            background-color: var(--handykech-primary-color);
            color: #fff;
          }
        }
      }
      .validate {
        cursor: pointer;
        text-decoration: underline;
      }
    }
  }

  .single-add-to-cart-button {
    width: 100%;
    padding: 1.5rem 2rem;
    background-color: var(--handykech-primary-color);
    color: #fff;
    border: none;
    border-radius: 4rem;
    text-align: center;
    font-size: 1.7rem;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.3s ease;
    margin-top: 2rem;

    &:hover:not(:disabled) {
      background-color: #1a3a52;
      transform: translateY(-2px);
      box-shadow: 0 4px 12px rgba(35, 76, 106, 0.3);
    }

    &:disabled {
      opacity: 0.5;
      cursor: not-allowed;
    }
  }
  .whatsapp-form-container {
    --whatsapp-color: #25d366;

    position: relative;

    .whatsapp-form {
      position: absolute;
      bottom: 0;
      left: 0;
      width: 100%;
      min-height: 41rem;
      background-color: #fff;
      padding: 2rem;
      z-index: 10;
      box-shadow: 0 0 5px rgb(0 0 0 / 15%);
      border-radius: 2rem;
      transform: translateY(-5px);
      opacity: 0;
      pointer-events: none;
      will-change: transform, opacity;
      transition: transform 0.3s, opacity 0.2s;

      &.open {
        pointer-events: auto;
        opacity: 1;
        transform: translateY(0);
      }
      .form-header {
        display: flex;
        align-items: center;
        justify-content: space-between;
        margin-bottom: 1rem;

        button {
          background-color: transparent;
          border: none;
          cursor: pointer;
        }
      }
      .field-group {
        margin-bottom: 1.5rem;

        .required {
          color: #f00;
          font-size: 0.9em;
        }
        label {
          margin: 0;
          color: #000;
          font-weight: 600;
        }
        input {
          border-radius: 10px;
          padding-block: 0.3rem;
        }
      }
    }

    @media (max-width: 476px) {
      .whatsapp-form {
        position: fixed;
        bottom: 0;
        left: 0;
        right: 0;
        z-index: 100;
        box-shadow: 0 0 5px rgb(0 0 0 / 15%), 0 0 0 2000px rgb(0 0 0 / 15%);
        border-radius: 2rem 2rem 0;
        transform: translateY(100%);
        opacity: 0;
        pointer-events: none;
        will-change: transform, opacity;
        transition: transform 0.3s, opacity 0.2s;

        &.open {
          pointer-events: auto;
          opacity: 1;
          transform: translateY(0);
        }
      }
    }

    .toggle-whatsapp-form {
      width: 100%;
      padding: 1.5rem 2rem;
      background-color: #fff;
      border: 2px solid #000;
      border-radius: 4rem;
      font-size: 1.7rem;
      text-align: center;

      span {
        color: var(--whatsapp-color);
      }
    }
    .order-via-whts {
      padding: 1.5rem 2rem;
      border-radius: 4rem;
      font-weight: 600;
      background-color: #000;
      color: #fff;
      width: fit-content;
      margin-top: 2rem;
      margin-left: auto;
      display: flex;
    }
  }
}
