@import url('https://fonts.googleapis.com/css?family=Josefin+Sans:100,100i,300,300i,400,400i,600,600i,700,700i&display=swap');
body {
	background: #fff;
	font-weight: 300;
}
html, body {
	height: 100%;
}
body, button, input, optgroup, select, textarea {
	font-family: 'Josefin Sans', sans-serif;
}
h1, h2, h3, h4, h5, h6 {
	font-family: 'Josefin Sans', sans-serif;
}
a {
	color: #555
}
a:hover, a:focus {
	color: #555;
	outline: none;
}
a, button {
	outline: none;
}
.no-padding {
	padding: 0;
}
.row {
	max-width: 990px;
}
#main-container {
	padding-top: 30px;
}
.img-responsive {
	width: 100%;
}
.banner {
	margin-bottom: 15px;
}
.page-row {
	max-width: 1280px;
	margin: auto;
}
.page-box-container {    
	padding: 0;
}
.bg-overlay {
	position: fixed;
	background: #000;
	width: 100%;
	height: 100%;
	z-index: 1000;
	opacity: 0.5;
	transition: ease-in 1s all;
}
/*home slider sitio
---------------------------*/
.full-screen-slider {
	position: relative;
	min-height: auto;
}
.swiper-container {
	position: absolute;
	width: 100%;
}
.swiper-lazy {
	max-width: 100%;
	background-size: cover;
	background-position:center;
}
.full-screen {
	position: relative;
	max-width: 1440px;
	min-height: auto;
	padding-right: 15px;
	padding-left: 15px;
	margin-right: auto;
	margin-left: auto;
}
.full-screen-container {
	width: 100%;
	height: 100%;
	position: absolute;
	right: 0;
	left: 0;
}
.home-absoluto {
	position: absolute;
	z-index: 5;
}
.slide-logo1 {
	width: 350px;
	top: 8%;
	left: 20%;
}
.slide-logo2 {
	width: 380px;
	right: 12%;
	margin: auto;
	top: 0;
	bottom: 0;
	height: 240px;
}
.slide-logo3 {
	width: 400px;
	bottom: 5%;
	right: 4%;
}
.container-home-slide {
	width: 50%;
	left: 25px;
	top: calc(20% - 100px);
}
.logo-mariposa p {
	font-style: italic;
	color: #fff;
	text-align: right;
	margin-top: 10px;
	font-size: 20px;
}
.logo-mariposa {
	width: 300px;
}
.logo-md {
	width: 600px;
	bottom: 50px;
	right: 50px;
}
.btn-home {
	background: #fff;
	padding: 10px 14px;
	text-transform: uppercase;
	margin: 8px auto;
	display: block;
	font-size: 10px;
	color: #000;
	font-weight: 700;
}
/*menu home 
---------------------------*/
.sticky-container {
	height: 133px;
}
.menu-container-home .sub-menu {
	display: none;
}
.menu-container-home {
	margin-top: 30px;
	margin-bottom: 15px;
}
.menu-site {
	margin: 0;
	list-style-type: none;
}
.menu-site li {
	display: block;
}
.menu-site li a {
	color: #000;
	font-size: 18px;
	line-height: 22px;
	padding: 2px 0;
	display: block;
	font-weight: 400;
}
.menu-site>li>a {
	text-transform: uppercase;
}
ul.sub-menu {
	margin-left: 0;
	text-transform: capitalize;
}
.menu-site>li:first-child {
	margin-bottom: 20px;
}
#menu-principal-home li a {
	color: #fff;
	font-size: 24px;
	line-height: 28px;
}
.menu-site>li:first-child a {
	font-weight: 700;
}
.btn-search {
	background: transparent;
	color: #fff;
	text-transform: uppercase;
	border: none;
	font-size: 24px;
	display: inline-block;
	vertical-align: bottom;
	padding: 0;
}
.input-search {
	width: 60%;
	max-width: 250px;
	margin-bottom: 0;
	border: none;
	background: transparent;
	border-bottom: 1px dashed #fff;
	box-shadow: none;
	color: #fff;
	display: inline-block;
	font-size: 24px;
	padding-bottom: 0;
}
.input-search:focus {
	border: none;
	border-bottom: 1px dashed #fff;
	box-shadow: none;
	background: transparent;
}
#menu-principal>li>a, 
#menu-sidebar>li>a {
	font-size: 20px;
	line-height: 24px;
}
#menu-principal>li,
#menu-sidebar>li {
	margin-bottom: 15px;
}
/*menu toggle
---------------------------*/
.overlay-menu-toggle {
	position: relative;
	width: 35px;
	height: 35px;
	cursor: pointer;
	outline: none;
	top: 5px;
}
.overlay-menu-toggle:before,
.overlay-menu-toggle:after {
	position: absolute;
	content: '';
	width: 100%;
	background: #000;
	margin: auto;
	height: 5px;
	right: 0;
	transition: all 1s ease;
}
.overlay-menu-toggle:before {
	box-shadow: 0 10px 0 #000;
	top: 4px;
}
.overlay-menu-toggle:after {
	top: 24px;
}
.icon-menu-activo:before {
	box-shadow: 0 0 0 transparent;
	-webkit-transform: rotate(225deg);
	-ms-transform: rotate(225deg);
	transform: rotate(225deg);
	top: 14px;
}
.icon-menu-activo:after {
	-webkit-transform: rotate(315deg);
	-ms-transform: rotate(315deg);
	transform: rotate(315deg);
	top: 14px;
}
.overlay-menu {
	position: fixed;
	border-top: 2px solid rgba(128, 128, 128, 0.4);
	background: #fff;
	top: 100%;
	width: 260px;
	left: -100%;
	height: 100vh;
	padding: 2.8% 5%;
	overflow-x: scroll;
}
.overlay-menu.is-open {
	left: 0;
	-webkit-transition: ease-in .5s all;
	transition: ease-in .5s all;
}
/*menu del sitio
---------------------------*/
.top-menu.is-stuck.is-at-top {
	padding-top: 10px;
	transition: all 1s;
	z-index: 70000;
}
.top-menu {    
	background: #fff;
	width: 100%;
	padding: 30px 0 15px;
	border-bottom: 2px solid rgba(128, 128, 128, 0.4);
	transition: padding .25s ease;
	z-index: 50000;
}
.logo-header {
	width: 200px;
}
.top-menu.is-stuck.is-at-top .logo-header {
	width: 120px;
	transition: width 1s ease;
}
.top-menu .row {
	display: flex;
	align-items: center;
	height: auto;
	max-width: 1200px;
}

.menu-site.is-at-top {
	padding-top: 50px;
	transition: all 1s;
}
/*
---------------------------*/
.section-imagen {
	position: relative;
	margin-bottom: 25px;
}
.section-txt-bottom {
	position: absolute;
	margin: auto;
	right: 0;
	left: 0;
	bottom: 0;
	width: 90%;
	padding: 40px;
	color: #fff;
	text-align: center;
	text-transform: uppercase;
}
.section-txt-lg {
	font-size: 40px;
	line-height: 44px;
	letter-spacing: 10px;
	margin-bottom: 8px;
	text-shadow: 2px 3px 4px #000;
	font-weight: 700;
}
.section-txt-sm {
	font-size: 54px;
	line-height: 58px;
	letter-spacing: 2px;
	text-shadow: 2px 3px 4px #000;
	font-weight: 700;
}
.txt-bottom-large {
	font-size: 80px;
	line-height: 84px;
	letter-spacing: 10px;
	margin-bottom: 20px;
	text-shadow: 2px 3px 4px #000;
	font-weight: 700;
}
/*Categorias
---------------------------*/
.box-home-cat {
	padding: 15px 10px;
	position: relative;
}
.titulo-categoria {
	position: absolute;
	bottom: 60px;
	background: #fff;
	border: 0 solid #000;
	padding: 10px 15px;
	font-size: 24px;
	margin: auto;
	right: 0;
	left: 0;
	width: 70%;
	text-align: center;
	text-transform: uppercase;
	color: #000;
	font-weight: 700;
}
.titulo-categoria:before, 
.titulo-categoria:after {
	content: " ";
	width: 100%;
	height: 100%;
	position: absolute;
	border: 0 solid #000;
	transition: all 0.8s;
}
.titulo-categoria:after {
	top: 0;
	left: 0;
	border-top: 4px solid black;
	border-left: 4px solid black;
}
.titulo-categoria:before {
	bottom: 0;
	right: 0;
	border-bottom: 4px solid black;
	border-right: 4px solid black;
}
.box-home-cat:hover .titulo-categoria:before, 
.box-home-cat:hover .titulo-categoria:after {
	width: 80%;
	height: 100%;
}
.box-home-cat:hover img {
	filter: brightness(.5);  
	transition: all 0.8s;
}
/*logo martha footer 
---------------------------*/
.logo-section-center {
	position: absolute;
	top: 0;
	right: 0;
	left: 0;
	bottom: 0;
	margin: auto;
	width: calc(50% + 100px);
	height: 42px;
}
.logo-section-center img {
	width: 580px;
	height: 45px;
}
/*seccion martha x ivonne
---------------------------*/
.icon-play {
	position: absolute;
	width: 100px;
	height: 100px;
	margin: auto;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
}
#logo-md-ivonne {
	width: 500px;
	padding: 10px 25px;
}
.imgRender{
	width: 100%;
}
.box-texto {
	margin-bottom: 30px;
}
.box-texto p {
	font-size: 16px;
	line-height: 20px;
}
.md-firma {
	width: 375px;
	margin: 33px auto 0;
	display: block;
}
.margin-image {
	margin-bottom: 20px;
}
/*seccion productos 
---------------------------*/
.section-txt-center {
	text-align: center;
	text-transform: uppercase;
	color: #000;
	margin: 40px auto 20px;
}
.txt-negro-lg,
.txt-negro-sm {
	text-shadow: none;
}
/*seccion detalles de producto 
---------------------------*/
.item-producto {
	float: left !important;
}
.info-producto {
	margin-bottom: 30px;
	position: relative;
}
.producto-imagen {
	position: relative;
}
.img-hover-effect {
	position: absolute;
	margin: auto;
	left: 0;
	right: 0;
	top: 0;
	bottom: 0;
	opacity: 0;
	transition: opacity .45s ease-in-out 0s;
}
.info-producto:hover .img-hover-effect {
	opacity: 1;
}
.producto-nombre {
	color: #000;
	font-size: 14px;
	font-weight: 400;
	line-height: 18px;
	margin-bottom: 5px;
}
.producto-nombre a {
	color: #000;
}
.producto-nombre a:hover {
	color: #555;
}
.producto-precio {
	font-size: 14px;
	font-weight: 400;
	line-height: 18px;
}
.border-top {
	width: 100%;
	background: #211915;
	height: 2px;
	margin: 15px 0;
}
.txt-hover-effect {
	position: absolute;
	bottom: -20px;
	width: 100%;
	display: block;
	font-weight: 400;
	text-transform: uppercase;
	opacity: 0;
	font-size: 12px;
	border: 2px solid #000;
	background: #000;
	color: #fff;
	padding-top: 2px;
}
.txt-hover-effect:hover {
	background: #fff;
	color: #000 !important;
}
.info-producto:hover .txt-hover-effect {
	opacity: 1;
	bottom: 0;
	transition: all .5s;
	color: #fff;
}
/* filtro de productos 
---------------------------*/
.productos-filtro {
	padding: 16px 0;
    margin-top: 20px;
}
.productos-filtro-tab {
	position: relative;
	text-transform: uppercase;
}
.productos-filtro ul>li>a {
	color: #000;
	font-size: 12px;
	padding: 4px 18px;
	font-weight: 700;
}
.is-accordion-submenu-parent>a:after {
	border-color: #000000 transparent transparent;
	right: 0;
}
.categoria-menu.is-active:before {
	border-top: 0.5px solid rgba(33, 25, 21, 0.5);
	content: '';
	position: absolute;
	width: 100%;
	top: 0;
	height: 1px;
	right: 0;
}
.categoria-menu {
	position: absolute;
	z-index: 50;
	background: #fff;
	margin-left: 0;
	width: 100%;    
	text-align: left;
	padding: 12px 0 6px;
}
.categoria-menu li label {
	margin: auto;
	display: block;
	font-size: 12px;
	font-weight: 300;
}
.categoria-menu li [type=checkbox] {
	position: absolute;
	opacity: 0;
	width: 100%;
}
.categoria-menu li input:checked ~ label {
	background: #dad8d8;
	margin: auto;
}
/*footer
---------------------------*/
.footer-container {
	background: #000;
	padding: 50px 0;
	color: #fff;
}
#social-media {
	margin: 15px 0;
}
#social-media li {
	display: inline-block;
}
#social-media li a {
	color: #fff;
	font-size: 28px;
	padding: 10px 16px;
	transition: color 1s ease;
}
#social-media li a:hover {
	color: #555;
}
.footer-derechos {
	margin-bottom: 30px;
}
.footer-derechos p {
	font-size: 12px;
	line-height: 16px;
	margin-bottom: 0;
}
.footer-derechos a {
	color: #fff;
}
.logo-md-footer {
	width: 120px
}
/*contador
---------------------------*/
#contador {
	max-width: 420px;
	margin-bottom: 20px;
}
.pleca {
	background: #000;
	text-transform: uppercase;
	font-size: 20px;
	color: #fff;
	padding: 4px 0 0;
	margin-bottom: 15px;
}
.counter {
	padding: 0;
}
.counter span:first-child {
	position: relative;
	color: #000;
	font-weight: 700;
	font-size: 50px;
	display: block;
	line-height: 54px;
}
.counter span:last-child {
	display: block;
	color: #555;
	font-weight: 400;
	font-size: 12px;
}
.counter:nth-child(3) span:first-child:after,
.counter:nth-child(4) span:first-child:after {
	content: ':';
	right: 0;
	top: -5px;
	position: absolute;
}
.counter span:first-child:before {
	left: 0;
	right: 0;
	bottom: 0;
	content: '';
	width: 50%;
	height: 2px;
	position: absolute;
	margin: auto;
	background: #ccc;
}
@media screen and (max-width: 39.9375em) {
	.sticky-container {
		height: 95px;
	}
	#main-container {
		padding-top: 15px;
	}
	.container-home-slide {
		display: none;
	}
	.swiper-lazy {
		height: 430px;
	}
	.full-screen {
		height: 430px;
	}
	.logo-md { 
		width: 240px;
		margin: auto;
		right: 0;
		left: 0;
	}
	.titulo-categoria {
		right: inherit;
		max-width: 260px;
		left: 30px;
		font-size: 16px;
		bottom: 30px;
	}
	.top-menu {
		padding-top: 15px;
	}
	.sticky img.logo-header {
		width: 140px;
	}
	.overlay-menu {
		padding: 20px 30px;
	}
	.txt-bottom-large {
		font-size: 50px;
		line-height: 54px;
	}
	.mobile-productos-filtro {
		position: relative;
	}
	#filter-mobile h5 {
		text-transform: uppercase;
		text-align: left;
		margin-bottom: 0;
	}
	#menu-filtro-mobile {
		z-index: 5000;
		position: absolute;
		background: rgb(255, 255, 255);
		width: 100%;
	}
	#menu-filtro-mobile>li:last-child {
		margin-bottom: 10px;
	}
	#menu-filtro-mobile>li:first-child {
		border-top: 0.5px solid rgba(33, 25, 21, 0.5);
	}
	#menu-filtro-mobile>li {
		border-bottom: 0.5px solid rgba(33, 25, 21, 0.5);
	}
	.categoria-menu {
		position: relative;
		padding: 10px;
	}
	.productos-filtro {
		border-top: 0.5px solid rgba(33, 25, 21, 0.5);
		border-bottom: 0.5px solid rgba(33, 25, 21, 0.5);
		padding: 0;
		margin-bottom: 15px;
	}
	.productos-filtro ul>li>a {
		padding: 14px 18px;
	}
	.categoria-menu.submenu li a {
	    padding: 2px 14px;
	}
	a#icon-filtro {
		position: relative;
	}
	#icon-filtro:after {
		border: none;
		background: url(../../images/productos/iconos/filtro.svg) no-repeat;
		height: 26px;
		width: 26px;
		right: 50px;
		top: 0;
		bottom: 0;
		margin: auto;
		transform: none;
	}
	.is-accordion-submenu-parent>a:after {
		right: 50px;
	}
	.icon-play {
		width: 50px;
		height: 50px;
	}
	.section-txt-center {
		margin: 20px auto 20px;
	}
	.home-absoluto {
		margin: auto;
		right: 0;
		left: 0;
		bottom: 50px;
		height: auto;
		top: inherit;
		width: 260px;
	}
	.info-producto {
		margin-bottom: 15px;
	}
	.producto-nombre, 
	.producto-precio {
		font-size: 12px;
		line-height: 16px;
	}
}
/* Medium and up */
@media screen and (min-width: 40em) {
	.overlay-menu-toggle {
		opacity: 0;
	}
	.top-menu.is-stuck.is-at-top .overlay-menu-toggle {
		opacity: 1;
	}
	.page-aside {
		width: 180px;
	}
	#topbox-container {
		width: calc(100% - 180px);
		padding-right: 18%;	
	}
}
/* Medium only */
@media screen and (min-width: 40em) and (max-width: 63.9375em) {
	.titulo-categoria {
		font-size: 20px;
	}
	.logo-md {
		width: 500px;
	}
	#menu-sidebar li a {
		font-size: 16px;
		line-height: 20px;
	}
	.logo-mariposa {
		width: 260px;
	}
	.home-absoluto {
		margin: auto;
		right: 0;
		left: 0;
		bottom: 50px;
		top: inherit;
		width: 400px;
	}
}
/* Large and up */
@media screen and (min-width: 64em) {
	.overlay-menu {
		width: 25%;
	}
	.page-aside {
		width: 220px;
	}
	#topbox-container {
		width: calc(100% - 220px);
		padding-right: 18%;	
	}

}
/* Large only */
@media screen and (min-width: 64em) and (max-width: 74.9375em) {
	.logo-md {
		width: 400px;
		bottom: 30px;
		right: 30px;
	}
}
@media (min-width: 1024px) and ( max-width: 1440px ) {
	.swiper-lazy {
		background-position: center;
		background-position-x: 100%;
	}
}
@media ( max-width: 1024px ) {
	.section-txt-lg {
		font-size: 30px;
		line-height: 34px;
	}
	.section-txt-sm {
		font-size: 44px;
		line-height: 48px;
	}
}
@media (min-width: 769px) and ( max-width: 900px ) {
	.section-txt-lg {
		font-size: 36px;
		line-height: 40px;
	}
	.section-txt-sm {
		font-size: 40px;
		line-height: 44px;
	}
	.txt-bottom-large {
		font-size: 60px;
		line-height: 64px;
	}
	.txt-negro-sm {
		font-size: 32px;
		line-height: 36px;
	}
	.txt-negro-lg {
		font-size: 20px;
		line-height: 24px;
	}
}
@media (min-width: 640px) and (max-width: 768px) {
	.section-txt-lg {
		font-size: 30px;
		line-height: 34px;
	}
	.section-txt-sm {
		font-size: 40px;
		line-height: 44px;
	}
	.section-txt-bottom {
		padding: 20px;
	}
	.txt-bottom-large {
		font-size: 44px;
		line-height: 48px;
	}
	.txt-negro-sm {
		font-size: 24px;
		line-height: 28px;
	}
	.txt-negro-lg {
		font-size: 20px;
		line-height: 24px;
		letter-spacing: 4px;
	}
}
@media (min-width: 481px) and (max-width: 639px) {
	.section-txt-bottom {
		padding: 5px;
	}
	.section-txt-lg {
		font-size: 16px;
		line-height: 24px;
	}
	.section-txt-sm {
		font-size: 28px;
		line-height: 30px;
	}
	.txt-bottom-large {
		font-size: 36px;
		line-height: 40px;
	}
}
@media (max-width: 480px) {
	.section-txt-lg {
		font-size: 20px;
		line-height: 24px;
		letter-spacing: 2px;
		margin-bottom: 2px;
	}
	.section-txt-sm {
		font-size: 16px;
		line-height: 20px;
		letter-spacing: 4px;
	}
	.section-txt-bottom {
		padding: 5px;
	}
	.txt-bottom-large {
		font-size: 18px;
		line-height: 22px;
	}
	.txt-negro-lg {
		font-size: 22px;
		line-height: 26px;
	}

	.txt-negro-sm {
		font-size: 20px;
		line-height: 24px;
	}
}
@media only screen and ( max-width: 360px ) {
/*	.producto-nombre, 
	.producto-precio {
		font-size: 12px;
		line-height: 16px;
	}*/
	.producto-nombre {
		min-height: 32px;
	}
	.counter span:first-child {
		font-size: 40px;
		line-height: 44px;
	}
}
@media only screen and ( max-height: 420px ) and (orientation : landscape) {
	.container-home-slide {
		display: none;
	}
	.logo-md {
		width: 400px;
		right: 0;
		left: 0;
		margin: auto;
	}
}
@media only screen and ( max-height: 600px ) {
	.menu-container-home {
		margin-top: 0;
		margin-bottom: 0;
	}
}
