@font-face {
			font-family: OpenSans-Bold;
			src: url("../fonts/OpenSans-Bold.ttf");
		}

		@font-face {
			font-family: OpenSans-Light;
			src: url("../fonts/OpenSans-Light.ttf");
		}

		@font-face {
			font-family: OpenSans-Regular;
			src: url("../fonts/OpenSans-Regular.ttf");
		}

		@font-face {
			font-family: OpenSans-Semibold;
			src: url("../fonts/OpenSans-Semibold.ttf");
		}

        @font-face {
			font-family: dinpro_regular;
			src: url("../fonts/dinpro.otf") format("opentype");
		}

		@font-face {
			font-family: dinpro_bold;
			src: url("../fonts/dinpro_bold.otf") format("opentype");
		}

		@font-face {
			font-family: dinpro_medium;
			src: url("../fonts/dinpro_medium.otf") format("opentype");
		}
* {
			margin: 0;
			padding: 0;
			box-sizing: border-box;
		}

		img {
			user-select: none;
		}

		#bg {
			background-size: cover;
			background-position: center center;
			background-repeat: no-repeat;
			position: absolute;
			width: 100vw;
			min-height: 100vh;
			max-width: 100%;
		}

		#appLoader {
			position: fixed;
			top: 0;
			left: 0;
			right: 0;
			bottom: 0;
			background: #A12B30;
			z-index: 9999;
			display: flex;
			justify-content: center;
			align-items: center;
		}

		#appLoader img {
			width: 30%;
		}

		section {
			top: 5vw;
			display: flex;
			flex-flow: wrap;
			justify-content: center;
		}

		.card_img {
			cursor: pointer;
			display: flex;
			place-items: center;
			place-content: center;
			width: 100%;
			aspect-ratio: 1/1;
			padding: 0;
			position: relative;
			background-size: 100% 100%;
			border: none;
			border-top-left-radius: 6px;
			border-top-right-radius: 6px;
			background-color: #F8F8F8;
			overflow: hidden;
		}

		.card_img>img {
			width: 94%;
			height: 94%;
			background-size: cover;
			background-repeat: no-repeat;
			transition: transform 0.5s ease;
		}

		.card_img>img:hover {
			transform: scale(1.1);
		}

		#header {
			width: 100vw;
		}

		#headertextparent {
			height: 68px;
			display: flex;
			justify-content: center;
			align-items: center;
			width: 100%;
		}

		#center {
			display: flex;
			justify-content: center;
			align-items: center;
			width: 100vw;
			overflow: hidden;
		}

		#headerwhite {
			width: 140px;
			vertical-align: middle;
		}

		.bordericon {
			transition: 0.8s;
			bottom: 1vw;
			left: 1vw;
			width: 3.5vw;
			position: absolute;
			box-shadow: 0px 0px 25px 1.5px;
			border-radius: 50%;
		}

		.categoryDiv {
			display: flex;
			flex-direction: column;
			place-items: center;
			place-content: center;
			margin-bottom: 5vw;
		}

		.categoryDiv:last-child {
			margin-bottom: 0;
		}

		/*effect css end */
		.shoeCardContainer {
			width: 100%;
			display: grid;
			/* grid-template-columns: repeat(4, 1fr); */
			grid-template-columns: repeat(4, minmax(0, 1fr));
    		gap: 3vw;
			padding: 3vw 4vw;
			box-sizing: border-box;
		}

		.shoeCard {
			/* height: 100%; */
			display: flex;
			flex-direction: column;
			/* margin: 1.5vw 1.5vw; */
			min-width: 0;
			border: 0.15vw solid #0000001A;
			border-radius: 6px;
			cursor: pointer;
		}

		.cards {
			height: 295px;
			width: 469px;
		}

		/* .image-button {
			background: none;
			border: none;
			padding: 0;
			cursor: pointer;
			background-color: #F8F8F8;
		} */
		.image-button {
			display: block;
			width: 100%;
			height: auto;
		}

		.cardParent {
			position: relative;
			width: 22vw;
			display: inline-block;
			margin-top: 3%;
			margin-bottom: 3%;
			margin-left: 0.25%;
			margin-right: 0.25%;
		}

		.cardVisual {
			position: relative;
			display: flex;
			align-items: center;
			margin: 0.5vw 0;
		}

		.cardBottomVisual {
			display: flex;
			flex-direction: column;
			gap: 0.5vw;
			padding: 0.8vw 0.6vw;
		}

		.shoeName {
			font-family: 'dinpro_medium';
			font-size: 1.2vw;
			color: black;
		}
		.shoeDetail {
			font-family: 'dinpro_regular';
			font-size: 1vw;
			color: #303234;  /*#A0A0A0;*/
		}
		.shoePrice {
			font-family: 'dinpro_medium';
			font-size: 1.2vw;
			color: black;
		}
		.ColorPalatte {
			font-size: 0.75vw;
			font-family: dinpro_regular;
			color: #707070;
		}

		.color-line {
			display: flex;
			justify-content: space-between;
			width: auto;
			margin-left: 1.5vw;
		}

		.color-circle {
			flex: 0 0 auto;
			width: 1vw;
			height: 1vw;
			background-size: cover;
			border-radius: 50%;
			margin-right: 1vw;
		}

		.horizontal-line {
			width: 100%;
			height: 2px;
			background-color: #f2f2f2;
		}

		.description {
			/* margin-bottom: 10px; */
			width: 100%;
			display: flex;
			font-size: 1vw;
			/* font-size: 0.84rem; */
			color: #231f20;
			text-align: left;
			/* position: absolute; */
			font-family: dinpro_bold;
			margin: 0.5vw 0;
		}

		.button {
			height: 3vw;
			background-color: #ee3431;  /* #ee312f;*/
			color: white;
			border: 1px solid #ee3431;	/*#ee312f;*/
			outline: none;
			text-decoration: none;
			transition: background-color 0.3s ease;
			font-size: 1vw;
			font-family: dinpro_bold;
			text-align: center;
			display: -webkit-flex;
			display: flex;
			justify-content: center;
			align-items: center;
			user-select: none;
			cursor: pointer;
		}

		.button:hover {
			background-color: #ffffff;
			border: 1px solid #ee3431;	/*#ee312f;*/
			color: #ee3431;	/*#ee312f;*/
			font-weight: 600;
		}

		.BannerUpContainer {
			width: 100vw;
			left: 0;
			position: absolute;
			transition: left 0.35s ease-out;
		}

		.BannerUpContainer>img:nth-child(1) {
			/* position: absolute; */
			width: 100vw;
		}

		.BannerUpContainer>img:nth-child(2) {
			position: absolute;
			height: 66%;
			left: 21%;
			top: 11%;
		}

		.BannerUpContainer>img:nth-child(3) {
			width: 100vw;
			position: absolute;
			left: 0;
		}

		.BannerDownContainer {
			position: absolute;
			right: 0;
			width: 100vw;
			transition: right 0.35s ease-in-out;
		}

		.BannerDownContainer>img:nth-child(1) {
			width: 100vw;
		}

		.banner-hidden-container {
			position: absolute;
			right: 0;
			width: 100vw;
			opacity: 0;
			left: -23%;
			transition: all 0.35s ease-out;
		}

		.banner-hidden-container>img {
			width: 100vw;
		}

		.bannerContainer {
			height: 20vw;
			width: 100vw;

            background: gray;
		}

		.bannerContainer:hover .BannerUpContainer {
			left: -15.5%;
		}

		.bannerContainer:hover .BannerDownContainer {
			/* right: -14.5%; */
		}

		.bannerContainer:hover .banner-hidden-container {
			opacity: 1;
			left: -1%;
		}

		/* -- For search filter container -- */
		.searchFilterContainer{
			width: 100%;
			padding-left: 3.5vw;
			padding-right: 3.5vw;
			margin-top: 3vw;
		}
		.searchContainer{
			width: 100%;
			display: flex;
			align-items: end;
			justify-content: space-between;
		}
		.filterContainer{
			width: 100%;
			display: flex;
			align-items: center;
			justify-content: space-evenly;
			flex-wrap: wrap;
			gap: 1.5vw;
			padding-top: 3vw;
			padding-bottom: 1.5vw;
		}
		.clearContainer{
			width: 100%;
			display: flex;
			justify-content: flex-end;
		}
		.searchBox{
			display:flex;
			align-items:center;
			border:1px solid #D9D9D9;
			border-radius:24px;
			padding: 8px 16px;
			width:100%;
			max-width:40vw;
			height: 48px;
			background:white;
		}

		.searchInput{
			flex:1;
			border:none;
			outline:none;
			font-family: 'dinpro_medium';
			font-size:16px;
			color: #1E1E1E;
			height: 100%;
		}
		.searchInput::placeholder{
			color: #43464b; /*#B3B3B3;*/
		}
		.search_iconBtn{
			background:none;
			border:none;
			cursor:pointer;
			display:flex;
			align-items:center;
			justify-content:center;
		}

		.search_iconBtn img{
			width:18px;
			height:18px;
		}

		.selectBox {
			flex: 1;
			display:flex;
			align-items:center;
			border:1px solid #B2B2B2;    /*#D9D9D9;*/
			border-radius:24px;
			padding:0px 16px;
			height: 48px;
			background:white;
			font-family: 'dinpro_medium';
			font-size:16px;
			color: #43464b;  /*#B3B3B3;*/
			appearance:none;
			-webkit-appearance:none;
			-moz-appearance:none;

			background-image:url("../assets/dropdown.png");
			background-repeat:no-repeat;
			background-position:right 16px center;
			background-size:12px;
		}
		.selectBox:focus {
			outline: none;
			border:1px solid #D9D9D9;
		}
		.sortFilter{
			max-width: 20vw;
		}

		.clearAllBtn{
			background:none;
			border:none;
			text-decoration:underline;
			cursor:pointer;
			font-family: 'dinpro_medium';
			font-size:16px;
			color: #43464b;  /*#B3B3B3;*/
		}

		.noResultFound {
			width: 100%;
			text-align: center;
			padding: 60px 20px;
			display: flex;
			justify-content: center;
			align-items: center;
		}

		.noResultFound p {
			font-size: 32px;
			font-weight: 600;
			color: #555;

			/* Change font here */
			font-family: dinpro_regular;

			letter-spacing: 1px;
		}

		/* media query for main page starts here */

		@media only screen and (max-device-width: 1024px) {
			.cardParent {
				margin-left: 0.5%;
				margin-right: 0.5%;
			}

			.ColorPalatte {
				font-size: 0.85vw;
			}

			.color-circle {
				width: 1.125vw;
				height: 1.125vw;
			}

			.description {
				font-size: 1.125vw;
				/* margin-top: 2vw; */
			}

			.button {
				height: 3.5vw;
				font-size: 1.125vw;
				/* margin-top: 1vw; */
			}
			.searchFilterContainer{
				padding-left: 5vw;
				padding-right: 5vw;
				margin-top: 6vw;
				margin-bottom: 3vw;
			}
			.filterContainer{
				/* row-gap: 3vw;
				column-gap: 2vw; */
				padding-top: 4vw;
				padding-bottom: 3vw;
			}
			.searchBox{
				max-width: 50vw;
				height: 40px;
			}
			.selectBox{
				flex: 1 1 calc(33.33% - 3vw);
				height: 40px;
				background-size: 8px;
				min-width: 0;
				max-width: calc(33.33% - 3vw);
				margin-top: 2vw;
			}
			.sortFilter{
				margin-top: 0;
			}
			.cardBottomVisual {
				gap: 1vw;
				padding: 1.3vw 1.1vw;
			}

			.shoeName {
				font-size: 1.4vw;
			}
			.shoeDetail {
				font-size: 1.4vw;
			}
			.shoePrice {
				font-size: 1.6vw;
			}
		}

		@media screen and (max-device-width: 912px) {
			.color-circle {
				width: 1.25vw;
				height: 1.25vw;
				margin-right: 1.125vw;
			}

			.ColorPalatte {
				font-size: 1vw;
			}

			.description {
				font-size: 1.25vw;
			}

			.button {
				font-size: 1.25vw;
			}
		}

		@media only screen and (max-device-width: 800px) {
			#headertextparent {
				height: 48px;
			}

			#headerwhite {
				width: 125px;
				padding: 15px;
			}

			.shoeCardContainer {
				/* gap: 2.5vw 0.75vw; */
				/* grid-template-columns: repeat(3, 1fr); */
				grid-template-columns: repeat(3, minmax(0, 1fr));
				gap: 6px;
        		padding: 6px;
			}

			.shoeCard {
				margin: 1.75vw 1.75vw;
				/* gap: 0.625vw 0; */
			}

			.cardParent {
				width: 39vw;
				margin-left: 0.75%;
				margin-right: 0.75%;
			}

			.cardVisual {
				margin: 0.75vw 0;
			}

			.button {
				height: 4.5vw;
				font-size: 1.5vw;
				/* margin-top: 1.5vw; */
			}

			.ColorPalatte {
				font-size: 1.125vw;
			}

			.color-line {
				width: auto;
				padding-left: 2vw;
			}

			.color-circle {
				width: 1.5vw;
				height: 1.5vw;
				margin-right: 1.5vw;
			}

			.description {
				font-size: 1.5vw;
				margin: 0.75vw 0;
			}
		}

		@media screen and (max-device-width: 720px) {
			.searchFilterContainer{
				padding-left: 6vw;
				padding-right: 6vw;
				margin-top: 6vw;
				margin-bottom: 3vw;
			}

			.cardBottomVisual {
				gap: 2.8vw;
				padding: 3vw 2.75vw;
			}

			.shoeName {
				font-size: 3.5vw;
			}
			.shoeDetail {
				font-size: 3.25vw;
			}
			.shoePrice {
				font-size: 3.5vw;
			}
		}

		@media screen and (max-device-width: 640px) {
			.ColorPalatte {
				font-size: 1.32vw;
			}

			.color-circle {
				width: 1.625vw;
				height: 1.625vw;
			}

			.description, .button {
				font-size: 1.75vw;
			}

			.searchBox{
				max-width: 70vw;
			}

			.sortFilter{
				height: 40px;
				max-width: 40px;
				font-size: 0px;
				background-color: black;
				background-image:url("../assets/sort.png");
				background-repeat:no-repeat;
				background-position: center;
				background-size: 20px;
			}

		}

		@media screen and (max-device-width: 560px) {
			
		}

		@media only screen and (max-device-width: 480px) {
			.shoeCardContainer {
				/* gap: 2.5vw 1.5vw; */
				/* grid-template-columns: repeat(2, 1fr); */
				grid-template-columns: repeat(2, minmax(0, 1fr));
				gap: 12px;
        		padding: 12px;
			}

			.shoeCard {
				/* margin: 2vw 2vw; */
				/* gap: 1.25vw 0; */
				margin: 0;
        		width: 100%;
			}

			.horizontal-line {
				height: 1px;
			}

			.cardVisual {
				margin: 1.25vw 0;
			}

			.cardParent {
				width: 40vw;
				margin-top: 9%;
				margin-bottom: 9%;
			}

			.ColorPalatte {
				font-size: 1.95vw;
			}

			.color-line {
				width: auto;
				padding-left: 3vw;
			}

			.color-circle {
				width: 2.5vw;
				height: 2.5vw;
				margin-right: 2vw;
			}

			.description {
				font-size: 2.5vw;
				margin: 1.25vw 0;
			}

			.button {
				height: 7.5vw;
				font-size: 2.5vw;
				/* margin-top: 2vw; */
			}
		}

		@media only screen and (max-device-width: 350px) {
			section {
				max-width: 100vw;
				top: 19vw;
			}

			#headerwhite {
				width: 30vw;
			}

			.cardParent {
				width: 40vw;
				margin-top: 8%;
				margin-bottom: 8%;
			}

			.ColorPalatte {
				font-size: 2vw;
			}

			.color-line {
				width: 17vw;
				padding-left: 3vw;
			}

			.description {
				font-size: 2.625vw;
				/* margin-top: 3vw;  */
			}

			.button {
				height: 7.5vw;
				font-size: 2.625vw;
				/* margin-top: 2vw;   */
			}
		}