@charset "UTF-8";
/* CSS Document */
*{
	margin: 0;
	padding: 0;
	box-sizing:border-box;
}

body{
	height: auto;
	padding: 0px;
	font-family: "Quicksand", sans-serif;
	}

.contenedor{
	width: 100%;
	height: auto;
	margin: auto;
	display: flex;
	justify-content: center;
	align-items: center;
	z-index: 99;
}

#header{
	width: 100%;
	height: 79px;
	position: absolute;
	top: 0;
	left: 0;
	background: transparent;
	z-index: 9999;
}

#header.slidedown{
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	background: #071D77;
	animation: slidedown .4s forwards;
}

@keyframes slidedown{
	from{
		top: -250px;
	}
	to{
		top: 0;
		box-shadow: 0 2px 8px 0 rgba(0, 0, 0, .2);
	}
}

#header,#menu-principal{
	width: 100%;
	height: 79px;
	display: flex;
	justify-content: space-between;
	align-items: center;
}

#header,#menu-principal,#nav-menu{
	display: flex;
	justify-content: flex-end;
	align-content: center;
}

#header,#menu-principal,#nav-menu,.nav-list{
	display: flex;
	justify-content: space-between;
	align-items: center;
}

#header,#menu-principal,#nav-menu,.nav-list,.nav-menu-item{
	list-style: none;
	padding: 15px 30px;
	
}

#logo,.nav-menu-item,.nav-link{
	display: inline-block;
	text-decoration: none;
	color: #ffffff;
	font-weight: 500;
	font-size: 15px;
	cursor: pointer;
}

#header,#menu-principal,#nav-menu,.nav-list,.nav-menu-item,.nav-link{
	transition: all ,1s ease-in-out;
}

.nav-menu-item, .nav-link{
	background: none;
}

.nav-link:hover{
	color: #2B3871;
	transition: all 0.2s ease;
}

#logo{
	justify-content: center;
	align-content: center;
	margin-bottom: 10px;
}

.showcase{
	width: 100%;
	height: 800px;
	background: url("vestidos_imgs/banner_vst.jpg") no-repeat;
	background-position: center;
	background-size: cover;
	position: relative;
	display: flex;
	justify-content: center;
	align-items: center;
}

.showcase .overlay{
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	background: rgba(0,0,0, .5);
}

.showcase .contenedor2{
	padding: 0 230px 0 230px;
	color: #FFFFFF;
}

.showcase .contenedor2 h3{
	font-size: 45px;
	font-weight: 600;
	line-height: 55px;
	color: #FFFFFF;
	justify-content: center;
}

.contenedor2{
	align-content: center;
	text-align: center;
	align-items: center;
	justify-content: center;
	margin-top: 400px;
}

.product{
	padding: 50px 0;
	text-align: center;
}

.product h3{
	color: #000C40;
	font-size: 20px;
	text-transform: uppercase;
	margin-bottom: 50px;
}

.productos-contenedor{
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 10px;
	padding: 10px 10px 10px 10px;
}

.product{
	text-align: center;
	padding: 30px;
	box-shadow: 0 0 20px rgba(0, 0,0, 0.1);
}

.product h3{
	font-size: 20px;
	color: #000C40;
	margin-bottom: 15px;
}

.product p, .precio{
	font-size: 15px;
	color: #000C40;
	margin-bottom: 15px;
}

.precio{
	font-weight: 800;
}

/*Footer*/
#main-footer {
	background-color: #071D77;
	color: #FFFFFF;
	padding: 60px 0 20px 0;
}

.footer-container {
	max-width: 1200px;
	margin: 0 auto;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	padding: 0 20px;
}

.footer-section h3 {
	font-size: 18px;
	margin-bottom: 20px;
	border-bottom: 2px solid #FFFFFF;
	display: inline-block;
	padding-bottom: 5px;
}

.footer-logo-img {
	width: 100%;
	height: auto;
	margin-bottom: 15px;
}

.footer-section ul {
	list-style: none;
	padding: 0;
}

.footer-section ul li a {
	margin-bottom: 10px;
}

.footer-section ul li a:hover {
	color: #FFFFFF;
	text-decoration: underline;
}

.footer-section i {
	margin-right: 10px;
	color: #FFFFFF;
}

.social-icons {
	display: flex;
	gap: 15px;
}

.social-icons a {
	color: #FFFFFF;
	transform: translateY(-5px);
}

.footer-bottom {
	text-align: center;
	border-top: 1px solid #333;
	margin-top: 40px;
	padding-top: 20px;
}

.footer-bottom p {
	font-size: 12px;
	color: #888;
	letter-spacing: 1px;
}
.modal {
	display: none;
	position: fixed;
	z-index: 10000;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	background-color: rgba(0,0,0,0.8);
	overflow: auto;
}

.modal-content {
	background-color: #fefefe;
	margin: 5% auto;
	padding: 20px;
	border-radius: 10px;
	width: 80%;
	max-width: 900px;
	position: relative;
	animation: animatetop 0.4s;
}

@keyframes animatetop {
	from {top: -300px; opacity: 0}
	to {top: 0; opacity: 1}
}

.close-modal {
	position: absolute;
	right: 20px;
	top: 10px;
	font-size: 35px;
	font-weight: bold;
	cursor: pointer;
	color: #071D77;
}

.modal-body {
	display: flex;
	gap: 30px;
	margin-top: 20px;
	align-items: flex-start;
}

/*Galeria*/
.product-gallery {
	display: flex;
	flex: 1.2;
	gap: 15px;
}

.main-img-container img {
	width: 100%;
	height: 400px;
	object-fit: cover;
	border-radius: 5px;
}

.thumbnails-side {
	display: flex;
	flex-direction: column;
	gap: 10px;
}

.thumbnails-side img {
	width: 60px;
	height: 60px;
	object-fit: cover;
	border: 1px solid #ddd;
	border-radius: 4px;
	cursor: pointer;
	transition: 0,2s
}

.thumbnails-side img:hover, .thumbnails-side img.active {
	border: 2px solid #071D77;
	box-shadow: 0 0 5px rgba(0,0,0,0.2);
}

.main-image-container {
	flex: 1;
}

.main-image-container img {
	width: 100%;
	max-height: 500px;
	object-fit: contain;
	border-radius: 4px;
}

/*Información*/
.product-info {
	flex: 1;
	text-align: left;
}

.modal-info h2 {
	color: #071D77;
	margin-bottom: 10px;
}

.brand-link {
	color: #071D77;
}

.modal-precio {
	font-size: 24px;
	font-weight: bold;
	color: #071D77;
	margin: 15px 0;
}

.modal-descripcion {
	font-size: 16px;
	color: #444;
	line-height: 1.5;
	margin-top: 15px;
	margin-bottom: 20px;
	text-align: justify;
	white-space: pre-line;
}

.menu-icon {
	display: none;
	font-size: 30px;
	color: white;
	cursor: pointer;
	padding: 10px;
}

@media (max-width: 810px) {
	
	#menu-open {
		display: block;
		color: white
	}
	
	#header {
		height: auto;
		position: fixed;
		background: transparent;
	}
	
	#header.slidedown{
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	background: #071D77;
	animation: slidedown .4s forwards;
	}
	
	#menu-principal {
		display: flex;
		flex-direction: row;
		align-items: center;
		height: 70px;
		padding: 0 20px;
		width: 100%;
	}
	
	#nav-menu, .nav-list {
		flex-direction: column; 
		padding: 0;
		width: 100%;
	}

	.nav-menu-item {
		padding: 10px; 
		width: 100%;
		text-align: center;
	}
	
	#logo {
		margin-bottom: 5px;
	}
	
	#logo img {
		width: 140px; 
		height: auto;
	}
	
	#nav-menu {
		position: fixed;
		top: 0;
		right: -100%; 
		width: 250px; 
		height: 100vh;
		background: #071D77;
		flex-direction: column;
		justify-content: flex-start !important;
		align-items: center;
		transition: 0.4s; 
		z-index: 10000;
		padding-top: 60px;
		box-shadow: -5px 0 15px rgba(0,0,0,0.3);
	}
	
	/*Clase activada con JavaScript para mostrar el menu*/
	#nav-menu.active {
		right: 0;
	}
	
	#menu-close {
		display: block;
		position: absolute;
		top: 20px;
		right: 20px;
	}
	
	.nav-list {
		flex-direction: column;
		width: 100%;
		padding: 0;
	}
	
	.nav-menu-item{
		width: 100%;
		text-align: center;
		padding: 20px 0;
	}
	
	/*Showcase-banner*/
	.showcase {
		height: 700px;
	}
	
	.showcase .contenedor {
		padding: 0 40px;
		margin-top: 200px;
	}
	
	.showcase .contenedor h3 {
		font-size: 30px;
		line-height: 38px;
	}
	
	.productos-contenedor {
		grid-template-columns: repeat(3, 1fr);
		gap: 10px;
		max-width: 100%;
		padding: 20px;
	}
	
	.product {
		padding: 20px;
		width: 100%;
	}
	
	.product img {
		width: 100%;
		height: auto;
	}
	
	.modal-content {
		width: 90%;
		margin: 5% auto;
		padding: 30px;
	}
	
	.modal-body {
		gap: 20px;
	}
	
	.main-image-container img {
		height: 350px;
	}
	
	.product-info h2 {
		font-size: 22px;
	}
	
/*Footer*/
	.footer-container {
		flex-direction: column;
		text-align: center;
	}
	
	.footer-section {
		width: 100%;
		margin-bottom: 40px;
	}
	
	.social-icons {
		justify-content: center;
	}
	
	.footer-logo-img {
		margin: 0 auto 15px auto;
		display: block;
		max-width: 200px;
	}
}

@media (max-width: 480px) {
	
	#menu-open {
		display: block;
		color: white
	}
	
	#header {
		height: auto;
		position: fixed;
		background: transparent;
	}
	
	#header.slidedown{
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	background: #071D77;
	animation: slidedown .4s forwards;
	}
	
	#nav-menu, .nav-list {
		flex-direction: column; 
		padding: 0;
		width: 100%;
	}

	.nav-menu-item {
		padding: 10px; 
		width: 100%;
		text-align: center;
	}
	
	#logo {
		margin-bottom: 5px;
	}
	
	#logo img {
		width: 140px; 
		height: auto;
	}
	
	#nav-menu {
		position: fixed;
		top: 0;
		right: -100%;
		width: 250px; 
		height: 100vh;
		background: #071D77;
		flex-direction: column;
		justify-content: flex-start !important;
		align-items: center;
		transition: 0.4s; 
		z-index: 10000;
		padding-top: 60px;
		box-shadow: -5px 0 15px rgba(0,0,0,0.3);
	}
	
	/*Clase activada con JavaScript para mostrar el menu*/
	#nav-menu.active {
		right: 0;
	}
	
	#menu-close {
		display: block;
		position: absolute;
		top: 20px;
		right: 20px;
	}
	
	.nav-list {
		flex-direction: column;
		width: 100%;
		padding: 0;
	}
	
	.nav-menu-item{
		width: 100%;
		text-align: center;
		padding: 20px 0;
	}
	
	.showcase {
		height: 600px;
		margin-top: 0;
	}
	
	.showcase .contenedor2 {
		padding: 0 20px;
		margin-top: 200px;
	}
	
	.showcase .contenedor2 ¨{
		font-size: 26px;
		line-height: 32px;
	}
	
	/*Sección Showcase Banner*/
	.showcase {
		height: 500px; 
	}
	
	.productos-contenedor {
		grid-template-columns: 1fr;
		gap: 20px;
		padding: 20px;
	}
	
	.product {
		padding: 20px;
		width: 100%;
	}
	
	.product img {
		width: 100%;
		height: auto;
	}
	
	.product h3 {
		font-size: auto;
		margin-bottom: 10px;
		margin-top: 15px;
	}
	
	.modal-body {
		flex-direction: column;
	}
	
	.product-gallery {
		flex-direction: column-reverse;
	}
	
	.thumbnails-side {
		flex-direction: row;
		overflow-x: auto;
		padding-bottom: 5px;
	}
	
	.thumbnails-side img {
		width: 50px;
		height: 50px;
	}
	
/*Footer*/
	.footer-container {
		flex-direction: column;
		text-align: center;
	}
	
	.footer-section {
		width: 100%;
		margin-bottom: 40px;
	}
	
	.social-icons {
		justify-content: center;
	}
	
	.footer-logo-img {
		margin: 0 auto 15px auto;
		display: block;
	}
 }
