.col_product
{
	width:30%;
	display:inline-block;
	margin-right:1%;
	margin-bottom:15px;
	vertical-align:top;
}

.col_product h3
{
	font-size:14px;
	line-height:20px;
	font-weight:300;
	margin-top:20px;
}

.elementor img {
    border-radius: 5px !important;
}

.col_product .product_picture
{
	min-height:230px;
	text-align:center;
	/* border:1px solid #eaeaea; */
}

.col_product .product_picture img
{
	max-height:350px;
    border-radius: 5px;
}

#single-product #col_left
{
    margin-right: 20px;
	width: calc(50% - 20px);
	display:inline-block;
}

#single-product #product_image_details img
{
	max-height:90px;
	margin-right:5px;
    border-radius: 5px;
}

#single-product #product_image img
{
    border-radius: 5px;
}

#single-product #product_info
{
	width:49%;
	display:inline-block;
	vertical-align:top;
}

#single-product #product_info h3, #single-product #product_info p, #single-product #product_info .form-control, #single-product #product_info #product-price,, #single-product #product_info #product-price-default
{
	margin-left:30px;

}

#single-product #product_info #product-price
{
	color:#44aa66;
		font-size:30px;
		display:inline-block;
}

#single-product #product_info #product-price-default
{
	color:#00AEEF;
		font-size:30px;
		display:inline-block;
}

.img-responsive
{
	max-width:100%;
}

button.add-to-cart, button.add-to-cart-custom
{
	margin-left:30px;
	padding:15px 30px;
	background:#000;
	color:#fff;
	border:0px;
	margin-top:30px;
    border-radius: 5px;
}

#ficha_tecnica
{
	margin-left:0px;
}

#ficha_tecnica label
{
	color:#111;
	font-weight:bold;
	clear:both;
	width:100%;
	display:block;
	margin-top:20px;
}


.family-list
{
	list-style:none;
	text-align:center;
	margin-bottom:20px !important;
}

.family-list li
{
	display:inline-block;
	margin-right:30px;
}

.family-list li.active
{
	border-bottom:1px solid #222;
}

.product_picture{
	margin-bottom:20px;
}

.product_title
{
	height:20px;
}

.product_title h3
{
	font-size:20px;
    width: 80%; display:
    inline-block;
    margin-top: 15px;
}

.product_title
{
	height:fit-content;
}

#single-product label
{
	clear:both;
	display:block;
	color: #111;
    border-bottom: 3px solid #111;
    margin-bottom: 15px;
    font-weight: bold;
    font-size: 14px;
}

.filtro_sidebar
{
	margin:15px;
	border:1px solid #eaeaea;
    border-radius: 5px;
	padding:15px;
    box-shadow: 4px 4px 6px -2px #eaeaea;
}

.filtro_sidebar ul{
	
	list-style:none !important;
	margin:0px !important;
	padding:0px !important;
}



.category-list
{
	list-style:none;
	margin-top:10px;
	text-align:center;
}

.category-list li
{
	display:inline-block;
	margin-right:30px;
}

.category-list li.active
{
	border-bottom:1px solid #222;
}

.category-list h3
{
	font-size:12px;
}

.selector-brazo span.active {
    border: 2px solid #00AEEF;
}


.table {
  width: 100%;
  max-width: 100%;
  margin-bottom: 1rem;
}

.table th,
.table td {
  padding: 0.75rem !important;
  vertical-align: top;
  border-top: 1px solid #eceeef !important;
}

.table thead th {
  vertical-align: bottom;
  border-bottom: 2px solid #eceeef;
}

.table tbody + tbody {
  border-top: 2px solid #eceeef;
}

.table .table {
  background-color: #fff;
}

.table-sm th,
.table-sm td {
  padding: 0.3rem;
}

.table-bordered {
  border: 1px solid #eceeef;
}

.table-bordered th,
.table-bordered td {
  border: 1px solid #eceeef;
}

.table-bordered thead th,
.table-bordered thead td {
  border-bottom-width: 2px;
}

.table-striped tbody tr:nth-of-type(odd) {
  background-color: rgba(0, 0, 0, 0.05);
}

.table-hover tbody tr:hover {
  background-color: rgba(0, 0, 0, 0.075);
}

.table-active,
.table-active > th,
.table-active > td {
  background-color: rgba(0, 0, 0, 0.075);
}

.table-hover .table-active:hover {
  background-color: rgba(0, 0, 0, 0.075);
}

.table-hover .table-active:hover > td,
.table-hover .table-active:hover > th {
  background-color: rgba(0, 0, 0, 0.075);
}

.table-success,
.table-success > th,
.table-success > td {
  background-color: #dff0d8;
}

.table-hover .table-success:hover {
  background-color: #d0e9c6;
}

.table-hover .table-success:hover > td,
.table-hover .table-success:hover > th {
  background-color: #d0e9c6;
}

.table-info,
.table-info > th,
.table-info > td {
  background-color: #d9edf7;
}

.table-hover .table-info:hover {
  background-color: #c4e3f3;
}

.table-hover .table-info:hover > td,
.table-hover .table-info:hover > th {
  background-color: #c4e3f3;
}

.table-warning,
.table-warning > th,
.table-warning > td {
  background-color: #fcf8e3;
}

.table-hover .table-warning:hover {
  background-color: #faf2cc;
}

.table-hover .table-warning:hover > td,
.table-hover .table-warning:hover > th {
  background-color: #faf2cc;
}

.table-danger,
.table-danger > th,
.table-danger > td {
  background-color: #f2dede;
}

.table-hover .table-danger:hover {
  background-color: #ebcccc;
}

.table-hover .table-danger:hover > td,
.table-hover .table-danger:hover > th {
  background-color: #ebcccc;
}

.thead-inverse th {
  color: #fff;
  background-color: #292b2c;
}

.thead-default th {
  color: #464a4c;
  background-color: #eceeef;
}

.table-inverse {
  color: #fff;
  background-color: #292b2c;
}

.table-inverse th,
.table-inverse td,
.table-inverse thead th {
  border-color: #fff;
}

.table-inverse.table-bordered {
  border: 0;
}

.table-responsive {
  display: block;
  width: 100%;
  overflow-x: auto;
  -ms-overflow-style: -ms-autohiding-scrollbar;
}

.table-responsive.table-bordered {
  border: 0;
}

.opcion_variante, .ver_mas_ficha 
{
	
	display:inline-block;
    border-radius: 5px;
	background:#eaeaea;
	padding:3px 10px;
	font-size:12px;
	color:#333;
	margin-right:10px;
	cursor:pointer;
	width:100px;
	text-align:center;
	margin-bottom:10px;
}

.ver_mas_ficha {
    background:#111;
	color:#fff;
    padding: 10px 10px;
    font-size: 16px;
    width:fit-content;
    border: none;
    margin: 0;
}

.opcion_variante.active
{
	
	background:#111;
	color:#fff;
	
}

.selector-variantes
{
	margin-bottom:30px;
}


.opcion_variante_configurador
{
	
	display:inline-block;

	background:#eaeaea;
	padding:3px 10px;
	font-size:12px;
	color:#333;
	margin-right:10px;
	cursor:pointer;
	width:100px;
	text-align:center;
	margin-bottom:10px;
}
.opcion_variante_configurador.active
{
	
	background:#111;
	color:#fff;
	
}

.seleccion_rango, .seleccion_cristal
{
	margin-bottom:30px;
}

.sel_componente
{
	background: #eaeaea;
    border: 0px;
    color: #111;
    padding: 5px 50px;
    border-left: 3px solid;
	font-size:14px;
}

#single-product p
{
	color:#111;
	font-size:13px;
	line-height:16px;
	margin-bottom:30px;
}

.item_familia
{
	display:inline-block;
	position: relative;
	
}

.item_familia .item-familia-titulo {
    text-align: center;
    background-color: rgba(255, 255, 255, 0.7);
    position: absolute;
    top: 87%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 90%;
}

.item_familia img
{
    width:40vw;
	max-width:32vw !important;
    border-radius: 10px !important;
	border: 4px solid #fff !important;
}

.family-list a, .family-list-image a{
	
	color:#111;
	font-weight:bold;
}

.filtro_sidebar h3
{
	clear:both;
	display:block;
	color: #111;
    border-bottom: 3px solid #111;
    margin-bottom: 15px;
    font-weight: bold;
    font-size: 14px;
}


.filtro_sidebar li
{
	clear:both;
	display:block;
	color: #111;
    font-size: 14px;
}

.row_product
{
	height:150px;
	clear:both;
	border-bottom:1px solid #aaa;
	margin-left:10%;
	padding-top:10px;
	
}

.row_product_2
{
	min-height:60px;
	clear:both;
	border-bottom:1px solid #aaa;
	margin-left:10%;
	padding:15px 0;
    color: black;
    font-weight: bold;
}

.row_product .product_picture, .row_accesorio .product_picture
{
	width:15%;
	float:left;
	text-align:center;
	margin-bottom: 10px;
}

.row_product .product_picture img
{
	max-height:120px;
	
}

.row_product .product_info, .row_accesorio .product_info
{
	width:54%;
	float:left;
}

.row_product .product_price, .row_accesorio .product_price
{
	width:7%;
	float:left;
	text-align:right;
	font-weight:bold;
	color:#222;
}

.row_product .product_quantity, .row_accesorio .product_quantity, .row_accesorio .product_buttons
{
	width:10%;
	float:left;
	margin-bottom: 0;
	text-align:right;
	font-weight:bold;
	color:#222;
}

input[type=number]:not(.elementor-field).update_quantity {
	margin-bottom: 0;
}

.row_accesorio
{
	clear:both;
	border-bottom:1px solid #aaa;
	margin-left:10%;
	padding-top:10px;
	height:90px;
	
}

.row_accesorio h3{
	font-size:14px;
}

.row_accesorio .product_info{
	font-size:12px;
}

.row-100 {
    width: 100%;
}

.col-30 {
    width: 30%;
}

.col-50 {
    width: 50%;
}

.col-70 {
    width: 70%;
}

.row-editando-carrito {
	display: flex;
	flex-direction: row;
	align-items: center;
}

.actions-editando-carrito-container {
	display: flex;
}

.msg-editando-carrito {
    font-size: 15px;
    width: fit-content;
    margin: 0;
    background-color: orange;
    color: white;
    border-radius: 5px 0 0 5px;
    padding: 5px;
	margin-left: 15px;
}

.actualizar-precios, .elimina-producto, .elimina-producto-custom, .limpia-datos, .muestra-precios, .guarda-carrito-btn, .cargar-carrito {
	margin: 20px 0;
	padding: 5px 10px;
	float: right;
	background-color: black;
	border-radius: 3px;
	color: white;
    border: none;
}

.actualizar_precios_container {
	display:flex;
	width:100%;
	justify-content: end;
}

.muestra-precios, .guarda-carrito-btn, .cargar-carrito {
    color:#111;
    background:#eaeaea;
    border: none;
    margin-left: 10px;
}

.load {
    color: white;
    background: black;
}

.guarda-carrito-btn {
    padding: 10px 15px;
}

.tooltip{
    position: relative;
    display: inline-block;  
}
.tooltip .tooltip-text {
    visibility: hidden;
    width:140px;
    background-color: #071e26;
    border-radius: 25px;
    color: #fff;
    text-align: center;
    padding: 6px;
    position: absolute;
    top: -30px;
    z-index: 1;
}
.tooltip:hover .tooltip-text {
    visibility: visible;
}

.elimina-producto, .elimina-producto-custom {
	font-size: 12px;
	width: 5%;
	margin: 0;
}

.carritos-guardados-container {
	width: 100%;
	margin-top: 50px;
	margin-bottom: 50px;
	text-align: right;
}

.row-carrito-guardado {
	background-color: aliceblue;
	border-radius: 10px;
	padding: 15px 10px 0 0;
	margin-bottom: 20px;
}

.info-carrito-guardado {
	display: flex;
	align-items: center;
	justify-content: right;
}

.text-carrito-guardado {
	width: 50%;
	margin: 0;
}

#brazos_seleccionables input[type=number], #productos_complementarios  input[type=number]
{
	width:60px;
}

#datos_pedido
{
	font-size:12px;
	width: calc(26% - 60px);
	margin-right: 60px;
	float:right;
	height:100%;
	min-height:100vh;
}


#datos_pedido h3
{
	font-size:18px;
	margin-top:30px;
}

#desglose_pedido {
	width:70%;
	float:left;
	height:100%;
	min-height:80vh;
}

.submit_form_button
{
	color:#fff;
	background:#000;
	padding:5px 20px;
	border:0px;
	border-radius: 3px;
}

.notification-icon {
    background-color: red;
    font-size: 14px;
    border-radius: 5px;
    padding: 1px;
    width: 14px;
    height: 14px;
    position: absolute;
    display: block;
    top: 0;
    right: 9px;
    color: white;
    text-align: center;
}


/* STRUCTURE */

.wrapper {
  display: flex;
  align-items: center;
  flex-direction: column; 
  justify-content: center;
  width: 100%;
  min-height: 100%;
  padding: 20px;
}

#formContent {
  -webkit-border-radius: 10px 10px 10px 10px;
  border-radius: 10px 10px 10px 10px;
  background: #fff;
  padding: 30px;
  width: 90%;
  max-width: 450px;
  position: relative;
  padding: 0px;
  -webkit-box-shadow: 0 30px 60px 0 rgba(0,0,0,0.3);
  box-shadow: 0 30px 60px 0 rgba(0,0,0,0.3);
  text-align: center;
}

#formFooter {
  background-color: #f6f6f6;
  border-top: 1px solid #dce8f1;
  padding: 25px;
  text-align: center;
  -webkit-border-radius: 0 0 10px 10px;
  border-radius: 0 0 10px 10px;
}

#relacionados {
    margin-top: 20px;
}

#relacionados div {
    display: flex;
    flex-wrap: wrap;
}

#relacionados li
{
    border-radius: 5px;
    width: calc(16.6% - 72px);
	margin:15px;
	border:1px solid #eee;
	padding:20px;
    display: flex;
    justify-content: center;
    font-size:11px;
}

#relacionados a
{
	max-width:150px;
	display:inline-block;
	text-decoration:none;
	text-align:center;
	color:#111;
}

#relacionados img
{
	max-width:125px;
	border-radius:5px;
}

#relacionados ul{
	
	list-style:none;
	
}

.product_breadcrumb
{
	font-size:12px;
	margin-bottom:20px;
	margin-left:30px;
}

.product_breadcrumb a{
	text-decoration:none;
}

.nodisponible
{
	opacity:0.5;
}

.inventory-disclaimer {
    background-color: darkorange;
    border-radius: 5px;
    padding: 6px;
    color: white !important;
}

.inventory-disclaimer i {
    margin-left: 4px;
    margin-right: 4px;
}

.custom-form {
    margin: 100px;
}

.custom-form h3 {
    display: flex;
	width: 100%;
}

.custom-form input[type="text"] {
    width: 40%;
}

.custom-form input[type="number"] {
	width: 10%;
}

.custom-form input[type="text"][name="descripcion"],
.custom-form input[type="text"][name="linea_referencia"] {
    width: 50%; /* Ajusta el ancho según sea necesario */
    /* Otros estilos para este input en particular */
}

.custom-form button[type="submit"] {
    width: 40px;
    height: 40px;
    background: #000;
    color: #fff;
    border-radius: 3px;
    /* Otros estilos para el botón de enviar */
}

.separador.s {
	height: 75px;
}

.separador.md {
	height: 150px;
}

/* Estilos para el modal */
.modal {
	display: none;
	position: fixed;
	z-index: 1;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	overflow: auto;
	background-color: rgba(0,0,0,0.4);
	animation: fadeIn 0.3s ease;
  }
  
  .modal .modal-content {
	background-color: #fefefe;
	margin: 15% auto;
	padding: 20px;
	border: 1px solid #888;
	height: 200px;
	min-width: 200px;
    max-width: 300px;
	border-radius: 5px;
	display: flex;
	flex-direction: column;
  }

  .modal .modal-content .text-container {
	height: 80%;
	text-align: center;
	display: flex;
	width: 100%;
    align-items: center;
    justify-content: center;
  }

  .modal .modal-content p {
	height: auto;
	width: auto;
  }
  
  .modal .buttons-container {
	text-align: end;
	height: 15%;
	min-height: 50px;
    padding-top: 22px;
	border-top: 1px solid lightgray;
  }

  /* Agregar una animación de desvanecimiento */
  @keyframes fadeIn {
	from { opacity: 0; }
	to { opacity: 1; }
  }

  .spinner {
	display: none;
	position: fixed;
	z-index: 1;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	overflow: auto;
	background-color: rgba(0,0,0,0.4);
  }

  .spinner .spinner-text {
	background-color: #6fa9ee;
    font-weight: 500;
    padding: 10px;
    border-radius: 7px;
    font-size: 16px;
    color: white;
    width: 156px;
    height: 100px;
    position: absolute;
    top: 46%;
    left: 50%;
    margin-top: -25px;
    margin-left: -76px;

  }

  .spinner .spinner-content {
	border: 8px solid rgba(221, 220, 220, 0.1);
	border-left-color: #ffffff;
	border-radius: 50%;
	width: 40px;
	height: 40px;
	animation: spin 1s linear infinite;
	position: absolute;
	top: 50%;
	left: 50%;
	margin-top: -20px;
	margin-left: -20px;
  }
  
  @keyframes spin {
	0% { transform: rotate(0deg); }
	100% { transform: rotate(360deg); }
  }
  
.custom-button {
	background-color: white;
    color: black;
    padding: 10px;
    border-radius: 5px;
    text-decoration: none;
    box-shadow: lightgray 2px 2px 5px !important;
	transition: all 1s ease;
}

.custom-button:hover {
	background-color: black;
	color: white;
}

.custom-button.primary {
	background-color: #3b8ced;
	color: white;
}

.custom-button.primary:hover {
	color: white;
}

.custom-button.success {
	background-color: #58a858;
	color: white;
}

.custom-button.success:hover {
	color: white;
}

.mostrar-filtros-categorias {
    display: none;
    position: fixed;
    top: 50%;
    left: 0;    
    background-color: #3b8ced;
    padding: 10px 5px 10px 5px;
}

.mostrar-filtros-categorias i {
    color: white;
}

.mostrar-filtros-categorias p {
    margin: 0;
}

.filtros-sidebar-container {
    display: block;
    width:20%;
    float:left;
    height:100%;
    min-height:100vh;
}

.row-products-col {
    width:78%;
    float:right;
}

.row-products-col.configurador {
    width:100%;
    float:none;
}

#accesorios h3, #tiradores h3, #productos_complementarios h3, #brazos_seleccionables h3 {
    margin-top: 30px;
}

#accesorios ul, #tiradores ul, #productos_complementarios ul, #brazos_seleccionables ul {
    margin-left: 30px;
}

#relacionados li {
    width: calc(20% - 62px);
    padding: 15px;
}

#relacionados a {
    width: 100%;
}

#relacionados img
{
	max-width:100%;
	border-radius:5px;
}

#res_products .col_product {
    width: 15%;
}

#res_products.bigger {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
}

#res_products.big .col_product,
#res_products.bigger .col_product {
    width: 30%;
}

#datos_direcciones input {
    width: 100%;
}

@media only screen and (min-width: 941px) { 
    .filtros-sidebar-container {
        display: block !important;
    }
}

@media screen and (max-width: 940px) and (orientation: landscape) {

    .item_familia .item-familia-titulo {
        top: 84%;
    }

    #res_products .col_product, #res_products.big .col_product {
        width: 32%;
    }

    .product_title h3 {
        margin-top: 10px;
    }

    .row-products-col {
        width: 100%;
        float: none;
    }

    .row_products {
        position: relative;
        padding: 0 20px 0 20px;
    }

    .row_products .col_product {
        margin-right: 1.3%;
    }

    .row_products .product_picture {
        min-height: 175px;
    }

    .filtros-sidebar-container {
        position: fixed;
        top: 0;
        left: 20px;
        width: 37% !important;
        z-index: 99;
        display: none;
        overflow: scroll;
        padding-top: 41vh;
    }

    .filtros-sidebar-container .filtro_sidebar {
        margin: 0 0 20px 0;
        background-color: white;
        box-shadow: 3px 4px 6px -2px #b9b5b5;
    }

    .mostrar-filtros-categorias {
        display: block;
    }

    .category-list {
        margin: 0 !important;
        display: flex;
        flex-direction: row;
        flex-wrap: wrap;
    }

    .category-list li {
        width: calc(20% - 30px);
        margin: 0 15px 0 15px;
    }

    .category-list li img {
        height: 120px !important;
        object-fit: cover;
        width: 100%;
    }

    .modal {
        z-index: 999;
    }

    .modal .modal-content {
		margin: 10% auto;
	}
	
    .custom-form {
        margin: 20px;
		margin-top: 100px;
    }

    .custom-form input[type="text"],
    .custom-form input[type="number"],
    .custom-form button[type="submit"] {
        width: 100%;
        margin-bottom: 10px;
    }

    .custom-form input[type="text"],
    .custom-form input[type="number"],
	.custom-form input[type="text"][name="descripcion"],
	.custom-form input[type="text"][name="linea_referencia"] {
        width: 100%; /* 100% del ancho en pantallas pequeñas */
        display: block;
        margin-right: 0;
    }

	#datos_pedido {
		float: none;
		width: 100%;
	}

	#datos_pedido input[type="text"][name="ref_cliente"] {
		width: 100%;
	}

	#desglose_pedido {
		width:100%;
		float:none;
	}

    .row_product, .row_product_2 {
        margin: 0;
    }

    .row_product .product_picture {
        width: 16%;
    }

    .row_product .product_info {
        width: 47%;
    }

    .row_product .product_info h3 {
        font-size: larger;
    }

    .row_product .product_quantity {
        width: 8%;
    }

    .row_product .product_price {
        width: 11%;
    }

    .row_accesorio {
        margin-left: 5%;
    }

    .row_accesorio .product_info {
        width: 43%;
    }

    .row_accesorio .product_quantity {
        width: 11%;
    }

    .row_accesorio .product_price {
        width: 12%;
    }

    .row-editando-carrito {
        flex-direction: row !important;
    }

    .row-editando-carrito .actions-editando-carrito-container {
        width: 70%;
    }

/* 	.row_product, .row_product_2 {
		margin: 0 10px;
	}

	.row_accesorio {
		margin-left: 12%;
    	margin-right: 10px;
	}

	.row_product, .row_accesorio {
		margin-bottom: 20px;
	}

	.row_product .product_picture, .row_accesorio .product_picture, .row_product .product_info, .row_accesorio .product_info {
		width: 100%;
	}

	.row_product .product_quantity, .row_accesorio .product_quantity,
	.row_product .product_price, .row_accesorio .product_price {
		width: 30%;
		text-align: left;
	}

	.row_product .elimina-producto, .row_accesorio .elimina-producto,
	.row_product_2 .elimina-producto {
		width: 10%;
		margin-bottom: 66px;
	}

	.actualizar_precios_container {
		justify-content: left;
	}

	.row_product .product_picture img {
		min-width: 160px;
		min-height: 130px;
	}

	.row_accesorio .product_picture img {
		min-width: 90px;
		min-height: 60px;
	} */

	.info-carrito-guardado {
		flex-direction: column;
	}
	
	.text-carrito-guardado {
		width: 100%;
	}

	.row-editando-carrito {
		flex-direction: column;	
	}

	.actions-editando-carrito-container {
		width: 100%;
	}

	.msg-editando-carrito {
		margin-left: 0;
	}

	#datos_direcciones input {
		width: 100%;
	}

	#datos_cliente input {
		width: 100%;
	}

    .selector-variantes-container {
        width: 100%;
    }

    .selector-variantes-container .opcion_variante {
        margin-left: 3px;
        margin-right: 3px;
        width: calc(33% - 25px);
    }

    #accesorios ul, #tiradores ul, #productos_complementarios ul, #brazos_seleccionables ul {
        margin-left: 0;
    }

    #accesorios ul li, #tiradores ul li, #productos_complementarios ul li, #brazos_seleccionables ul li {
        width: 100% !important;
    }

    .selector-variantes-container {
        width: 100%;
    }

    .selector-variantes-container .opcion_variante {
        margin-left: 3px;
        margin-right: 3px;
        width: calc(25% - 25px);
    }

    #product_image {
        width: 100%;
    }

    #product_image img {
        height: 400px;
        width: 100%;
        object-fit: cover;
    }

    #product_image_details {
        width: 100%;
    }

    #product_image_details img {
        height: 90px;
        margin-left: 2px !important;
        margin-right: 2px !important;
        object-fit: cover;
        width: calc(25% - 4px);
    }

    .selector-variantes[data-filter=color_perfil_es],
    .selector-variantes[data-filter=acabado_cristal_es] {
        display: flex;
        flex-wrap: wrap;
        justify-content: space-between;
        margin-bottom: 0;
    }

    .selector-variantes[data-filter=color_perfil_es] .opcion_variante,
    .selector-variantes[data-filter=acabado_cristal_es] .opcion_variante {
        margin-bottom: 35px;
    }
}

@media only screen and (max-width: 1100px) {
    .show-mobile-logo .mobile-branding img.mobile-logo, .show-mobile-logo.show-device-logo .mobile-branding img.mobile-logo, .show-device-logo .mobile-branding img {
        max-width: 24% !important;
    }
}

@media only screen and (max-width: 600px) {

    .show-mobile-logo .mobile-branding img.mobile-logo, .show-mobile-logo.show-device-logo .mobile-branding img.mobile-logo, .show-device-logo .mobile-branding img {
        max-width: 43% !important;
    }

    #relacionados li {
        width: calc(50% - 62px);
        padding: 15px;
    }

    #relacionados a {
        width: 100%;
    }

    #res_products .row > h3 {
        margin-top: 25px;
    }

    #res_products .col_product, #res_products.big .col_product {
        width: 100%;
        margin-bottom: 5px;
    }

    #res_products .col_product .product_title {
        height: fit-content;
    }

    .opcion_variante[data-name=color_perfil_es], .opcion_variante[data-name=acabado_cristal_es] {
        margin-bottom: 25px;
        margin-left: 3% !important;
        margin-right: 3% !important;
    }

    #accesorios, #tiradores, #brazos_seleccionables {
        margin-top: 50px;
    }

    #accesorios ul, #tiradores ul, #productos_complementarios ul, #brazos_seleccionables ul {
        margin-left: 0;
    }

    #accesorios li, #tiradores li, #productos_complementarios li, #brazos_seleccionables li {
        width: 100% !important;
    }

    #single-product #col_left {
        width: calc(100% - 20px);
    }

    #product_image {
        width: calc(100vw - 10vw);
    }

    #product_image img {
        height: 30vh;
        width: 100%;
        object-fit: cover;
    }

    #product_image_details {
        width: calc(100vw - 10vw);
    }

    #product_image_details img {
        height: 90px;
        margin-left: 2px !important;
        margin-right: 2px !important;
        object-fit: cover;
        width: calc(33% - 4px);
    }

    #iconos {
        width: calc(100vw - 10vw);
    }

    #iconos img {
        width: 20%;
        display: inline-block;
    }

    .selector-variantes-container {
        width: calc(100vw - 10vw);
    }

    .selector-variantes-container .opcion_variante {
        margin-left: 3px;
        margin-right: 3px;
        width: calc(33% - 25px);
    }

    #productos_complementarios {
        width: calc(100vw - 10vw);
    }

    #productos_complementarios ul {
        margin-left: 0 !important;
    }

    #product_info {
        width: calc(100% - 20px) !important;
    }

    #product_info .product_breadcrumb {
        margin: 0 0 10px 0;
    }

    .filtros-sidebar-container {
        position: fixed;
        top: 0;
        left: 20px;
        width: 70% !important;
        z-index: 99;
        display: none;
        overflow: scroll;
        padding-top: 20vh;
    }

    .filtros-sidebar-container .filtro_sidebar {
        margin: 0 0 20px 0;
        background-color: white;
        box-shadow: 3px 4px 6px -2px #b9b5b5;
    }

    .col-product h3 {
        position: relative;
    }

    .row-products-col {
        width: 100%;
        float: none;
    }

    .row_products {
        position: relative;
        padding: 0 20px 0 20px;
    }

    .row_products .col_product {
        width: 100%;
    }

    .mostrar-filtros-categorias {
        display: block;
    }

    .item_familia {
        width: 100%;
    }

    .item_familia img {
        min-width: 100% !important;
        /* min-width: calc(90vw - 10vw) !important; */
    }

    .family-list {
        margin: 0 !important;
        margin-bottom: 15px !important;
    }

    .family-list li {
        width: 50%;
        font-size: 14px;
        margin: 0;
    }

    .item_familia .item-familia-titulo {
        top: 87%;
    }

    .category-list {
        margin: 0 !important;
        display: flex;
        flex-direction: row;
        flex-wrap: wrap;
    }

    .category-list li {
        width: calc(50% - 30px);
        margin: 0 15px 0 15px;
    }

    .category-list li img {
        height: 120px !important;
        object-fit: cover;
        width: 100%;
    }

	.modal .modal-content {
		margin: 80% auto;
	}
	
    .custom-form {
        margin: 20px;
		margin-top: 100px;
    }

    .custom-form input[type="text"],
    .custom-form input[type="number"],
    .custom-form button[type="submit"] {
        width: 100%;
        margin-bottom: 10px;
    }

    .custom-form input[type="text"],
    .custom-form input[type="number"],
	.custom-form input[type="text"][name="descripcion"],
	.custom-form input[type="text"][name="linea_referencia"] {
        width: 100%; /* 100% del ancho en pantallas pequeñas */
        display: block;
        margin-right: 0;
    }

	#datos_pedido {
		float: none;
		width: 100%;
	}

	#datos_pedido input[type="text"][name="ref_cliente"] {
		width: 100%;
	}

	#desglose_pedido {
		width:100%;
		float:none;
	}

	.row_product, .row_product_2 {
		margin: 0 10px;
	}

	.row_accesorio {
		margin-left: 12%;
    	margin-right: 10px;
	}

	.row_product, .row_accesorio {
		margin-bottom: 20px;
	}

	.row_product .product_picture, .row_accesorio .product_picture, .row_product .product_info, .row_accesorio .product_info {
		width: 100%;
	}

	.row_product .product_quantity, .row_accesorio .product_quantity,
	.row_product .product_price, .row_accesorio .product_price {
		width: 30%;
		text-align: left;
	}

	.row_product .elimina-producto,
    .row_accesorio .elimina-producto,
	.row_product_2 .elimina-producto,
    .row_product .elimina-producto-custom,
    .row_accesorio .elimina-producto-custom,
	.row_product_2 .elimina-producto-custom {
		width: 10%;
		margin-bottom: 66px;
	}

	.actualizar_precios_container {
		justify-content: left;
	}

	.row_product .product_picture img {
		min-width: 160px;
		min-height: 130px;
	}

	.row_accesorio .product_picture img {
		min-width: 90px;
		min-height: 60px;
	}

	.info-carrito-guardado {
		flex-direction: column;
	}
	
	.text-carrito-guardado {
		width: 100%;
	}

	.row-editando-carrito {
		flex-direction: column;	
	}

	.actions-editando-carrito-container {
		width: 100%;
	}

	.msg-editando-carrito {
		margin-left: 0;
	}

	#datos_direcciones input {
		width: 100%;
	}

	#datos_cliente input {
		width: 100%;
	}

    .notification-icon {
        left: 7px;
        top: 7px;
    }

}