


/* variables de colores */

:root {
	/* colores */

	--spanish-gray: hsl(0, 0%, 60%);
	--sonic-silver: hsl(0, 0%, 47%);
	--eerie-black: hsl(0, 0%, 13%);
	--salmon-pink: hsl(353, 100%, 78%);
	--sandy-brown: hsl(29, 90%, 65%);
	--bittersweet: hsl(0, 100%, 70%);
	--ocean-green: hsl(152, 51%, 52%);
	--davys-gray: hsl(0, 0%, 33%);
	--cultured: hsl(0,0%, 93%);
	--onyx: hsl(0,0%, 27%);
	--white: hsl(0, 0%, 98%);

	/* typography */

	--fs-1: 1.563rem;
	--fs-2: 1.375rem;
	--fs-3: 1.25rem;
	--fs-4: 1.125rem;
	--fs-5: 1rem;
	--fs-6: 0.938rem;
	--fs-7: 0.875rem;
	--fs-8: 0.813rem;
	--fs-9: 0.75rem;
	--fs-10: 0.688rem;
	--fs-11: 0.625rem;


	--weight-300: 300;
	--weight-400: 400;
	--weight-500: 500;
	--weight-600: 600;
	--weight-700: 700;

	/* border radius */

	--border-radius-md: 10px;
	--border-radius-sm: 5px;

	/* transition */

	--transition-timing: 0.2s ease; 
}

*, *::before, *::after {
	margin: 0;
	padding: 0;
	box-sizing: border-box;
}

a {
	text-decoration: none;
}

li {
	list-style: none;
}

button {
	background: none;
	font: inherit;
	border: none;
	cursor: pointer;
}

img, ion-icon, button, a {display: block;}

span { display: inline-block; }

html {
	font-family: 'Poppins', sans-serif;
	overscroll-behavior: contain;

}

input {
	display: block;
	width: 100%;
	font: inherit;
}

input::placeholder { font: inherit; }

body {
	background: var(--white);
	padding-bottom: 60px;
}

/* scrollvar style*/

body::-webkit-scrollbar { width: 15px; }

body::-webkit-scrollbar-track {
	background: var(--white);
	border-left: 1px solid var(--cultured);
}

body::-webkit-scrollbar-thumb {
	background: hsl(0, 0%, 80%);
	border: 3px solid var(--white);
	border-radius: 10px;
}

body::-webkit-scrollbar-thumb:hover { background: hsl(0, 0%, 70%); }

/*----------------------- reused style ------------------- */

.container { padding: 0 15px; }

.has-scrollbar { padding-bottom: 5px; }

.has-scrollbar::-webkit-scrollbar {
	width: 12px;
	height: 12px;
}

.has-scrollbar::-webkit-scrollbar-thumb {
	background: transparent;
	border: 3px solid var(--white);
	border-radius: 20px;
}

.has-scrollbar:hover::-webkit-scrollbar-thumb { background: hsl(0, 0%, 90%); }

.has-scrollbar::-webkit-scrollbar-thumb:hover { background: hsl(0, 0%, 80%); } 

.title {
	color: var(--eerie-black);
	font-size: var(--fs-5);
	font-weight: var(--weight-600);
	letter-spacing: 0.4px;
	text-transform: capitalize;
	padding-bottom: 10px;
	border-bottom: 1px solid var(--cultured);
	margin-bottom: 30px;
}



/* ---------- Overlay ---------------- */

.overlay {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100vh;
	background: hsla(0, 0%, 0%, 0.5);
	opacity: 0;
	pointer-events: none;
	z-index: 15;
	transition: 0.5s ease;
}

.overlay.active  {
	opacity: 1;
	pointer-events: all;
}


/* ------------------ MODAL ------------------- */

.modal {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100vh;
	background: hsla(0, 0%, 0%, 0.5);
	display: flex;
	justify-content: center;
	align-items: center;
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
	z-index: 10;
	animation: popud 1s ease-in-out 5s forwards;
}

@keyframes popud {
	0% {
		opacity: 0;
		visibility: hidden;
		pointer-events: none;
	}

	100% {
		opacity: 1;
		visibility: visible;
		pointer-events: all;	
	}
}

.modal.closed { display: none; }

.modal-close-overlay {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 1;
}

.newsletter-img { display: none; }

.modal-content {
	position: relative;
	max-width: 350px;
	margin: 20px;
	background: var(--white);
	border-radius: var(--border-radius-md);
	overflow: hidden;
	z-index: 2;
	animation: scaleUp 0.5s ease-in-out 5s forwards;
}

@keyframes scaleUp {
	0% { transform: scale(0.9); }
	100% { transform: scale(1); }
}

.modal-close-btn {
	position: absolute;
	top: 15px;
	right: 15px;
	background: var(--salmon-pink);
	color: var(--white);
	font-size: 16px;
	padding: 5px;
	border-radius: var(--border-radius-sm);
}

.modal-close-btn:hover { opacity: 0.9; }

.modal-close-btn ion-icon { --ionicon-stroke-width: 70px; }

.newsletter {
	padding: 50px 30px;
	text-align: center;
}

.newsletter-header { margin-bottom: 20px; }

.newsletter-title {
	color: var(--onyx);
	font-size: var(--fs-2);
	font-weight: var(--weight-600);
	margin-bottom: 10px;
}

.newsletter-desc {
	color: var(--sonic-silver);
	font-size: var(--fs-7);
	line-height: 1.6;
}

.email-field {
	font-size: var(--fs-7);
	padding: 8px 16px;
	border-radius: var(--border-radius-sm);
	border: 1px solid var(--cultured);
	margin-bottom: 16px;
}

.btn-newsletter {
	background: var(--eerie-black);
	color: var(--white);
	font-size: var(--fs-7);
	font-weight: var(--weight-600);
	text-transform: uppercase;
	padding: 10px 15px;
	border-radius: var(--border-radius-sm);
	margin: auto;
	transition: var(--transition-timing);
}

.btn-newsletter:hover { background: var(--salmon-pink); }

/*-------- NOTIFICACION TOAST ------------------*/

.notificacion-toast {
	position: fixed;
	bottom:80px;
	left: 20px;
	right: 20px;
	background: var(--white);
	max-width: 300px;
	display: flex;
	align-items: flex-start;
	gap: 15px;
	padding: 15px;
	border-radius: var(--bopreder-radius-md);
	box-shadow: 0 5px 20px hsla(0, 0%, 0%, 0.15);
	transform: translateX(calc(-100% -40px));
	transition: 0.5s ease-in-out;
	z-index: 5;
	animation: slideInOut 10s ease-in-out infinite;
}

@keyframes slideInOut {
	0%,
	45%, 
	100% {
		transform: translateX(calc(-100% -40px));
		opacity: 0;
		visibility: hidden;
	} 

	50%,
	95% {
		transform: translateX(0);
		opacity: 1;
		visibility: visible;
	}                                                                                                                                                                           
}

.notificacion-toast.closed { display: none; }

.toast-close-btn {
	position: absolute;
	top: 10;
	right: 10px;
	color: var(--sonic-silver);
}

.toast-close-btn ion-icon { --ionicon-stroke-width: 50px; }

.toast-baner {
	width: 70px;
	height: 70px;
	border: 1px solid var(--cultured);
	border-radius: var(--border-radius-sm);
}

.toast-baner img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	object-position: center;
}

.toast-detail {
	width: calc(100% - 85px);
	padding-right: 10px;
}

.toast-message {
	font-size: var(--fs-10);
	color: var(--sonic-silver);
	margin-bottom: 8px;
}

.toast-title {
	font-size: var(--fs-7);
	font-weight: var(--weight-500);
	color: var(--onyx);
}

.toast-meta {
	font-size: var(--fs-10);
	color: var(--sonic-silver);
}

/* ------------- Header ------------------- */ 

.header-top,
.header-user-actions,
.desktop-navigation-menu { display: none; }

.header-main {
	padding: 20px 0;
	border-bottom: 1px solid var(--cultured);
}

.header-logo { margin-bottom: 20px; }

.header-logo img { margin: auto; }

.header-search-container { position: relative; }

.header-search-container .search-field {
	font-size: var(--fs-7);
	color: var(--onyx);
	padding: 10px 15px;
	padding-right: 50px;
	border: 1px solid var(--cultured);
	border-radius: var(--boreder-radius-md);
}

.search-field::-webkit-search-cancel-button { display: none; }

.search-btn {
	background: var(--white);
	position: absolute;
	top: 50%;
	right: 2px;
	transform: translateY(-50%);
	color: var(--onyx);
	font-size: 18px;
	padding: 8px 15px;
	transition: color var(--transition-timing);
}


.search-btn:hover { color: var(--salmon-pink); }

.mobile-bottom-navigation {
	background: var(--white);
	position: fixed;
	bottom: 0;
	left: 50%;
	transform: translateX(-50%);
	width: 100%;
	max-width: 500px;
	margin: auto;
	display: flex;
	justify-content: space-around;
	align-items: center;
	padding: 5px 0;
	box-shadow: 0 0 10px hsla(0, 0%, 0%, 0.25);
	z-index: 5;
}

.mobile-bottom-navigation .action-btn {
	position: relative;
	font-size: 26px;
	color: var(--eerie-black);
	padding: 10px;
}

.mobile-bottom-navigation .count {
	background: var(--bittersweet);
	color: var(--white);
	position: absolute;
	top: 0;
	right: 0;
	font-size: 12px;
	font-weight: var(--weight-500);
	line-height: 1;
	padding: 2px 4px;
	border-radius: 20px;
}

.mobile-navigation-menu {
	background: var(--white);
	position: fixed;
	top: 0;
	left: -100%;
	width: 100%;
	max-width: 320px;
	height: 100vh;
	padding: 20px;
	box-shadow: 0 0 10px hsla(0, 0%, 0%, 0.1);
	overflow-y: scroll;
	visibility: hidden;
	transition: 0.5s ease;
	z-index: 20;

}

.mobile-navigation-menu.active {
	left: 0;
	visibility: visible;
}

.menu-top {
	padding-bottom: 15px;
	margin-bottom: 10px;
	display: flex;
	justify-content: space-between;
	align-items: center;
	border-bottom: 2px solid var(--cultured);
}

.menu-top .menu-title {
	color: var(--salmon-pink);
	font-size: var(--fs-4);
	font-weight: var(--weight-600);
}

.menu-close-btn {
	color: var(--eerrie-black);
	font-size: 22px;
}

.menu-close-btn ion-icon { --ionicon-stroke-width: 50px; }

.mobile-menu-category-list { margin-bottom: 30px; }

.menu-category .accordion-menu {
	width: 100%;
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.mobile-menu-category-list .menu-category { border-bottom: 1px solid var(--cultured); }

.mobile-menu-category-list .menu-title {
	color: var(--onyx);
	font-size: var(--fs-6);
	font-weight: var(--weight-500);
	padding: 12px 0;
}

.accordion-menu > div { font-size: 14px; }

.accordion-menu ion-icon {
	color: var(--onyx);
	--ionicon-stroke-width: 90px;
}

.accordion-menu.active .add-icon,
.accordion-menu  .remove-icon { display: none; }

.accordion-menu .add-icon,
.accordion-menu.active  .remove-icon { display: block; }

.menu-category .submenu-category-list { margin-left: 10px; }

.submenu-title {
	padding: 6px 0;
	font-size: var(--fs-6);
	color: var(--sonic-silver);
	font-weight: var(--weight-300);
}

.submenu-title:hover { color: var(--davys-gray); }

.submenu-category-list {
	max-height: 0;
	overflow: hidden;
	visibility: hidden;
	transition: 0.5s ease-in-out;
}

.submenu-category-list.active {
	max-height: 148px;
	visibility: visible;
}

.menu-bottom .menu-category-list { margin-bottom: 20px; }

.menu-bottom .menu-category-list { border-bottom: none; }

.menu-bottom .menu-title {
	font-size: var(--fs-6);
	font-weight: var(--weight-500);
	color: var(--eerie-black);
	padding: 12px 0;
}

.accordion-menu.active .caret-back { transform: rotate(-0.25turn); }

.menu-bottom .submenu-category-list {
	border: 1px solid var(--cultured);
	border-radius: var(--border-radius-md);
	padding: 0 15px;
	margin-left: 0;
	box-shadow: 0 0 10px hsla(0, 0%, 0%, 0.05);
}

.menu-bottom .submenu-category:not(:last-child) { border-bottom: 1px solid var(--cultured); }

.menu-social-container {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 10px;
}

.menu-social-container .social-link{
	background: var(--cultured);
	color: var(--eerie-black);
	font-size: 20px;
	padding: 10px;
	border-radius: var(--border-radius-md);
}

.menu-social-container .social-link:hover {
	color: var(--salmon-pink);
}

/* --------------------- MAIN ----------------- */

.banner { margin: 30px 0; }

.slider-container {
	display: flex;
	align-items: center;
	gap: 10px;
	border-radius: var(--border-radius-md);
	overflow: auto hidden;
	scroll-behavior: inline mandatory;
	overscroll-behavior-inline: contain;
}

.slider-item {
	position: relative;
	min-width: 100%;
	height: 250px;
	border-radius: var(--border-radius-md);
	overflow: hidden;
	scroll-snap-align: start;
}

.slider-item .banner-img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: right;

}

.banner-content {
	background: hsla(0, 0%, 100%, 0.8);
	width: 280px;
	position: absolute;
	top: 85px;
	bottom: 25px;
	left: 25px;
	right: 25px;
	padding: 20px 20px;
	border-radius: var(--border-radius-md);
}

.banner-subtitle {
	color: var(--salmon-pink);
	font-size: var(--fs-7);
	font-weight: var(--weight-500);
	text-transform: capitalize;
	letter-spacing: 2px;
	margin-bottom: 10px;
}

.banner-title {
	color: var(--eerie-black);
	font-size: var(--fs-1);
	text-transform: uppercase;
	line-height: 1;
	margin-bottom: 10px;
}

.banner-text { display: none; }

.banner-btn {
	background: var(--salmon-pink);
	color: var(--white);
	width: max-content;
	font-size: var(--fs-11);
	font-weight: var(--weight-600);
	text-transform: uppercase;
	padding: 4px 10px;
	border-radius: var(--border-radius-sm);
	transition: var(--transition-timing);
}

.banner-btn:hover {background: var(--eerie-black);}

/*----------------- CATEGORY -----------------*/

.category { margin-bottom: 30px; }

.category-item-container {
	display: flex;
	align-items: center;
	gap: 10px;
	overflow: auto hidden;
	scroll-snap-type: inline mandatory;
	overscroll-behavior-inline: contain;
}

.category-item {
	min-width: 100%;
	display: flex;

	align-items: center;
	gap: 10px;
	padding: 15px;
	border: 1px solid var(--cultured);
	border-radius: var(--border-radius-md);
	scroll-snap-align: start;
}

.category-img-box {
	background: var(--cultured);
	border: 1px solid hsl(0, 0%, 80%);
	padding: 10px;
	border-radius: var(--border-radius-md);
}

.category.content-box { width: 100%; }

.category-content-flex {
	display: flex;
	width: 60%;
	/*justify-content: space-between;*/
	align-items: center;
	margin-bottom: 10px;
}

.category-item-title {
	color: var(--eerie-black);
	font-size: var(--fs-9);
	font-weight: var(--weight-600);
	text-transform: uppercase;
	margin-right: 10px;
}

.category-item-amount {
	color: var(--sonic-silver);
	font-size: var(--fs-11);
	/*margin-right: 90px;*/
}

.category-btn {
	color: var(--salmon-pink);
	font-size: var(--fs-9);
	font-weight: var(--weight-500);
	text-transform: capitalize;
}


/* SIDEBAR*/

.sidebar {
	background: var(--white);
	position: fixed;
	top: 0;
	left:-100%;
	bottom: 0;
	width: 100%;
	max-width: 320px;
	padding: 30px;
	overflow-y: scroll;
	overscroll-bahavior: contain;
	visibility: hidden;
	transition: 0.5s ease;
	z-index: 20;
}

.sidebar.active {
	left: 0;
	visibility: visible;
}

.sidebar-category {
	margin-bottom: 15px;
	padding-bottom: 15px;
	border-bottom: 1px solid var(--cultured);
}

.sidebar-top {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 10px;
}

.sidebar-title {
	color: var(--onyx);
	font-size: var(--fs-5);
	text-transform: uppercase;
	letter-spacing: 0.8px;
	font-weight: var(--weight-600);
}

.sidebar-close-btn {
	color: var(--eerie-black);
	font-size: 22px;
	font-weight: var(--weight-600);
}

.sidebar-close-btn ion-icon { --ionicon-stroke-width: 50px; }

.sidebar-accordion-menu {
	width: 100%;
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 7px 0;
}

.sidebar .menu-title-flex {
	display: flex;
	align-items: center;
	gap: 10px;
}

.sidebar .menu-title{
	font-size: var(--fs-5);
	color: var(--sonic-silver);
	font-weight: var(--weight-500);
}

.sidebar-accordion-menu ion-icon {
	color: var(--sonic-silver);
	font-size: 14px;
	--ionicon-stroke-width: 70px;
}

.sidebar-submenu-category-list {
	border-top: 1px solid var(--cultured);
	max-height: 0;
	overflow: hidden;
	visibility: hidden;
	transition: 0.5s ease-in-out;
}

.sidebar-submenu-category-list.active {
	padding: 13px 0 8px;
	max-height: 122px;
	visibility: visible;
}

.sidebar-submenu-title {
	display: flex;
	justify-content: space-between;
	align-items: center;
	color: var(--sonic-silver);
	font-size: var(--fs-7);
	padding: 2px 0;
}

.sidebar-submenu-title:hover {
	color: var(--eerie-black);
}

.sidebar .product-name { text-transform: capitalize; }

.sidebar-accordion-menu.active .add-icon,
.sidebar-accordion-menu .remove-icon { display: none; }


.sidebar-accordion-menu .add-icon,
.sidebar-accordion-menu.active .remove-icon { display: block; }

.sidebar .showcase-heading {
	font-size: var(--fs-5);
	font-weight: var(--weight-600);
	color: var(--onyx);
	text-transform: uppercase;
	letter-spacing: 0.8px;
	margin-bottom: 15px;
}

.sidebar .showcase {
	display: flex;
	align-items: center;
	gap: 15px;
}

.sidebar .showcase:not(:last-child) { margin-bottom: 15px; }

.sidebar .showcase-img { border-radius: var(--border-radius-sm); }

.sidebar .showcase-content { width: calc(100% -90px); }

.sidebar .showcase-title {
	color: var(--onyx);
	font-size: var(--fs-7);
	font-weight: var(--weight-400);
	text-transform: capitalize;
	overflow: hidden;
	white-space: nowrap;
	text-overflow: ellipsis;
	letter-spacing: 0.5px;
}

.sidebar .showcase-rating {
	display: flex;
	align-items: center;
	color: var(--sandy-brown);
	font-size: 13px;
	padding: 4px 0;
}

.sidebar .price-box {
	display: flex;
	align-items: center;
	gap: 15px;
}

.sidebar .price-box del {
	color: var(--sonic-silver);
	font-size: 13px;
}

.sidebar .price-box .price {
	font-size: var(--fs-7);
	font-weight: var(--weight-600);
	color: var(--davys-gray);
}

/*----------- PRODUCT MINIMAL ----------------*/

.product-minimal { margin-bottom: 30px; }

.product-minimal .product-showcase { margin-bottom: 10px; }

.product-minimal .showcase-wrapper {
	display: flex;
	align-items: center;
	overflow-x: auto;
	overscroll-behavior-inline: contain;
	scroll-snap-type: inline mandatory;
}

.product-minimal .showcase-container{
	min-width: 100%;
	padding: 0 5px;
	scroll-snap-aling: start;
}

.product-minimal .showcase {
	display: flex;
	justify-content: flex-start;
	align-items: center;
	gap: 15px;
	border: 1px solid var(--cultured);
	padding: 15px;
	border-radius: var(--border-radius-md);
}

.product-minimal .showcase:not(:last-child) { margin-bottom: 15px; }

.product-minimal .showcase-content { width: calc(100% - 85px); }

.product-minimal .showcase-title {
	color: var(--eerie-black);
	font-size: var(--fs-7);
	font-weight: var(--weight-600);
	text-transform: capitalize;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	margin-bottom: 2px;
}

.product-minimal .showcase-category {
	width: max-content;
	color: var(--davys-gray);
	font-size: var(--fs-8);
	text-transform: capitalize;
	margin-bottom: 3px;
}

.product-minimal .showcase-category:hover { color: var(--salmon-pink); }

.product-minimal .price-box {
	display: flex;
	align-items: center;
	gap: 10px;
}

.product-minimal .price {
	font-size: var(--fs-7);
	font-weight: var(--weight-700);
	color: var(--salmon-pink);
}

.product-minimal .price-box del {
	font-size: var(--fs-9);
	color: var(--sonic-silver);
}


/*---------- PRODUCT FEATURED---------------*/
.product-container {
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 20px;
}
.product-featured { margin-bottom: 30px; }

.product-featured  .showcase-wrapper {
	display: flex;
	align-items: center;
	gap: 20px;
	overflow-x: auto;
	overscroll-behavior-inline: contain;
	scroll-snap-type: inline mandatory;
}

.product-featured  .showcase-container {
	min-width: 100%;
	padding: 30px;
	border: 1px solid var(--cultured);
	border-radius: var(--border-radius-md);
	scroll-snap-align: start;
}
.product-featured  .showcase{
	
	border: 1px solid var(--cultured);
	border-radius: var(--border-radius-md);
}

.product-featured  .showcase-img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.product-featured  .showcase-content { margin-top: 30px; }

.product-featured  .showcase-rating {
	color: var(--sandy-brown);
	display: flex;
	align-items: center;
	font-size: 16px;
	margin-bottom: 15px;
}

.product-featured  .showcase-title {
	font-size: var(--fs-7);
	color: var(--eerie-black);
	overflow: hidden;
	white-space: nowrap;
	text-overflow: ellipsis;
	text-transform: uppercase;
	margin-bottom: 3px;
}

.product-featured  .showcase-desc {
	color: var(--sonic-silver);
	font-size: var(--fs-7);
	font-weight: var(--weight-300);
	margin-bottom: 10px;
}

.product-featured .price-box {
	font-size: var(--fs-3);
	display: flex;
	gap: 10px;
	margin-bottom: 10px;
}

.product-featured .price {
	color: var(--salmon-pink);
	font-weight: var(--weight-700);
}

.product-featured del {
	color: var(--sonic-silver);
	font-weight: var(--weight-300);
}

.product-featured .add-cart-btn {
	background: var(--salmon-pink);
	padding: 8px 15px;
	color: var(--white);
	font-size: var(--fs-9);
	font-weight: var(--weight-700);
	text-transform: uppercase;
	border-radius: var(--border-radius-md);
	margin-bottom: 15px;
	transition: var(--transition-timing); 
}

.product-featured .add-cart-btn:hover {
	background: var(--eerie-black);
	color: var(--white);
}

.product-featured .showcase-status { margin-bottom: 15px; }

.product-featured .showcase-status .wrapper {
	display: flex;
	justify-content: space-between;
	align-items: center;
	color: var(--eerie-black);
	font-size: var(--fs-9);
	font-weight: var(--weight-400);
	text-transform: uppercase;
	margin-bottom: 10px;
}

.product-featured .showcase-status-bar {
	background: var(--cultured);
	position: relative;
	height: 10px;
	border-radius: 5px;
}

.product-featured .showcase-status-bar::before {
	position: absolute;
	content: '';
	top: 3px;
	left: 3px;
	height: 4px;
	width: 40%;
	background: var(--salmon-pink);
	border-radius: 4px;
}

.product-featured .countdown-desc {
	color: var(--eerie-black);
	font-size: var(--fs-9);
	font-weight: var(--weight-600);
	text-transform: uppercase;
	margin-bottom: 10px;
}

.product-featured .countdown {
	display: flex;
	gap: 5px;
}

.product-featured .countdown-content {
	padding: 5px;
	background: var(--cultured);
	border-radius: var(--border-radius-md);
	text-align: center;
	margin-left: 10px;
}

.product-featured .display-number {
	color: var(--eerie-black);
	font-size: var(--fs-5);
	font-weight: var(--weight-500);
	min-width: 40px;
}

.product-featured .display-text {
	color: var(--davys-gray);
	font-size: var(--fs-11);
}


/*---------------- PREDUCT GRID ----------------*/

.product-main { margin-bottom: 30px; }

.product-grid {
  display: grid;
  grid-template-columns: 1fr; /* Móvil por defecto */
  gap: 25px;
  padding: 0 20px;
}

@media (min-width: 600px) {
  .product-grid {
    grid-template-columns: repeat(2, 1fr); /* Tablet */
  }
}

@media (min-width: 992px) {
  .product-grid {
    grid-template-columns: repeat(4, 1fr); /* Escritorio */
  }
} 

.product-main h2 {
	color: var(--eerie-black);
	font-size: var(--fs-5);
	text-transform: uppercase;
	letter-spacing: 0.8px;
	font-weight: var(--weight-600);
	text-align: center;
}

.product-grid .showcase {
	border: 1px solid var(--cultured);
	border-radius: var(--border-radius-md);
	overflow: hidden;
	transition: var(--transition-timing);
}

.product-grid .showcase:hover { box-shadow: 0 0 10 hsla(0, 0%, 0%, 0.1); }

.product-grid .showcase-banner { position: relative; }

.product-grid .product-img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: var(--transition-timing);
}


.product-grid .product-img.default {
	position: relative;
	z-index: 1;
}

.product-grid .product-img.hover {
	position: absolute;
	top: 0;
	left: 0;
	z-index: 2;
	opacity: 0;
} 

.product-grid .showcase:hover .product-img.hover { opacity: 1; } 

.product-grid .showcase:hover .product-img.default { opacity: 0; }

.product-grid .showcase:hover .product-img { transform: scale(1.1); }


.product-grid .showcase-badge {
	position: absolute;
	top: 15px;
	left: 15px;
	background: var(--ocean-green);
	font-size: var(--fs-8);
	font-weight: var(--weight-500);
	color: var(--white);
	padding: 0 8px;
	border-radius: var(--border-radius-sm);
	z-index: 3;

}

.product-grid .showcase-badge.angle {
	top: 8px;
	left: -29px;
	transform: rotate(-45deg);
	text-transform: uppercase;
	font-size: 11px;
	padding: 5px 40px;
}

.product-grid .showcase-badge.black { background: var(--eerie-black); }

.product-grid .showcase-badge.pink { background: var(--salmon-pink); }

.product-grid .showcase-actions {
	position: absolute;
	top: 10px;
	right: 10px;
	font-size: 20px;
	transform: translateX(50px);
	transition: var(--transition-timing);
	z-index: 3;
}

.product-grid .showcase:hover .showcase-actions {transform: translateX(0);}

.product-grid .btn-action {
	background: var(--white);
	color: var(--sonic-silver);
	margin-bottom: 5px;
	border: 1px solid var(--cultured);
	padding: 5px;
	border-radius: var(--border-radius-sm);
	transition: var(--transition-timing);
}

.product-grid .btn-action:hover {
	background: var(--eerie-black);
	color: var(--white);
	border-color: var(--eerie-black);
}

.product-grid .showcase-content { padding: 15px 20px 0; }

.product-grid .showcase-category {
	color: var(--salmon-pink);
	font-size: var(--fs-9);
	font-weight: var(--weight-500);
	text-transform: uppercase;
	margin-bottom: 10px;
}

.product-grid .showcase-title {
	color: var(--sonic-silver);
	font-size: --fs-8;
	font-weight: var(--weight-300);
	text-transform: capitalize;
	letter-spacing: 1px;
	margin-bottom: 10px;
	transition: var(--transition-timing);
}

.product-grid .showcase-title:hover {color: var(--eerie-black);}

.product-grid .showcase-rating{
	display: flex;
	color: var(--sandy-brown);
	margin-bottom: 10px;
}

.product-grid .price-box {
	display: flex;
	gap: 10px;
	font-size: var(--fs-7);
	color: var(--eerie-black);
	margin-bottom: 10px;

}

.product-grid .price { font-weight: var(--fs-700); }

.product-grid del { color: var(--sonic-silver); }

/* ----------------- TESTIMONIAL --------------- */

.testimonial-box { margin-bottom: 50px; }

.testimonial-card {
	padding: 30px 20px;
	border: 1px solid var(--cultured);
	border-radius: var(--border-radius-md)
}

.testimonial-banner {
	margin: auto;
	margin-bottom: 20px;
	border-radius: 50%;
}

.testimonial-name {
	font-weight: (--weight-700);
	text-transform: uppercase;
	color: var(--sonic-silver);
	margin-bottom: 5px;
}

.testimonial-title {
	color: var(--onyx);
	font-size: var(--fs-7);
	margin-bottom: 15px;
}

.quotation-img {
	margin: auto;
	margin-bottom: 10px;
}

.testimonial-desc {
	max-width: 70%;
	margin: auto;
	color: var(--sonic-silver);
	font-size: var(--fs-7);

}

/*---------- CTA ---------------*/

.cta-container {
	position: relative;
	aspect-ratio: 5 / 6;
	border-radius: var(--border-radius-md);
	overflow: hidden;
	margin-bottom: 25px;
}

.cta-banner {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.cta-content {
	display: inline-block;
	background: hsla(0, 0%, 98%, 0.7);
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: fit-content;
	padding: 15px 20px;
	text-align: center;
	border-radius: var(--border-radius-sm);
}

.cta-content .discount {
	background: var(--eerie-black);
	color: var(--white);
	font-size: var(--fs-11);
	font-weight: var(--weight-600);
	text-transform: uppercase;
	width: max-content;
	margin: auto;
	padding: 0 5px;
	border-radius: var(--border-radius-sm);
	margin-bottom: 5px;

}

.cta-title {
	color: var(--onyx);
	font-size: var(--fs-5);
	text-transform: capitalize;
	margin-bottom: 5px;
}

.cta-txt {
	color: var(--sonic-silver);
	font-size: var(--fs-7);
	margin-bottom: 5px;
}

.cta-btn {
	font-size: var(--fs-9);
	color: var(--sonic-silver);
	text-transform: uppercase;
	font-weight: var(--weight-700);
	margin: auto;

}

/*---- SERVICE-----*/

.service-container {
	display: flex;
	justify-content: center;
	align-items: center;
	flex-wrap: wrap;
	gap: 30px;
	padding: 30px 15px;
	border: 1px solid var(--cultured);
	border-radius: var(--border-radius-md);
}

.service-item {
	min-width: 190px;
	display: flex;
	align-items: center;
	gap: 15px;
}

.service-icon {
	font-size: 35px;
	color: var(--salmon-pink);
	transition: var(--transition-timing);

}

.service-icon ion-icon { --ionicon-stroke-width: 25px; }
.service-item:hover .service-icon { color: var(--eerie-black); }

.service h2{
	color: var(--eerie-black);
	font-size: var(--fs-5);
	font-weight: var(--weight-600);
	text-transform: capitalize;
	margin-bottom: 5px;
}

.service-title {
	color: var(--sonic-silver);
	font-size: var(--fs-7);
	font-weight: var(--weight-600);
	text-transform: capitalize;
	margin-bottom: 5px;
}

.service-desc {
	color: var(--sonic-silver);
	font-size: var(--fs-9);
}


/*----------- BLOGS ---------------*/

.blog { margin-bottom: 30px; }

.blog-container {
	display: flex;
	align-items: flex-start;
	gap: 15px;
	overflow-x: auto;
	overscroll-behavior-inline: contain;
	scroll-snap-type: inline mandatory;
}

.blog-card {
	min-width: 100%;
	scroll-snap-align: start;
}

.blog-banner {
	width: 100%;
	border-radius: var(--border-radius-md);
	margin-bottom: 20px;
}

.blog-category {
	width: max-content;
	color: var(--salmon-pink);
	font-size: var(--fs-8);
}

.blog-title {
	color: var(--eerie-black);
	font-size: var(--fs-5);
	font-weight: var(--weight-600);
	line-height: 1.4;
	margin-bottom: 5px;
	transition: var(--transition-timing);
}


.blog-title:hover { color: var(--salmon-pink); }

.blog-meta {
	color: var(--sonic-silver);
	font-size: var(--fs-7);
}

.blog-meta cite {
	font-style: normal;
	color: var(--davys-gray);  
}


/*-------------- FOOTER --------------------*/

footer {
	background: var(--eerie-black);
	padding: 30px 0;
}

.footer-category {
	margin-bottom: 30px;
	padding-bottom: 15px;
	border-bottom: 1px solid var(--onyx);
}

.footer-category-title {
	color: var(--salmon-pink);
	font-size: var(--fs-6);
	font-weight: var(--weight-600);
	text-transform: uppercase;
	margin-bottom: 15px;
}

.footer-category-box {
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-start;
	align-items: center;
	column-gap: 20px;
	row-gap: 3px;
	margin-bottom: 15px;
}

.category-box-title {
	color: var(--spanish-gray);
	font-size: var(--fs-8);
	font-weight: var(--weight-600);
	text-transform: uppercase;
}

.footer-category-link {
	position: relative;
	color: var(--sonic-silver);
	font-size: var(--fs-7);
	text-transform: capitalize;
	transition: var(--transition-timing);
}

.footer-category-link:hover { color: var(--spanish-gray); }

.footer-category-link:not(:last-child)::after {
	position: absolute;
	content: '';
	top: 3px;
	right: -10px;
	background: var(--sonic-silver);
	width: 1px;
	height: 15px;
}

.footer-nav-list {
	border-bottom: 1px solid var(--onyx);
	padding-bottom: 30px;
	margin-bottom: 30px; 
}

.footer-nav-list:not(:last-child) { margin-bottom: 20px; }

.footer-nav-list .nav-title {
	position: relative;
	color: var(--white);
	font-size: var(--fs-7);
	text-transform: uppercase;
	margin-bottom: 15px;
	padding-bottom: 5px;

}
.nav-title{
	position: relative;
	color: var(--white);
	font-size: var(--fs-7);
	text-transform: uppercase;
	margin-bottom: 15px;
	padding-bottom: 5px;

}

.footer-nav-list .nav-title::before {
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	background: var(--salmon-pink);
	width: 60px;
	height: 1px;
}

.footer-nav-item { padding: 3px 0; }

.footer-nav-link,
.footer-nav-item .content {
	width: max-content;
	color: var(--sonic-silver);
	font-size: var(--fs-7);
	text-transform: capitalize;
	transition: var(--transition-timing);
}



.footer-nav-link:hover { color: var(--salmon-pink); }

.footer-nav-item.flex {
	display: flex;
	align-items: flex-start;
	gap: 10px;
}

.footer-nav-item .content {
	font-style: normal;
	margin-bottom: 5px; 
}

.footer-nav-item  .icon-box {
	color: var(--sonic-silver);
	font-size: 25px;
}

.footer-nav-item  .icon-box ion-icon { --ionicon-stroke-width: 30px; }

.footer-nav-list .social-link {
	display: flex;
	justify-content: flex-start;
	align-items: center;
	gap: 10px;
	margin-bottom: 20px;
}
.footer-nav-list .social-link:hover { color: var(--salmon-pink); }

.social-link .footer-nav-link { font-size: 25px; }

.footer-bottom {
	margin-bottom: 50px;
	text-align: center;
}

.payment-img {
	max-width: 335px;
	width: 100%;
	margin: auto;
	margin-bottom: 15px;
}

.copyright {
	color: var(--sonic-silver);
	font-size: var(--fs-8);
	font-weight: var(--weight-500);
	text-transform: capitalize;
	letter-spacing: 1.2px;
}

.copyright a {
	display: inline;
	color: inherit;
}


/* --------------- RESPONSIBE -------------------*/

@media (min-width: 480px) {
	:root {
		--fs-1: 1.875rem;
	}

	.header-top {
		display: block;
		padding: 10px 0;
		border-bottom: 1px solid var(--cultured);
	}

	.container .social-link { display: none; }
	.header-top-actions { display: none; }

	.header-alert-news {
		color: var(--sonic-silver);
		font-size: var(--fs-9);
		text-transform: uppercase;
	}

	.header-alert-news b { font-weight: var(--weight-500); }

	.header-main { padding: 25px 0; }

	.mobile-bottom-navigation {
		border-top-left-radius: var(--border-radius-md);
		border-top-right-radius: var(--border-radius-md);
	}

	.slider-item { aspect-ratio: 5 / 3; }

	.banner-content {
		top: 50%;
		right: auto;
		bottom: auto;
		transform: translateY(-50%);
		max-width: 320px;
	}

	.banner-subtitle { --fs-7: 1rem; }

	.banner-text {
		display: block;
		color: var(--sonic-silver);
		font-size: var(--fs-7);
		font-weight: var(--weight-500);
		margin-bottom: 10px;
	}

	.banner-text b { font-size: var(--fs-2); }

	.banner-btn { padding: 7px 20px; }

	.product-grid {
		grid-template-columns: repeat(4, 1fr);
		gap: 30px;
	}

	.cta-content { padding: 40px; }

	.cta-content .discount {
		--fs-11: 0.875rem;
		padding: 5px 10px;
	}

	.cta-title { --fs-5: 1.5rem; }

	.cta-text { --fs-7: 1rem; }

	.cta-btn { --fe-9: 1rem; }

	.copyright { --fs-8: 0.875; }

}

@media (min-width: 570px) {
	.header-top .container {
		display: flex;
		justify-content: space-between;
		align-items: center;
	}

	.header-main .container {
		display: flex;
		justify-content: space-between;
		align-items: center;
	}

	.header-logo { margin-bottom: 0; }

	.header-top-actions {
		display: flex;
		align-items: center;
		gap: 10px;
	}

	.header-top-actions select {
		border: none;
		display: flex;
		min-width: 80px;
		padding: 5px 0;
		font: inherit;
		color: var(--sonic-silver);
		font-size: var(--fs-8);
		text-transform: uppercase;
		cursor: pointer;
		transition: var(--transition-timing);
	}

	.header-top-actions select:hover { color: var(--eerie-black); }

	.header-search-container { min-width: 300px; }

	.slider-item { aspect-ratio: 4 / 2; }

	.banner-content { background: none; }

	.category-item-container { gap: 30px; }

	.category-item {min-width: calc(50% -15px);}

	.product-minimal .showcase-container { min-width: 50%; }

	.product-featured .showcase-img {
		max-width: 450px;
		margin: auto;
	}

	.product-featured .countdown { gap: 20px; }

	.cta-container { 
		aspect-ratio: 2 / 1; 
	
  	width: 100%;
	}

	.blog-container { gap: 30px; }

	.blog-card {min-width: calc(50% - 15px);}

}

@media (min-width: 768px) {
	:root {
		--fs-1: 2.375rem;
    }

	html {font-size: 17px;}

	.container {
		max-width: 750px;
		margin: auto;
	}

	.modal-content {
		display: flex;
		align-items: center;
		max-width: 750px;
		width: fit-content;
	}

	.newsletter-img { display: block; }

	.newsletter { text-align: left; }

	.header-main .container { gap: 80px; }

	.header-search-container {flex-grow: 1;}

	.slider-item {
		aspect-ratio: auto;
		height: 350px;
	}

	.banner-content { max-width: 380px; }

	.banner-subtitle { --fs-7: 1.25rem; }

	.banner-text { --fs-7: 1.125rem; }

	.banner.text b {--fs-2: 1.875rem;}

	.banner-btn { --fs-11: 0.75rem; }

	.category-img-box { padding: 20px; }

	.product-minimal {
		display: flex;
		flex-wrap: wrap;
		justify-content: center;
		gap: 20px;
	}

	.product-minimal .product-showcase {
		min-width: calc(50% - 10px);
		width: calc(50% - 10px);
	}

	.product.minimal .showcase-container { min-width: 100%; }

	.product-featured .showcase {
		display: flex;
		justify-content: center;
		align-items: center;
		gap: 20px;
	}

	.product-featured .showcase-img { max-width: fit-content; }

	.product-featured .showcase-content {
		margin-top: 0;
		min-width: calc(100% - 345px);
	}



	.footer-nav .container {
		display: flex;
		flex-wrap: wrap;
		row-gap: 50px;
		column-gap: 20px;
	}

	.footer-nav-list {
		min-width: calc(33.33% - 15px);
		width: calc(33.33% - 15px);
	}
}

@media (min-width: 1024px){
	:root {
		--fs-1: 2.265rem;
		--fs-2: 1.125rem;
	}

	.container { max-width: 980px; }

	.notification-toast { bottom: 30px; }

	.header-social-container {
		display: flex;
		align-items: center;
		gap: 5px;
	}

	.header-social-container .social-link-a {
		padding: 5px;
		background: hsl(0, 0%, 95%);
		border-radius: var(--border-radius-sm);
		color: var(--sonic-silver);
		transition: var(--transition-timing);
	}

	.header-social-container .social-link:hover { 
		color: var(--white);
		background: var(--salmon-pink);
	 }

	 .header-user-actions {
	 	display: flex;
	 	align-items: center;
	 	gap: 15px;
	 }

	 .header-user-actions .action-btn {
	 	position: relative;
	 	font-size: 35px;
	 	color: var(--onyx);
	 	padding: 5px;
	 }

	  .header-user-actions .count {
	  	position: absolute;
	  	top: -2px;
	  	right: -3px;
	  	background: var(--bittersweet);
	  	color: var(--white);
	  	font-size: 12px;
	  	font-weight: var(--weight-500);
	  	line-height: 1;
	  	padding: 2px 4px;
	  	border-radius: 20px;
	  }


}