.cart-terms-popup {
  --overlay-color: rgba(0, 0, 0, 0.4);
  --drawer-background-color: white;
  --drawer-border-radius: 1rem;
  --drawer-padding: 2rem;
  --drawer-box-shadow: 0 -4px 20px rgba(0, 0, 0, 0.2);
  --transition-duration: 0.3s;
  --transition-ease: ease-out;
  --drawer-max-height: 80vh;
  position: absolute;
  inset: 0;
  pointer-events: auto;
  z-index: 9999;

  .cart-terms-popup__overlay {
    position: absolute;
    inset: 0;
    background-color: var(--overlay-color);
  }

  .cart-terms-popup__drawer {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    max-height: var(--drawer-max-height);
    background: var(--drawer-background-color);
    border-top-left-radius: var(--drawer-border-radius);
    border-top-right-radius: var(--drawer-border-radius);
    padding: var(--drawer-padding);
    box-shadow: var(--drawer-box-shadow);
    overflow-y: auto;
    display: flex;
    flex-direction: column;
    gap: 1.5rem;

    >p {
      text-align: center;
      margin: 0;
    }

    .buttons {
      align-items: center;
      gap: 1rem;
      display: flex;
      justify-content: center;

      >.button {
        flex: 1;
      }
    }
  }

  .transition-enter {
    transition: transform var(--transition-duration) var(--transition-ease), opacity var(--transition-duration) var(--transition-ease);
  }

  .transition-enter-start {
    transform: translateY(100%);
    opacity: 0;
  }

  .transition-enter-end {
    transform: translateY(0);
    opacity: 1;
  }

  .transition-leave {
    transition: transform var(--transition-duration) var(--transition-ease), opacity var(--transition-duration) var(--transition-ease);
  }

  .transition-leave-start {
    transform: translateY(0);
    opacity: 1;
  }

  .transition-leave-end {
    transform: translateY(100%);
    opacity: 0;
  }
}
