.ch_row{
  display: block;            /* default (mobile first) */
  padding-top: 2.5rem;       /* py-10 = 40px */
  padding-bottom: 2.5rem;
  gap: 1.25rem;              /* gap-5 = 20px */
  justify-content: space-between;
}


.error_message_cupon{color:#B61417;display: block;font-weight: 600;margin-top: 6px;}


.upsell-card {
  cursor: pointer;
  background: #F8FDFF;
  border: 1px solid #179BD7;
  border-radius: 1rem;
  padding: 0.75rem;
  outline: none;
  transition: box-shadow 0.2s ease;
  display: block;
  margin-bottom: 1rem;
}

/* Hide default checkbox */
.upsell-checkbox {
  display: none;
}

.upsell-content {
  display: flex;
  gap: 1rem;
  align-items: flex-start;
}

.upsell-radio {
    width: 19px;
    height: 19px;
    border-radius: 50%;
    border: 1px solid #aeaeae;
    background: none;
    flex-shrink: 0;
    margin-top: 0.25rem;
    transition: background 0.2s 
ease, border-color 0.2s 
ease;
}

.upsell-checkbox:checked + .upsell-content .upsell-radio {
    background: #fff;
    border: 6px solid #1773B0;
}

.upsell-title {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 1.125rem;
  font-weight: 700;
}

.upsell-text {
  font-size: 0.875rem;
  margin-top: 0.25rem;
}

.upsell-text .highlight {
  color: #dc2626;
  font-weight: 700;
}

/* Each item */
.feature-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}

/* SVG Icon */
.feature-icon {
  width: 33px;   /* h-[33px] */
  height: 33px;  /* w-[33px] */
}



/* Outer card */
.quantity-card {
  margin-bottom: 1rem;       /* mb-4 */
  border-radius: 1rem;       /* rounded-2xl */
  background: #fff;          /* bg-white */
  padding: 0.75rem;          /* p-3 */
  text-align: center;
}

/* Header */
.quantity-header {
  display: flex;
  align-items: center;
  gap: 0.5rem;               /* gap-2 */
}

.quantity-icon {
  width: 20px;
  height: 20px;
  fill: none;
}

.quantity-title {
  text-align: left;
  font-size: 15px;
  font-weight: 700;          /* bold */
  text-transform: uppercase;
}

/* Divider */
.quantity-divider {
  height: 1px;
  background: #e0e0e0;
  margin: 0.5rem 0;
}

/* Options wrapper */
.quantity-options {
  margin-top: 0.625rem;      /* mt-2.5 */
  display: flex;
  flex-direction: column-reverse;
  gap: 0.75rem;              /* gap-3 */
}


.quantity-option:hover {
  box-shadow: 0 2px 6px rgba(0,0,0,0.15);
}

.quantity-option:focus {
  outline: none;
  box-shadow: 0 0 0 3px #F79E1B;
}

.quantity-option.active .quantity-label {
  background-color: #F79E1B;
  box-shadow: 0 2px 8px rgba(247, 158, 27, 0.3);
  
}
.quantity-option.active .quantity-label span{
color: #fff;
}

.quantity-option.active{
  border: 1px solid #F79E1B;
}

.quantity-option.active .quantity-body{
   background: linear-gradient(to bottom, #ffffff, #ffffff, #FFF6E8);
}



.review-section {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

/* Customer Review */
.review-card {
  display: flex;
  gap: 0.75rem;
  background: #fff;
  padding: 0.75rem;
  border-radius: 1rem;
}

.review-avatar {
  width: 40px;
  height: 40px;
  border-radius: 9999px;
  object-fit: cover;
}

.review-name {
  font-size: 0.875rem;
  font-weight: 600;
}

.review-text {
  padding: 0.5rem 0;
  font-size: 0.875rem;
  font-weight: 600;
}

.review-verification {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.75rem;
  margin-top: 0.5rem;
}

/* Guarantee Grid */
.guarantee-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.6rem;
  background: #fff;
  padding: 0.75rem;
  border-radius: 1rem;
}


.guarantee-item {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  font-size: 0.8rem;
  font-weight: 500;
}

/* 

.upsell-card {
  cursor: pointer;
  background: #F8FDFF;
  border: 1px solid #179BD7;
  border-radius: 1rem;
  padding: 0.75rem;
  outline: none;
  transition: box-shadow 0.2s ease;
}

.upsell-card:focus {
  box-shadow: 0 0 0 2px #179BD7;
}

.upsell-content {
  display: flex;
  gap: 1rem;
  align-items: flex-start;
}

.upsell-radio {
  width: 19px;
  height: 19px;
  border-radius: 50%;
  border: 6px solid #1773B0;
  background: #fff;
  flex-shrink: 0;
  margin-top: 0.25rem;
}

.upsell-title {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 1.125rem;
  font-weight: 700;
}

.upsell-text {
  font-size: 0.875rem;
  margin-top: 0.25rem;
}

.upsell-text .highlight {
  color: #dc2626; 
  font-weight: 700;
}

 */





/* Each option */
.quantity-option {
  display: flex;
  flex-direction: column;
  overflow: hidden;
  border-radius: 1rem;       /* rounded-2xl */
  border: 1px solid #e0e0e0; /* default border */
  cursor: pointer;
  transition: all 0.3s ease;
}

.quantity-option:hover {
  box-shadow: 0 2px 8px rgba(0,0,0,0.1);
}

.quantity-option:focus {
  outline: none;
  box-shadow: 0 0 0 2px #f79e1b;
}

/* Special selected state */
.quantity-option[aria-checked="true"] {
  border-color: #f79e1b;
}

/* Option header label */
.quantity-label {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.625rem;
  padding: 0.5rem 5rem;
  background: #e0e0e0;
  text-align: center;
}

.quantity-label span {
  font-size: 0.875rem;       /* text-sm */
  font-weight: 700;
  text-transform: uppercase;
  white-space: nowrap;
  color: #000;
}

/* Special BEST VALUE label */
.quantity-option[aria-checked="true"] .quantity-label {
  background: #f79e1b;
}

.quantity-option[aria-checked="true"] .quantity-label span {
  color: #fff;
}

/* Option body */
.quantity-body {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.75rem 2.75rem 0.75rem 1.25rem;
  background: #fff;
  border-radius: 0 0 1rem 1rem;
}

/* Gradient background for BEST VALUE */
.quantity-option[aria-checked="true"] .quantity-body {
  background: linear-gradient(to bottom, #fff, #fff, #fff6e8);
}

/* Image */
.quantity-img {
  width: auto;
  height: 116px;
  object-fit: contain;
}

/* Text info */
.quantity-info {
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.quantity-count {
  font-size: 34px;
  font-weight: 700;
  color: #333;
}

.quantity-name {
  margin-bottom: 0.25rem;
  font-size: 0.75rem;
  color: #333;
}

.quantity-price {
  font-size: 1.5rem;         /* text-2xl */
  font-weight: 700;
  color: #333;
}

.quantity-oldprice {
  font-size: 0.875rem;
  text-decoration: line-through;
  color: #a8a8a8;
}


/* Section titles */
.form-section h2 {
  font-size: 18px;
  font-weight: 600;
  margin-bottom: 14px;
}

.form-section h2 span{
  display: block;
  font-size: 14px;
   font-weight: normal;
   margin-top: 8px;
   color: #707070;
}

/* Label */
.form-label {
  display: block;
  font-size: 14px;
  margin: 10px 0 5px;
  font-weight: 500;
}

form .form-input {
  width: 100%;
  padding: 0 14px !important;
  border: 1px solid #ccc !important;
  border-radius: 6px !important;
  font-size: 14px !important;
  transition: border 0.2s ease-in-out, box-shadow 0.2s ease-in-out;
  height: 51px !important;
}

/* Focus effect */
.form-input:focus {
  border-color: #000;
  box-shadow: 0 0 0 2px rgba(0,0,0,0.1);
  outline: none;
}

/* Grid rows */
.form-row {
  display: flex;
  gap: 15px;
  margin-bottom: 0 !Important;
  }

.form-row .form-input {
  flex: 1;
}



/* Accordion wrapper */
.pay-accordion {
  font-size: 14px;
  background: #F5F5F5;
  border: 1px solid #DEDEDE;
  border-radius: 5px;

}

.pay-row{
background: #fff;

}
.pay-row-card{
border-radius: 5px 5px 0px 0px;
}

.pay-row-paypal{
border-radius:  0px 0px 5px 5px;
}



.payment_form{
  padding: 16px;
      border: 1px solid #DEDEDE;
      border-left: 0;
      border-right: 0;

}

/* Radio row */
.pay-row .pay-control {
  padding: 9px 17px 9px 34px;
  position: relative;
  display: flex;
  min-height: 1.6rem;
  justify-content: space-between;
  align-items: center;
  /* background: #EFF5FF; */
}

/* Hide native input */
.pay-control-input {
  position: absolute;
  left: 0;
  z-index: -1;
  width: 1rem;
  height: 1.3rem;
  opacity: 0;
  padding: 0;
  box-sizing: border-box;
}

/* Radio label */
.pay-control-label {
  position: relative;
  margin-bottom: 0;
  vertical-align: top;
  cursor: pointer;
}

/* Custom radio design */
.pay-control-label:before,
.pay-control-label:after {
  position: absolute;
  top: 2px;
  left: -25px;
  display: block;
  width: 19px;
  height: 19px;
  content: "";
  border-radius: 50%;
  border: 1px solid #adb5bd;
  transition: all .15s ease-in-out;
}

/* Checked state */
.pay-control-input:checked ~ .pay-control-label:before {
  /* border-color: #1773B0; */
  background-color: #1773B0;
  background-image: url(../images/bullet-white.png?v=4);
  background-size: 37%;
  background-position: center;
  background-repeat: no-repeat;
}

/* Card inner row */
.pay-card-inner {
  padding: 10px 20px;
}

/* Small row styling */
.pay-small-row {
  margin-top: 5px;
}

/* Dropdown */
.pay-select {
  padding: 6px 10px;
  border: 1px solid #ccc;
  border-radius: 5px;
  font-size: 14px;
}

/* Icons container */
.pay-icons {
  display: flex;
  text-align: right;
}

/* Card icons */
.pay-icon {
  height: 28px !important;
  width: auto !important;
  border-radius: 5px;
  margin-left: 6px;
}

.form-holder{
  margin-bottom: 16px;
}


    .checkbox-container {
      display: flex;
      align-items: center;
      font-size: 14px;
      cursor: pointer;
      user-select: none;
    }

    /* Hide default checkbox */
    .checkbox-container input {
      display: none;
    }

    /* Custom box */
    .checkmark {
      width: 20px;
      height: 20px;
      background-color: #1773B0; /* blue background */
      border-radius: 4px;
      display: inline-block;
      position: relative;
      margin-right: 10px;
    }

    /* Tick mark */
    .checkmark::after {
      content: "";
      position: absolute;
      left: 7px;
      top: 3px;
      width: 6px;
      height: 12px;
      border: solid white;
      border-width: 0 2px 2px 0;
      transform: rotate(45deg);
      display: none;
    }

    /* Show tick when checked */
    .checkbox-container input:checked + .checkmark::after {
      display: block;
    }

    .active_radio{
          border: 1px solid #1773B0;
    background: #EFF5FF;
    }
    .pay_btn{
      margin-top: 30px;
    }

    .pay_btn button{
      background: #000;
      color: #fff;
      text-align: center;
      width: 100%;
      padding: 16px 0;
      border-radius: 7px;
      font-weight: 600;
      font-size: 18px;
    }


    .wrap_paypal_top{
      box-sizing:border-box;
      text-align:center;
    }

    .heading_paypal_top{
      color: #777;
      font-weight:500;
      margin-bottom: 11px;
      font-size: 15px;
    }

    .paypal-btn{
      background: #ffcc4d;
      border-radius: 8px;
      padding: 12px 20px;
      display:flex;
      align-items:center;
      justify-content:center;
      height: auto;
      cursor: pointer;
      border: none;
      width: 100%;
    }

    .paypal-logo{
      display:flex;
      align-items: center;
      gap:8px;
      /* font-family: Arial, sans-serif; */
      font-weight:700;
      /* font-size: 24px; */
    }

    .pp-mark{
      width:32px;
      height:32px;
      border-radius:5px;
      display:flex;
      align-items:center;
      justify-content:center;
      font-weight:800;
      color: #fff;
      background: #003087;
      font-size:18px;
    }

    .pp-word{
      font-size: 24px;
      color: #003087;
    }

    .or-row{
      display:flex;
      align-items:center;
      gap:12px;
      margin-top: 15px;
      margin-bottom: 25px;
    }

    .or-row .line{
      height:1px;
      background: #ddd;
      flex: 1;
    }

    .or-text{
      color: #777;
      font-weight:500;
      font-size:14px;
    }


  .coupon-box {
      display: flex;
      align-items: center;
      justify-content: space-between;
      border: 1px solid #e0dfdb;
      border-radius: 8px;
      background: #fff;
      padding: 19px 20px;
      margin: 40px auto;
    }

    .coupon-box h3 {
      font-size: 23px;
      font-weight: normal;
      color: #1a0e0e;
      margin: 0;
      padding-left: 9px;
    }

    .coupon-form {
      display: flex;
      /* align-items: center; */
      gap: 10px;
    }

    .coupon-form input { 
      padding: 0 14px !important;
      border: 1px solid #ccc !important;
      border-radius: 6px !important;
      font-size: 14px !important;
      outline: none !important;
      height: 51px !important;
    }

    .coupon-form input:focus {
      border-color: #000;
    }

    .coupon-form button {
      padding: 15px 28px;
      border: none;
      border-radius: 6px;
      background: #000;
      color: #fff;
      font-size: 14px;
      font-weight: 600;
      cursor: pointer;
      transition: 0.2s;
    }

    .coupon-form button:hover {
      background: #333;
    }


     input.no-error, select.no-error {
  appearance: none;
  -webkit-appearance: none; /* Safari/Chrome */
  -moz-appearance: none;    /* Firefox */
}

.coupon_input {
    width: 264px;
}

select {
       color: #a5a5a5 !important;
}


.form-holder{
    position:relative;
}


.popover_part {
    position: absolute;
    z-index: 99;
    right: 9px;
    top: 17px;
}

.popover__wrapper { 
    position: relative;
    display: inline-block;
    cursor: pointer;
}
.popover__title {
    position: relative;
    right: 2px;
    top: 0px;
    width: 19px;
} 

.popover__content {
    opacity: 0;
    visibility: hidden;
    position: absolute;
    right: -58px;
    top: -84px;
    transform: translate(0, 10px);
    background-color: #666;
    padding: 10px;
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.26);
    width: 142px;
    color: #fff;
    border-radius: 5px;
    text-align: center;
    font-size: 12px;
    line-height: 15px;
    transition: all 0.3s ease-in-out;
}

.popover__wrapper:hover .popover__content {
    opacity: 1;
    visibility: visible;
    transform: translate(0, 0);
}



@media (max-width: 768px) {
div#coupon-box {
  display:block;
          display: block;
        margin: 15px 0 0 0;
}

.coupon-form{
display:flex;
justify-content: space-between;
}

.coupon_input {
    width: 65%;
}
.ch_row {
    padding-top: 1rem;

}

.pay-control-label:before, .pay-control-label:after {
    position: absolute;
    top: 0px;
}


.coupon-form input {
    min-width: auto !important; 
}
.checkmark {
    width: 27px;

}

.popover__content {
    right: -18px; 

} 

.coupon_button {
    width: 36%;
}

.coupon-form button {
    padding: 15px 0;
} 
#coupon-form{
       padding: 0px;
}
.coupon-box {
        padding: 6px 14px 14px 14px;
    }
    .coupon-box h3 {
    padding-left: 0;
    margin-bottom: 11px;
}


}




@media (min-width: 768px) {

  .quantity-options {
    display: grid;
    grid-template-columns: 1fr; /* md:grid-cols-1 */
  }
    .guarantee-grid {
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
  }

.ch_row {
    display: flex;           /* md:flex */
    padding-top: 2rem;       /* md:py-20 = 80px */
    padding-bottom: 5rem;
  }


  .feature-icon {
    width: 47px;  /* md:w-[47px] */
    height: 47px; /* md:h-[47px] */
  }

  /* Container */
.feature-box {
  display: flex;
  justify-content: space-around; /* justify-around */
  background-color: #fff;        /* bg-white */
  border-radius: 1rem;           /* rounded-2xl */
  padding: 1rem;                 /* p-4 */
  margin-bottom: 1rem;           /* mb-4 */
}


  /* Text */
.feature-text {
  margin-top: 0.5rem;      /* mt-2 */
  max-width: 70px;         /* max-w-[70px] */
  font-size: 10px;         /* text-[10px] */
  font-weight: 600;        /* font-semibold */
  line-height: normal;     /* leading-[normal] */
  color: #333;             /* text-[#333] */
  text-align: center;
}

  .feature-text {
    margin-top: 1rem;       /* md:mt-4 */
    max-width: 117px;       /* md:max-w-[117px] */
    font-size: 0.875rem;    /* md:text-sm = 14px */
  }

}



@media (min-width: 1280px) {
  .quantity-options {
    grid-template-columns: repeat(2, 1fr); /* xl:grid-cols-2 */
  }
}

@media (max-width: 768px) {

.form-container {
    margin-left: -1em;
    margin-right: -1em;
    padding: 19px;
    margin-top: 20px;
}

    .feature-box {
        display: flex;
        justify-content: space-around;
        background-color: #fff;
        border-radius: 1rem;
        padding: 1rem;
        margin-bottom: 1rem;
    }
    p.feature-text{
      font-size: 10px;
      line-height: normal;
          margin-top: .5rem;
    }
     .feature-box  img{
      width: 33px;
      height: 33px;
     }

     .form-row{
      flex-direction: column;
     }

}


@media (max-width: 768px) {
.coupon-form input{

}
}
