body {
    margin: 0 auto;
    font-size: 16px;
    padding: 0;
    font-family: "Inter", sans-serif;
    color: #000;
}
::selection{
    background-color: #2196f3;
    color: #fff;
}
h1,
h2,
h3,
h4,
h5,
h6,
.h1,
.h2,
.h3,
.h4,
.h5,
.h6 {
    color: #000;
}
a, button{
    transition: all 0.5s ease;
    -moz-transition: all 0.5s ease;
    -ms-transition: all 0.5s ease;
    -o-transition: all 0.5s ease;
    -webkit-transition: all 0.5s ease;
    outline: 0;
    color: #1E1E1E;
    text-decoration: none;
}
a:hover{
    outline:none;
    color:#1d1d1d;
    text-decoration:none;
}
img{
    max-width:100%;
}
.app-view {
    height:100vh;
    min-height:100%;
}
.app-wrapper {
    width: 100%;
    margin: auto;
    min-height: 100%;
    background: url(../images/background-img.png) no-repeat bottom center / cover;
    background-attachment: fixed;
    display: flex;
    flex-direction: column;
    justify-content:start;
    max-width: 520px;
    background-size: 610px;
    padding-top: 50px;
}

.app-body{
    padding:25px 20px 0;
}
.otp-container {
    margin-top: 60px;
}
.otp-container .form-group label{
    margin-bottom:10px;
    color:#1E1E1E;
    font-weight: 600;
    line-height: 26px;
    letter-spacing: -2%;
}
.otp-container .input-group {
    display: flex;
    align-items: center;
    background: #fff;
    border-radius: 8px;
    padding:0;
    margin-bottom: 20px;
    border:0;
    flex-wrap: nowrap;
}
.otp-container .input-group span {
    font-size: 14px;
    padding:10px 20px;
    color: #939393;
}
.otp-container .input-group input {
    border: none;
    width: 100%;
    background: transparent;
    border-left: 1px solid #D2D2D2;
    outline: 0;
    box-shadow: none !important;
    font-weight: 400;
    font-size: 14px;
    line-height: 26px;
    padding: 12px 18px;
}
input[type=number]::-webkit-inner-spin-button, 
input[type=number]::-webkit-outer-spin-button { 
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    margin: 0; 
}
.otp-box {
    display: flex;
    justify-content: space-between;
    margin-bottom: 20px;
    gap: 20px;
}
.otp-box input {
    width: 100%;
    height: 50px;
    text-align: center;
    font-size: 18px;
    border: 1px solid #bbb;
    border-radius: 8px;
    outline: none;
    transition: 0.3s;
    background: #fff;
}
.otp-box input:focus {
    border-color: #c9102e57;
    box-shadow: 0 0 5px #c9102e8f;
}
.btn {
    background: #1E1E1E;
    color: #fff;
    font-size: 15px;
    font-weight: 600;
    border: none;
    border-radius: 5px;
    width: 100%;
    padding: 13px 0;
    cursor: pointer;
    transition: 0.3s;
}
.btn:hover{
    background:#000;
    color:#fff;
}
.resend-text{
    text-align:center;
    margin-top:10px;
    font-size:13px;
    color:#fff;
}
.resend-text a{
    color: #fff;
    text-decoration: none;
    font-weight: 600;
    text-decoration:underline;
}
.resend-text a:hover{
    text-decoration:none;
}
.otp-section{
    display:none;
}
.otp-section.show{
    display:block;
}

.check-list ul{
    list-style:none;
    padding:0;
    margin:0;
}
.selectOption {
    background: radial-gradient(2.03% 50% at 50% 50%, #F53E02 0%, rgba(245, 62, 2, 0.58) 100%), linear-gradient(0deg, #FFFFFF 0%, rgba(255, 255, 255, 0) 100%);
    padding: 1px;
    border-radius: 10px;
}
.optionBox{
    background: #796b6b;
    padding: 37px 19px;
    border-radius: 10px;
}
.selectOption ul{
    margin:0;
}
.optionBox li{
    background: #fff;
    padding: 20px;
    margin-bottom: 30px;
    border-radius: 5px;
    text-align: center;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 20px;
    font-weight: 800;
    font-size: 16px;
    line-height: 26px;
    text-transform: uppercase;
}
.optionBox li:last-child{
    margin-bottom: 0px;
}
.back-btn{
    color: #fff;
}
.back-btn span {
    width: 18px;
    height: 18px;
    background: #fff;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
}
.accordion .accordion-item:not(:last-child) {
    margin-bottom: 30px;
}
.accordion .accordion-item {
    border: 0;
    border-radius: 10px;
    background: #E4E4E4;
}
.accordion .accordion-item .accordion-button {
    border-radius: 10px;
    font-weight: 600;
    font-size: 16px;
    line-height: 26px;
    color: #1E1E1E;
    box-shadow:none;
    outline:0;
}
.accordion .accordion-button:not(.collapsed){
    background:#fff;
    box-shadow:none;
}
.accordion .accordion-body{
    background:transparent;
    padding:17px;
}
.accordion .accordion-button::after{
    display:none;
}
.form-invoice .form-group{
    margin-bottom:10px;
    width:100%;
}
.form-group .form-control{
    padding: 8px 16px;
    font-weight: 400;
    font-size: 14px;
    line-height: 26px;
    border-radius: 8px;
    color: #1E1E1E;
    outline:0;
    box-shadow:none;
}
.form-group .form-control::placeholder {
  color:#1E1E1E;
}
.form-group .form-control::-ms-input-placeholder {
  color:#1E1E1E;
}
.custom-file{
  position:relative;
  display:inline-block;
}
.custom-file input[type="file"]{
  display:none;
}
.custom-file label{
    background-color:#fff;
    padding: 8px 16px;
    font-weight: 400;
    font-size: 14px;
    line-height: 26px;
    border-radius: 8px;
    color: #1E1E1E;
    width:100%;
}
.file-name{
  margin-left:10px;
}
.invoice-bx .accordion{
    margin-top:40px;
}
.thankyouBx {
    background: #FFFFFF;
    box-shadow: 0px 0px 10px 2px #00000040;
    border-radius: 10px;
    padding: 0 12px 40px;
}
.thankyouIcon {
    background: #D20A28;
    height: 120px;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    /*clip-path: circle(72% at 50% -60%);*/
    clip-path: ellipse(50% 100% at 50% 0%);
    margin-bottom: 30px;
}
.thankyouBx h3 {
    font-weight: 700;
    font-size: 20px;
    line-height: 26px;
}
.thankyouBx p {
    font-weight: 500;
    font-size: 16px;
    line-height: 26px;
    color: #1E1E1E;
    max-width: 80%;
    margin: auto;
}
.thankyouBx {
    background: #FFFFFF;
    box-shadow: 0px 0px 10px 2px #00000040;
    border-radius: 10px;
    padding: 0 12px 40px;
    margin-top: 20%;
}
/*.rewardBx {
    margin-top: 22px;
}*/
.totalReward {
    margin-bottom: 18px;
}
.totalRewardBx {
    background: #D9D9D9;
    border: 4px solid #5A5A5A;
    width: 255px;
    height: 255px;
    border-radius: 50%;
    margin: auto;
    display: flex;
    align-items: center;
    justify-content: center;
}
.bgReward {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 220px;
    height: 220px;
    background: #fff;
    box-shadow: 0px 6px 7px 0px #000000BF;
    border-radius: 50%;
    border: 2px solid #969696;
    font-weight: 900;
    font-size: 50px;
    line-height: 100%;
    color: #D20A28;
    font-family: sans-serif;
}
.totalReward span {
    background: #D20A28;
    box-shadow: 0px 2px 4.3px 0px #5A5A5A66;
    padding: 16px 15px;
    font-weight: 800;
    font-size: 28px;
    line-height: 28px;
    color: #fff;
    border-radius: 6px;
    margin: auto;
    margin-top: -60px;
    display: block;
    position: relative;
    max-width: fit-content;
}
.redeemPoints {
    font-weight: 700;
    font-size: 18px;
    line-height: 100%;
    color: #D20A28;
    background: #fff;
    border: 1px solid #5A5A5A;
    box-shadow: 0px 2px 4.3px 0px #5A5A5A66;
    padding: 10px 32px;
    border-radius: 6px;
    display: inline-block;
}
.pointBalance {
    display: flex;
    gap: 20px;
    margin-top: 20px;
}
.pointBalance .pointBx {
    background: #fff;
    display: flex;
    flex-direction: column;
    box-shadow: 0px 2px 4.3px 0px #5A5A5A66;
    border-radius: 6px;
    padding: 8px;
    width: 50%;
    font-weight: 400;
    font-size: 12px;
    line-height: normal;
    color: #1E1E1E;
}
.pointBalance .pointBx span {
    font-weight: 900;
    font-size: 22px;
    line-height: normal;
    color: #5A5A5A;
    font-family: sans-serif;
}
.rewardsDate {
    font-weight: 600;
    font-size: 12px;
    line-height: 18px;
    text-align: center;
    color: #fff;
}
.rewardsDate span {
    display: block;
    font-weight: 700;
    font-size: 15px;
    line-height: 18px;
}
.redeemCatalogue{
    background: #D20A28;
    box-shadow: 0px 2px 4.3px 0px #5A5A5A66;
    font-weight: 700;
    font-size: 20px;
    line-height: 100%;
    color: #FFFFFF;
    padding: 11px 23px;
    border-radius: 6px;
    display: inline-block;
    position: relative;
    z-index: 1;
}
.rewardCoupon.notRedem {
    max-height: calc(100vh - 267px);
}
.rewardCoupon {
    background: #E8E8E8;
    box-shadow: 0px 2px 4.3px 0px #5A5A5A66;
    padding: 38px 20px 25px;
    border-radius: 17px 17px 0 0;
    max-height: calc(100vh - 195px);
    overflow: auto;
}
.redeemCatalogue + .rewardCoupon{
    margin-top:-22px;
}
.rewardCoupon ul {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 25px;
}
.rewardCoupon ul li {
    background: #fff;
    border-radius: 8px;
    padding: 20px 20px;
    width:calc(50% - 12.5px);
}
.rewardLogo {
    min-height: 120px;
    display: flex;
    align-items: center;
    justify-content: center;
}
.rewardCoupon ul li span {
    font-weight: 400;
    font-size: 9px;
    line-height: normal;
    color: #000000;
    min-height: 35px;
    display: block;
    max-width: 100px;
    margin: auto;
}
.rewardCoupon .rewardPoints span{
    background: #D20A28;
    box-shadow: 0px 2px 4.3px 0px #5A5A5A66;
    font-weight: 700;
    font-size: 13px;
    line-height: normal;
    color: #fff;
    display: block;
    width: fit-content;
    padding: 8px 12px;
    border-radius: 6px;
    margin: auto;
    min-width: 120px;
    min-height: auto;
}
.rewardCoupon .redemPoints{
    border: 1px solid #D20A28;
    box-shadow: 0px 2px 4.3px 0px #5A5A5A66;
    display: block;
    width: fit-content;
    padding: 8px 18px;
    border-radius: 6px;
    font-weight: 700;
    font-size: 13px;
    line-height: normal;
    color: #D20A28;
    margin: auto;
    min-width: 120px;
    margin-top: 8px;
}
.notRedem ul li {
    position: relative;
}
.notRedem ul li:after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    width: 100%;
    height: 100%;
    background: #1E1E1E80;
    top: 0;
    border-radius: 6px;
}


@media(max-height:680px){
.welcome-img {
    padding: 0 0 20px;
}
.thankyouBx {
    margin-top: 8%;
}
}
@media(max-height:640px){
.page-title h1 {
    font-size: 52px;
}
}
@media(max-width:414px){
.app-wrapper {
    background-size: 420px;
}
.otp-box {
    gap:15px;
}
.rewardCoupon ul {
    gap: 15px;
}
.rewardCoupon ul li {
    padding: 20px 15px;
}
}
@media(max-width:375px){
.app-wrapper {
    background-size:380px;
}
.otp-box {
    gap: 10px;
}
.rewardCoupon .rewardPoints span, .rewardCoupon .redemPoints {
    width: 100%;
    min-width: 100%;
}
.rewardCoupon {
    padding: 38px 15px 25px;
}
.rewardCoupon .rewardPoints span {
    font-size: 12px;
    padding: 8px 8px;
}
.rewardCoupon ul li {
    width: calc(50% - 8px);
}
}