:root {
	--transparent-color: #ffffff00;

    --white-color: #ffffff;
	--white-color-15: #ffffff26;
	--white-color-25: #ffffff40;
	--white-color-50: #ffffff80;
	--white-color-75: #ffffffbf;
	
    --black-color: #000000;
	--black-color-15: #00000026;
	--black-color-25: #00000040;
	--black-color-50: #00000080;
	--black-color-75: #000000bf;

    --dark-color: #01020b;
	--dark-color-15: #01020b26;
	--dark-color-25: #01020b40;
	--dark-color-50: #01020b80;
	--dark-color-75: #01020bbf;

    --theme-color-01: #b61337;
	--theme-color-01-25: #b6133740;
	--theme-color-01-50: #b6133780;
	--theme-color-01-75: #b61337bf;

	--gray-color: #f5f5f5;
	
	--red-color: #b41e1e;
	
	--border-radius-00: 0;
    --border-radius-01: .25rem;
	--border-radius-02: 1rem;
	--border-radius-03: 0 .25rem .25rem 0;
	--border-radius-04: 1rem 1rem 0 0;
	--border-radius-05: 0 1rem 1rem 0;
    --border-radius-06: 1rem 0 0 1rem;
    --border-radius-07: 50%;

	--font-montserrat: "Montserrat", sans-serif;
	--font-bebasneue: "Bebas Neue", sans-serif;
    --font-kufi: "Noto Kufi Arabic", sans-serif;
}

* {
    outline: 0 !important;
    box-shadow: none !important;
}

html {
    position: relative;
    height: 100%;
    min-height: 100%;
    overflow-x: hidden;
    overflow-y: scroll;
}

body {
	font-family: var(--font-kufi);
    color: var(--dark-color);
    background-color: var(--dark-color);
	font-size: 1.125rem;
	font-weight: 400;
    margin: 0;
    padding: 0;
    overflow-x: hidden;
    position: relative;
    width: 100%;
    min-height: 100%;
	direction: rtl;
    background-image: url(../img/body-bg.webp);
    background-position: center top;
    background-repeat: no-repeat;
    background-attachment: scroll;
    background-size: cover;
}

@media (min-width: 1400px) {
    body {
        background-image: url(../img/body-bg-full.webp);
    }
}

a,
a:focus,
a:hover {
    text-decoration: none !important;
    transition: all .3s ease-in-out;
}

ul {
    padding: 0;
    margin-bottom: 0;
}

li {
    list-style: none;
}

p {
    margin-bottom: 0;
}

::selection {
    background: var(--dark-color);
    color: var(--white-color);
}

.lang-en {
    font-family: var(--font-montserrat);
}

.lang-ar {
    font-family: var(--font-kufi);
}


/****** Header ******/

header {
    position: relative;
    top: 0;
    left: 0;
	right: 0;
    width: 100%;
    height: 46px;
    z-index: 20;
    padding: .5rem 0;
	background-color: var(--transparent-color);
	border: none;
}

header .navbar-toggler-icon-cus {
    cursor: pointer;
}

header .side-menu-btn {
    padding: 0;
    line-height: normal;
    background-color: transparent;
    border: none;
    border-radius: var(--border-radius-01);
    display: inline-block;
}

header .navbar-collapse .navbar-nav {
    height: calc(100vh - 202px);
    text-align: center;
    padding-top: 2rem;
    overflow: auto;
    transition: all .3s ease-in-out;
}

header .side-menu-btn .icon-bar {
    width: 40px;
    height: 2px;
    display: block;
    margin: .25rem 0;
    background-color: var(--white-color);
    transition: all .3s ease-in-out;
}

header .side-menu-btn .icon-bar:nth-of-type(1) {
    transform: rotate(0);
}

header .side-menu-btn .icon-bar:nth-of-type(2) {
    opacity: 1;
    filter: alpha(opacity=100);
}

header .side-menu-btn .icon-bar:nth-of-type(3) {
    transform: rotate(0);
    width: 20px;
    margin-right: 20px;
}

header .side-menu-btn.close .icon-bar:nth-of-type(1) {
    transform: rotate(45deg);
    -webkit-transform-origin: 25% 25%;
    -ms-transform-origin: 25% 25%;
    transform-origin: 25% 25%;
    width: 30px;
}

header .side-menu-btn.close .icon-bar:nth-of-type(2) {
    opacity: 0;
    filter: alpha(opacity=0);
}

header .side-menu-btn.close .icon-bar:nth-of-type(3) {
    transform: rotate(-45deg);
    -webkit-transform-origin: 20% 20%;
    -ms-transform-origin: 20% 20%;
    transform-origin: 20% 20%;
    width: 30px;
    margin-right: 0;
}


/****** Side Menu ******/

.menu-bg {
    position: fixed;
    top: 0;
    right: 0;
    width: 100vw;
    height: 100vh;
    background-color: var(--transparent-color);
    z-index: 15;
    display: none;
    transition: all .3s ease-in-out;
}

.menu-bg.show {
    display: block;
    transition: all .3s ease-in-out;
}

.side-menu.show {
    left: 0;
    transition: all .3s ease-in-out;
}

.side-menu {
    display: block;
    position: fixed;
    top: 3rem;
    left: -105%;
    bottom: 2rem;
    width: 25vw;
    max-width: 350px;
    height: calc(100vh - 5rem);
    padding: 0;
    border-radius: 0;
    background-color: var(--dark-color);
    border: none;
    border-radius: var(--border-radius-03);
    margin: 0;
    z-index: 18;
    overflow: hidden;
    box-shadow: 5px 5px 10px 5px rgba(0, 0, 0, .5) !important;
    transition: all .3s ease-in-out;
}

@media (max-width: 992px) {
    .side-menu {
        width: 45vw;
    }
}

@media (max-width: 576px) {
    .side-menu {
        width: 70vw;
    }
}

.side-menu .side-menu-links {
    background-color: var(--white-color);
    border-radius: var(--border-radius-03);
    padding: 1rem;
    height: calc(100vh - 4rem);
}

.side-menu .side-menu-links li {
    width: 100%;
	margin-bottom: 0.25rem;
    display: inline-block;
}

.side-menu .side-menu-links li a,
.side-menu .side-menu-links li a:focus {
    color: var(--dark-color);
	background-color: var(--transparent-color);
    border-radius: var(--border-radius-02); 
    position: relative;
    padding: .5rem .75rem;
    font-size: 1rem;
    font-weight: 600;
    display: block;
}

.side-menu .side-menu-links li a:hover,
.side-menu .side-menu-links li a.active,
.side-menu .side-menu-links li a:active {
    color: var(--white-color);
    background-color: var(--theme-color-01);
	border-radius: var(--border-radius-02); 
}

.side-menu .side-menu-links li a i {
	margin-right: .5rem;
	font-size: 1rem;
	width: 1.25rem;
}

.side-menu .side-menu-links li.active a.submenu-side {
    color: var(--black-color);
    background-color: var(--white-color);
	border-radius: var(--border-radius-02); 
    transition: all .3s ease-in-out;
}

.side-menu .side-menu-links li.active a.submenu-side::after {
	content: "\f068";
	color: var(--black-color);
    transition: all .3s ease-in-out;
}

.side-menu .side-menu-links li.active>.menu-submenu {
    display: block;
    transition: all .3s ease-in-out;
}

.side-menu .side-menu-links .menu-submenu[aria-expanded="true"] {
    display: block;
    transition: all .3s ease-in-out;
}

.side-menu .menu-submenu li a,
.side-menu .menu-submenu li a:focus {
    padding-left: 4rem;
    background-color: var(--transparent-color);
    color: var(--black-color);
}

.side-menu .side-menu-links .menu-submenu li a,
.side-menu .side-menu-links .menu-submenu li a:focus {
    padding-left: 1rem;
    background-color: var(--transparent-color);
    color: var(--black-color-75);
}

.side-menu .side-menu-links .menu-submenu li a:hover,
.side-menu .side-menu-links .menu-submenu li a.active{
    color: var(--black-color);
}

.side-menu .side-menu-links li.lang-ea {
    border-top: 1px solid var(--dark-color-25);
    padding-top: .5rem;
}


/****** Main ******/

main {
    position: relative;
    display: inline-block;
    width: 100%;
    z-index: 1;
    padding-top: 8%;
}

@media (min-width: 1400px) {
    main {
        padding-top: 4%;
    }
}

@media (max-width: 576px) {
    main {
        padding-top: 8%;
    }
}

.menu-overflow {
	overflow: hidden;
}

.bg-white {
	background-color: var(--white-color);
}

.bg-black {
	background-color: var(--black-color);
}

.bg-theme-color-01 {
	background-color: var(--theme-color-01);
}

.bg-theme-color-02 {
	background-color: var(--theme-color-02);
}

.text-white {
	color: var(--white-color);
}

.text-black {
	color: var(--black-color);
}

.text-theme-01 {
	color: var(--theme-color-01);
}

.font-size-2 {
	font-size: 1.5rem;	
}

.font-size-2-25 {
	font-size: 1.25rem;	
}

.font-size-3 {
	font-size: 2.5rem;	
}

@media (max-width: 576px) {
	.font-size-2 {
		font-size: 1.25rem;	
	}
	.font-size-2-25 {
		font-size: 1rem;	
	}
	.font-size-3 {
		font-size: 1.75rem;	
	}	
}

.btn-cus-01,
.btn-cus-01:focus {
	position: relative;
    font-size: 1.125rem;
    font-weight: 500;
    text-decoration: none;
    color: var(--white-color);
    background: none;
    background-color: var(--theme-color-01);
    padding: .5rem 2rem;
    border-radius: var(--border-radius-02);
    display: inline-block;
    text-align: center;
    border: none;
    transition: all .3s ease-in-out;
}

.btn-cus-01:hover {
	background-color: var(--white-color);
    color: var(--dark-color);
    transition: all .3s ease-in-out;
}

.btn-cus-02,
.btn-cus-02:focus {
	position: relative;
    font-size: 1.5rem;
    font-weight: 500;
    text-decoration: none;
    color: var(--white-color);
    background: none;
    background-color: var(--theme-color-01);
    padding: .5rem 1rem;
    border-radius: var(--border-radius-02);
    border: 2px solid var(--theme-color-01);
    display: inline-flex;
    text-align: center;
    justify-content: center;
    transition: all .3s ease-in-out;
}

.btn-cus-02:hover {
	background-color: var(--dark-color);
    border: 2px solid var(--theme-color-01);
    color: var(--white-color);
    transition: all .3s ease-in-out;
}

.btn-cus-02 img {
    width: auto;
    height: 36px;
}

.cus-link,
.cus-link:focus {
    position: relative;
    display: inline-block;
    color: currentColor;
}

.cus-link:hover {
    color: var(--theme-color-01);
}

.cus-link::after,
.cus-link::before {
    content: "";
    position: absolute;
    left: 0;
    bottom: 2px;
    height: 1px;
    width: 100%;
    background-color: currentColor;
}

.cus-link::before {
    -webkit-transform-origin: 100% 50%;
    -moz-transform-origin: 100% 50%;
    transform-origin: 100% 50%;
}

.cus-link::after {
    -webkit-transform-origin: 0 50%;
    -moz-transform-origin: 0 50%;
    transform-origin: 0 50%;
    -webkit-transform: scaleX(0);
    -moz-transform: scaleX(0);
    transform: scaleX(0);
}

.cus-link:hover::before {
    -webkit-transform: scaleX(0);
    -moz-transform: scaleX(0);
    transform: scaleX(0);
    -webkit-transition: -webkit-transform .3s cubic-bezier(.86, 0, .07, 1);
    -moz-transition: -moz-transform .3s cubic-bezier(.86, 0, .07, 1);
    transition: transform .3s cubic-bezier(.86, 0, .07, 1);
}

.cus-link:hover::after {
    -webkit-transform: scaleX(1);
    -moz-transform: scaleX(1);
    transform: scaleX(1);
    -webkit-transition: -webkit-transform .3s cubic-bezier(.86, 0, .07, 1) .25s;
    -moz-transition: -moz-transform .3s cubic-bezier(.86, 0, .07, 1) .25s;
    transition: transform .3s cubic-bezier(.86, 0, .07, 1) .25s;
}

.home-btn-01 {
    position: fixed;
    bottom: 10%;
    margin: auto;
}

.products-cus {
    position: relative;
    padding-top: 30vh;
}

@media (min-width: 1400px) {
    .products-cus {
        padding-top: 35vh;
    }
}

@media (max-width: 992px) {
    .products-cus {
        padding-top: 35vh;
    }
}

@media (max-width: 576px) {
    .products-cus {
        padding-top: 35vh;
    }
}

.products-cus .pro-info {
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: normal;
    width: fit-content;
    height: fit-content;
    max-height: 30%;
    margin: 0 auto;
}

.products-cus .pro-info .pro-num {
    font-family: var(--font-bebasneue);
    font-weight: 700;
    color: var(--theme-color-01);
    font-size: 12rem;
    line-height: normal;
}

.products-cus .pro-info .pro-text {
    color: var(--white-color);
    font-size: 1.25rem;
    width: 30%;
    line-height: normal;
}

.products-cus .pro-img {
    position: relative;
    margin: 0;
    margin-bottom: .75rem;
    padding: 0;
    padding-top: 75%;
    overflow: hidden;
    border: 1px solid var(--theme-color-01);
    border-radius: var(--border-radius-02);
    background-position: 50% 50%;
    background-repeat: no-repeat;
    background-size: cover;
}

@media (max-width: 576px) {
	.products-cus .pro-info .pro-num {
        font-size: 8rem;
    }
    .products-cus .pro-info .pro-text {
        font-size: 1.125rem;
		width:30%;
    }
}

.proswiper {
	padding-bottom: 2rem;
    padding-top: 0;
}

.proswiper.swiper-container {
    padding-left: 0;
    padding-right: 0;
}

.proswiper .swiper-container-horizontal>.swiper-pagination-bullets,
.proswiper .swiper-pagination-custom, .swiper-pagination-fraction {
    bottom: 0;
}

.proswiper .swiper-pagination-bullet {
    width: 12px;
    height: 12px;
    display: inline-block;
    border-radius: 50%;
    background-color: var(--theme-color-01-25);
    opacity: 1;
    -webkit-transition: all .3s ease-in-out;
    -o-transition: all .3s ease-in-out;
    transition: all .3s ease-in-out;
}

.proswiper .swiper-pagination-bullet-active {
    opacity: 1;
    background-color: var(--theme-color-01);
    -webkit-transition: all .3s ease-in-out;
    -o-transition: all .3s ease-in-out;
    transition: all .3s ease-in-out;
}

.card-cus {
    border-radius: var(--border-radius-04);
    min-height: 50vh;
}

.card-cus .card-header {
    padding: .75rem 1.5rem;
    color: var(--dark-color);
    background-color: var(--white-color);
    border-radius: var(--border-radius-04);
}

.card-cus .card-header img.pr-im {
    max-width: 50%;
    border-radius: var(--border-radius-04);
}

@media (max-width: 576px) {
	.card-cus .card-header img.pr-im {
        max-width: 90%;
    }
}

.card-cus .card-header.header-order span {
    color: var(--theme-color-01);
}

.card-cus .card-header.header-point h2 {
    color: var(--theme-color-01);
    font-size: 2.5rem;
    font-weight: 700;
}

.card-cus .card-header.header-point span {
    font-size: 1rem;
}

.point-bg-01 {
    background-image: url(../img/point-bg-01.webp);
    background-repeat: repeat-x;
    background-size: contain;
    min-height: 4.5rem;
    color: var(--white-color);
    padding: .5rem 1rem;
    text-align: center;
}

.point-bg-01 a,
.point-bg-01 a:focus,
.point-bg-01 a:hover {
    color: var(--white-color);
}

.point-bg-01 img {
    width: auto;
    height: 1.25rem;
}

.point-bg-02 {
    background-color: var(--theme-color-01);
    color: var(--white-color);
    padding: 1rem 1rem;
    text-align: center;
    font-size: 1.5rem;
    font-weight: 700;
    margin: -1.5rem;
}

.redeem-products {
    position: relative;
    text-align: center;
    margin-bottom: 3rem;
}

.redeem-products .prd-img {
    position: relative;
    margin: auto;
    padding: 0;
    width: 80%;
    aspect-ratio: 1 / 1;
    overflow: hidden;
    border: .25rem solid var(--theme-color-01);
    border-radius: var(--border-radius-07);
    background-position: 50% 50%;
    background-repeat: no-repeat;
    background-size: cover;  
}

.redeem-products p {
    margin-top: .5rem;
    font-size: 1.5rem;
}

@media (max-width: 576px) {
    .redeem-products {
        margin-bottom: 1.5rem;
    }
    .redeem-products .prd-img {
        width: 90%;
    }
    .redeem-products p {
        font-size: 1.125rem;
    }
}

img.cong-img {
    max-width: 50%;
}

@media (max-width: 576px) {
	img.cong-img {
    max-width: 100%;
}
}


/****** Forms ******/

.form-outline {
    position: relative;
}

.form-outline .form-control {
    padding: .5rem 1rem;
    font-size: 1rem;
    font-weight: 400;
    line-height: normal;
    color: var(--dark-color);
    background-color: var(--gray-color);
    border: 1px solid var(--dark-color-15);
	border-radius: var(--border-radius-02);
    transition: all .3s ease-in-out;
}

.form-outline .form-control:focus {
    border: 1px solid var(--dark-color-25);
    transition: all .3s ease-in-out;
}

.form-outline .form-control::placeholder {
	color: var(--dark-color-50) !important;
	font-weight: 400 !important;
    font-size: .875rem !important;
	opacity: 1 !important;
}

.form-outline .form-label {
    margin-bottom: .25rem;
    margin-left: .5rem;
    font-size: 1rem !important;
    color: var(--dark-color);
}

.form-label.form-label-cus {
    margin-bottom: .25rem;
    margin-left: .5rem;
    font-size: .1rem !important;
    width: 49%;
}

@media (max-width: 992px) {
    .form-label.form-label-cus {
        width: 70%;
    }
}

@media (max-width: 576px) {
    .form-label.form-label-cus {
        width: 72%;
    }
}

.form-outline.form-check {
    display: -webkit-inline-box;
}

.form-outline .form-check-input {
    border: 1px solid var(--dark-color);
    background-color: var(--transparent-color);
    position: relative;
    top: -2px;
    width: 20px;
    height: 20px;
    margin-left: .5rem;
}

.form-outline .form-check-input[type=checkbox] {
    border-radius: var(--border-radius-07);
    transition: all .3s ease-in-out;
}

.form-outline .form-check-input:checked {
    background-color: var(--transparent-color);
    border: .25rem solid var(--theme-color-01);
    transition: all .3s ease-in-out;
}

.form-outline .form-check-input:checked[type=checkbox] {
    background-image: none;
}

.form-outline .form-check-input:checked[type=radio] {
    background-image: none;
}

.form-outline .form-check-label {
    color: var(--dark-color);
    font-size: .9375rem;
}

.form-outline.is-invalid .form-check-input {
    border: 1px solid var(--red-color);
}

.form-outline.is-invalid .form-control {
    border: 1px solid var(--red-color);
}

.form-outline .invalid-feedback, .error {
    width: auto;
    position: absolute;
    bottom: -1.125rem;
    left: .5rem;
    z-index: 2;
    color: var(--red-color);
    font-size: .75rem;
    font-weight: 500;
    transition: all .3s ease-in-out;
}

.form-outline .toggle-password {
    position: relative;
    left: .75rem;
    top: 2.5rem;
	float: left;
    z-index: 2;
    color: var(--dark-color-50);
    cursor: pointer;
    transition: all .3s ease-in-out;
}

.form-outline .toggle-password~.form-control {
    padding-right: 2.5rem !important;
}

.form-outline .eye::before {
    content: "\f06e";
    font-family: var(--font-awesome);
    font-size: 1rem;
}

.form-outline .eye-slash::before {
    content: "\f070";
    font-family: var(--font-awesome);
    font-size: 1rem;
}

.form-outline .bootstrap-select.form-control {
    padding: 0;
}

.form-outline .bootstrap-select .btn-light,
.form-outline .bootstrap-select .btn-light:focus {
    color: var(--dark-color) !important;
    background-color: var(--gray-color) !important;
	padding: 0 !important;
    margin: 0 !important;
    border: none !important;
    line-height: 1.128rem !important;
    border-radius: var(--border-radius-02) !important;
    outline: none !important;
}

.form-outline .bootstrap-select .btn,
.form-outline .bootstrap-select .btn:focus {
    color: var(--black-color) !important;
    background-color: var(--gray-color) !important;
    border: none !important;
    padding: .75rem 1rem !important;
    margin: 0 !important;
    line-height: 1.5 !important;
    border-radius: var(--border-radius-02) !important;
    outline: none !important;
}

.form-outline .bootstrap-select .actions-btn.btn.btn-light {
    border: none !important;
    padding: 0 !important;
    margin: 0 !important;
    border-radius: var(--border-radius-02) !important;
    outline: none !important;
}

.form-outline .bootstrap-select .dropdown-menu {
    padding: 0;
    margin: 0 !important;
    font-size: .9375rem;
    color: var(--black-color);
    text-align: left;
    width: 100%;
    background-color: var(--white-color);
    border: 1px solid var(--dark-color-15);
    border-radius: var(--border-radius-02);
    box-shadow: 0 2px 5px var(--dark-color-05) !important;
}

.form-outline .bootstrap-select .dropdown-menu.inner {
    margin: 0 !important;
    border: none;
}

.form-outline .bootstrap-select .dropdown-item,
.form-outline .bootstrap-select .dropdown-item:focus {
    padding: .75rem .75rem;
    color: var(--black-color);
    text-align: right;
}

.form-outline .bootstrap-select .dropdown-item:hover {
    color: var(--black-color);
    background-color: var(--gray-color)
}

.form-outline .bootstrap-select .dropdown-item.active,
.form-outline .bootstrap-select .dropdown-item:active {
    color: var(--white-color);
    background-color: var(--theme-color-01)
}

.form-outline .bootstrap-select .no-results {
    padding: .125rem;
    font-size: .875rem;
    background: none;
    background-color: var(--transparent-color);
    margin: .25rem .5rem;
}

.form-outline .form-control.input-select-cus {
    width: calc(100% - 16rem);
}

.form-outline .bootstrap-select .dropdown-toggle .filter-option-inner-inner {
    text-align: right;
}

button.btn-number {
    background-color: transparent;
    border: 1px solid var(--dark-color-15);
    padding: 0 1rem;
    margin: 0;
    font-size: 1.75rem;
    line-height: normal;
    background-color: var(--gray-color);
}

button.btn-number.minus {
    border-radius: var(--border-radius-05);
	height: 49px;
}

button.btn-number.plus {
    border-radius: var(--border-radius-06);
	height: 49px;
}

.form-outline .form-control.prod-items {
	border-radius: var(--border-radius-00);
}

.cus-link {
    display: inline-block; /* important so the underline matches the text width */
    /* your existing styles here */
}

.cus-link {
    display: inline-block; /* important so the underline matches the text width */
    /* your existing styles here */
}