/*
Theme Name: Redoffice
Theme URI: https://redoffice.dev.radar.cl/
Author: Rodolfo Aranguiz
Author URI: https://redoffice.dev.radar.cl/
*/

@import url('https://fonts.googleapis.com/css2?family=Barlow:ital,wght@0,200;0,300;0,400;0,500;0,600;0,700;1,200;1,300;1,400;1,500;1,600;1,700&family=Khula:wght@300;400;600;700;800&family=Poppins:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,100;1,200;1,300;1,400;1,500;1,600;1,700;1,800;1,900&display=swap');

body { font-family: 'Barlow', sans-serif; }

:root { --Gris: #393939;    
        --Gris2: #565656;  
        --Azul: #00155E;
        --Amarillo: #FED800; 
        --Celeste:#00AEEF; 
        --Verde:#2BA84A; 
        --Negro: #010101; 
        --Rojo:#CF1B2B;         
        --NegroGrafito: #1A1A1A;
    }

.wa__btn_popup { right: 15px !important; bottom: 100px !important; }
.xoo-wsc-markup { z-index: 999999999999999999; position: relative; }

.btn-ficha-tecnica { font-weight: 700; background-color: #1A1A1A; color: #fff; position: relative; padding-left: 40px; } 
.btn-ficha-tecnica::before { content: ''; background-image: url(public/images/download-ficha.svg); position: absolute; background-repeat: no-repeat; background-size: cover; width: 20px; height: 20px; left: 10px; top: 9px; }
.btn-ficha-tecnica:hover { background-color: var(--Celeste); color: #fff;}

.woocommerce-cart .wp-block-woocommerce-product-new { display: none; }
.sin-cabecera { margin-top: 30px; padding: 10px; }
.bg-primary { background-color: var(--Amarillo) !important; color: #fff; }
.bg-gris {background-color: var(--Gris);}
.bg-secondary { background-color: var(--Azul) !important;  }
.btn-custom { background-color: var(--Verde) !important; color: #fff; }
.bg-gris p {
    color: #fff;
    margin: 0px;
}
.text-black { color: #000 !important;}

.caja-nueva-stockyficha { order:4; }

.wc-block-components-button.wp-element-button.wc-block-components-checkout-place-order-button.contained { background-color: var(--Verde) !important; border:none !important}
a { transition: 0.5s all;}
p { font-size: 1em; font-weight: 500; line-height: 155.523%;}
#breadcrumbs a, #breadcrumbs span { font-weight: 400; color: #000; text-decoration: none; }
#breadcrumbs .breadcrumb_last { color: var(--Verde) !important; font-weight: 500;}
.link_mi_cuenta { padding: 5px 15px; border-radius: 10px; background-color: transparent; text-decoration: none; color: #fff; border: solid 1px #fff; display: flex; align-items: center; }
.link_mi_cuenta:hover { background-color: var(--Amarillo); color: #fff !important; border-color: var(--Amarillo);}
.p-relative { position: relative;}
.pull-left { float: left;}

/* Logo | Buscador */
.logo-header {
    max-width: 200px;
}
a.sucursal {
    text-decoration: none;
    color: var(--Azul);
    border: solid 1px var(--Azul);
    border-radius: 10px;
    padding: 3px 30px;
    transition: 300ms;
}
a.sucursal:hover {
    text-decoration: none;
    color: var(--Azul);
    background-color: var(--Celeste);
    border: solid 1px var(--Celeste);
    transition: 300ms;
}
input#dgwt-wcas-search-input-1 {
    background-color: #fff;
}
/* button.dgwt-wcas-search-submit:after {
    content: "Buscar";
    color: red;
    text-transform: none;
} */

a.btn-sin-stock {
    background: #00155eb5;
    color: #fff;
    padding: 5px 10px;
    border-radius: 5px;
    text-decoration: none;
    text-transform: uppercase;
    font-weight: bold;
    font-size: 12px;
    margin: auto;
}

a.ofertas {
    text-decoration: none;
    color: var(--Azul);
    background-color: var(--Amarillo);
    border-radius: 10px;
    padding: 5px 15px;
    transition: 300ms;
}
a.ofertas, a.lista-escolar, a.categorias-menu, a#btn-categorias.ocultar  {
    text-decoration: none;
    border-radius: 10px;
    padding: 5px 15px;
    transition: 300ms;
    gap: 5px;
}
a.ofertas {    
    color: var(--Azul);
    background-color: var(--Amarillo);
}
a.ofertas:hover {    
    color: var(--Azul);
    background-color: var(--Celeste);
    transition: 300ms;
}

a.categorias-menu {
    background-color: transparent;
    color: #fff;
    border: solid 1px #fff;
    width: 170px;
}
a.categorias-menu:hover{
    background-color: var(--Amarillo);
    color: #fff !important;
    border-color: var(--Amarillo);
    transition: 300ms;
}
a#btn-categorias.ocultar {
    background-color: #fff;
    color: var(--Rojo);
}
a#btn-categorias.ocultar:hover {
    background-color: var(--Amarillo);
    color: var(--Rojo);
    transition: 300ms;
}
div#menu-web .row div,
div#menu-web .row div ul {
    gap: 30px;
}
div#menu-principal {
    background-color: #fff;
    padding: 15px 15px;
}
div#menu-principal a {
    text-decoration: none;
    color: var(--Gris);
    line-height: 30px;
}
#menu-principal ul {
    list-style: none;
    margin: 0;
    padding: 0;
}

#menu-principal ul li {
    list-style: none; 
}
div#menu-web a span {
    font-size: 14px;
    font-weight: 500;
}

/* CABECERA SITIO  */
.icono_header{max-width: 30px;}
.top .barra-texto-top { position: relative;}
.top .barra-texto-top p { background-color: var(--Verde); position: absolute; left: 0; right: 0; top: -15px; bottom: -15px; display: flex; align-items: center; justify-content: center; border-radius: 0px 0px 10px 10px; }
.top a, .top p { font-size: 0.8rem; }
.sticky-top { position: fixed; top: 0; left: 0; right: 0;}
.margin-top-negativo-40 { margin-top: -40px;}
.margin-top-negativo-50 { margin-top: -50px;}
.margin-top-negativo-60 { margin-top: -80px;}

header .rrss-top img { width: 30px; }
header a:hover { color: var(--Rojo);}
header nav { height: 100%; }
header nav > ul { height: 100%; list-style: none; display: flex; justify-content: center; align-items: center; margin-bottom: 0; }
header nav > ul > li { margin-right: 40px; position: relative;}
header nav > ul > li > a { text-decoration: none; color: #fff;  font-size: 1.2em; font-style: normal; font-weight: 600; margin: 20px 0; display: inline-block; }
header nav li.current-menu-item > a, header nav li.current_page_item > a { color: var(--Rojo);}
header nav ul.sub-menu li.current-menu-item ul.sub-menu { display: block; }
header nav ul.sub-menu li:first-child ul.sub-menu { display: block; }
header nav ul.sub-menu > li:hover > ul.sub-menu { display: block; }

header nav > ul > li > ul > li > a { text-decoration: none; color: #000; font-size: 0.8em;  font-style: normal; font-weight: 600; line-height: 260%; margin-left: 25px; }
header nav > ul > li > ul > li > a img { margin-right: 10px; margin-top: -5px; }
header nav > ul > li > ul > li > a:hover { color: var(--Verde);}
header nav > ul > li > ul > li > a:hover img { filter: invert(70%) sepia(16%) saturate(6844%) hue-rotate(212deg) brightness(99%) contrast(103%) }
header nav > ul > li:hover > ul.sub-menu { display: flex; justify-content: center; flex-direction: column; }
header nav > ul li > ul.sub-menu {    box-shadow: 0 .5rem 1rem rgba(0, 0, 0, .15) !important; border-radius: 5px; display: none;     position: absolute; background-color: #fff; padding: 10px; z-index: 99; list-style-type: disclosure-closed; left: -100px; top: 68px; min-width:270px; min-height: 170px; }
header nav > ul > li > ul.sub-menu > li { width: 100%;
    background-color: #fff;
    display: inline-block;
    align-items: center;
    margin-bottom: 5px; }
header nav .sub-menu .sub-menu { padding: 20px 20px; list-style: none; background-color: #fff;  position: relative; font-size: 0.9em; text-transform: uppercase; position: absolute; width: 1032px; left: 20%; min-width: unset; top: 0; }
header nav .sub-menu .sub-menu > li { margin-bottom: 5px; width: calc(98% / 4); display: inline-block; vertical-align: top;     font-weight: 600; text-transform: capitalize; }
header nav .sub-menu .sub-menu > li > a { color: var(--Amarillo) !important; text-decoration: none;}

header nav .sub-menu .sub-menu .sub-menu { left: 0; position: relative; padding: 0; width: fit-content; height: fit-content; min-height: unset; }
header nav .sub-menu .sub-menu .sub-menu li { width: 100%; font-weight: 400; left: 0; }
header nav .sub-menu .sub-menu .sub-menu li a:hover { color: var(--Verde);}

.tienda-menu > a { background-color: var(--Celeste); color: #fff !important; padding:5px 12px 5px 35px; border-radius: 5px; height: 40px;}
.tienda-menu > a:before { content: ''; background-image: url(public/images/lists.svg);      position: absolute; background-position: center; width: 20px; height: 20px; left: 10px; top: 30px; background-repeat: no-repeat; background-size: cover; }
/* SLIDER PRINCIPAL  */


.carousel-control-prev-icon {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23000'%3e%3cpath d='M11.354 1.646a.5.5 0 0 1 0 .708L5.707 8l5.647 5.646a.5.5 0 0 1-.708.708l-6-6a.5.5 0 0 1 0-.708l6-6a.5.5 0 0 1 .708 0z'/%3e%3c/svg%3e");
}
.carousel-control-next-icon {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23000'%3e%3cpath d='M4.646 1.646a.5.5 0 0 1 .708 0l6 6a.5.5 0 0 1 0 .708l-6 6a.5.5 0 0 1-.708-.708L10.293 8 4.646 2.354a.5.5 0 0 1 0-.708z'/%3e%3c/svg%3e");
}
/* BUSCADOR  */
.buscador { position: relative;}
.buscador a { color: transparent; } 
.buscador a::after { content: ''; background-image: url(public/images/buscador.svg); position: absolute; left: 0; width: 25px; height: 25px; background-size: 80%; background-repeat: no-repeat; background-position: center; }
.buscador a:hover { color: transparent; }
.buscador-form .dgwt-wcas-sf-wrapp { background-color: transparent !important;}
.buscador-form form input[type=search] { width: 100% !important; border: solid 1px #000 !important; padding: 5px 5px 5px 35px !important; border-radius: 5px !important; }
.buscador-form form button[type=submit] {  top: 12px !important; left: 10px !important; }

/* FORMULARIOS CF7  */
.wpcf7-form { }
.wpcf7-form p { }
.wpcf7-form p select, 
.wpcf7-form p input[type=text], 
.wpcf7-form p input[type=password], 
.wpcf7-form p input[type=email], 
.wpcf7-form p input[type=search],
.wpcf7-form p input[type=tel], 
.wpcf7-form p textarea { border: solid 1px var(--Amarillo); border-radius: 5px; }
.wpcf7 form.invalid .wpcf7-response-output, .wpcf7 form.unaccepted .wpcf7-response-output, .wpcf7 form.payment-required .wpcf7-response-output {border-color: var(--Azul)!important; text-align: left;}

.suscribirse { max-width: 100%; }
.suscribirse .newsletter { display: grid; grid-template-columns: 1fr auto; gap: 0; width: 90%; align-items: center;}
.wpcf7-form p input[type=submit] { margin-left: 50px; position: relative; background-color: var(--Amarillo); color: #fff; border: none; padding: 5px 20px 5px 40px; text-transform: capitalize; border-radius: 5px}
.wpcf7-form p input[type=submit]:hover { background-color: var(--Amarillo); }
footer .wpcf7-form input[type="submit"] { height: 100%; padding: 6px 10px; border: none; background: var(--Celeste); color: #fff; border-radius: 0px 5px 5px 0px;  margin: 0;}
footer .wpcf7-form input[type="submit"]:hover{background-color: var(--Azul); border: none!important;}
footer .wpcf7-form p input[type=submit]:before { content: ''; background-image: url(public/images/arrow_upward.svg); position: absolute; width: 25px !important; height: 25px; left: 60px; background-size: cover; background-position: center; z-index: 99; top: 7px; }
footer .suscribirse .newsletter .email, footer .suscribirse .newsletter .enviar {margin: 0;}
footer .wpcf7-form input[type="email"] {width: 100%; padding: 10px 12px; border-radius: 5px 0 0 5px; box-sizing: border-box; border: solid 1px #000; border-right: none; height: 37px; }

footer .wpcf7-not-valid-tip {     position: absolute; right: 0; } 

.btn-con-flecha > p { position: relative; width: fit-content; margin: auto; }
.btn-con-flecha > p:before { content: ''; background-image: url(public/images/arrow_upward.svg); position: absolute; width: 25px !important; height: 25px; left: 60px; background-size: cover; background-position: center; z-index: 99; top: 7px; }

main { min-height: 75vh;}
.owl-dots { text-align: center;  margin-top: 20px;}
button.owl-dot { width: 20px; height: 6px; background: #B2B2B2 !important; margin-right: 10px; }
button.owl-dot.active { background-color: #000 !important;}

/* CABECERA PAGINAS  */
.contenedor-categorias { position: relative;}
.contenedor-categorias .caja-titulo .page-title { color: #fff; font-weight: 900; }
.caja-titulo { position: absolute; top: 0; left: 15%; right: 50%; bottom: 0; color: #fff; display: flex; align-items: start; justify-content: center; flex-direction: column; }


/* MINICART  */
.mini-carrito { position: relative; width: fit-content; margin: auto; }
.mini-carrito a { background-color: var(--Rojo); border-radius: 10px; padding: 5px 15px; color: #fff; text-decoration: none;}
.mini-carrito a:hover { background-color: var(--Amarillo); color: #fff; }

.caja-info-pagos {     height: fit-content; }

.menu-mobile { display: none;}
.volver { display: none !important; }

.woocommerce ul.carrusel-destacados.products li.product { width: 100% !important; border: solid 1px #D7D2D2; margin-bottom: 0px !important;}
.woocommerce ul.products li.product .onsale { display: flex !important; justify-content: center; align-items: center; font-size: 0.8rem; right: 5% !important; width: fit-content; top: 15px !important; border-radius: 5px;  padding: 0px 10px; background-color: var(--Amarillo); color: #fff; min-height: 30px !important; height: 30px; }

/* WIDGETS  */
.archive .widgets { background-color: #F9F8F8;}
.archive .widgets .widget { margin-bottom: 20px;}
.archive .widgets .widget h3 { font-size: 1.3em; font-weight: 700; }
.archive .widgets ul { list-style: none; margin: 0; padding: 0; }
.archive .widgets ul li a { text-decoration: none; color: #000; font-size: 1em; font-style: normal; font-weight: 400; line-height: 17px; letter-spacing: -0.4px; }

/* FILTRO DE PRECIO  */
.woocommerce .widget_price_filter .ui-slider .ui-slider-range, .woocommerce .widget_price_filter .ui-slider .ui-slider-handle  { background-color: var(--Verde) !important; }
.woocommerce .widget_price_filter .price_slider_amount .button { width: fit-content;} 
.woocommerce .widget_price_filter .price_slider_amount { display: flex; flex-direction: column-reverse; align-items: end; }

/* PLP  */

.bloque-secciones-archive { display: flex; flex-direction: row-reverse; flex-wrap: wrap; justify-content: space-between; align-items: center; }
.bloque-secciones-archive .woocommerce-notices-wrapper { order: 1; margin: auto; width: 100%; }
.bloque-secciones-archive .woocommerce-result-count { order: 2; }
.bloque-secciones-archive .woocommerce-ordering { order: 3;}


.filtros-titulo { font-weight: 700; font-size: 1.5rem; margin-bottom: 10px; display: block;}
.hr-custom { height: 2px; background: black; opacity: 1; }
.caja-marca span { text-transform: uppercase; font-weight: bold; color: var(--Verde); }
ul.products li.product  { background-color: #fff; border-radius: 10px;}
ul.products li.product:hover { box-shadow: 0 .5rem 1rem rgba(0, 0, 0, .15) !important; }
ul.products li.product .caja-loop a:first-child { padding: 10px;     display: flex !important; flex-direction: column; }
ul.products li.product .caja-loop a h2 { order:2; padding-top: 0px !important; min-height: 62px; color: #000 !important;
     text-align: left !important; font-size: 1em !important; font-style: normal; line-height: 18px; }
ul.products li.product .caja-loop a .product-sku { order: 3;  color: gray; font-size: 12px; }
ul.products li.product .caja-loop form { padding: 5px;  display: flex; align-items: center; justify-content: center; background-color: #F2F2F2;}
ul.products li.product .caja-loop form .caja-mas-menos { }
ul.products li.product .caja-loop form .caja-mas-menos div.quantity { margin-top: 10px;}
ul.products li.product .caja-loop form .caja-mas-menos .minus { left: -26px; top: 15px; }
ul.products li.product .caja-loop form .caja-mas-menos .plus { right: -26px; top: 15px; }
ul.products li.product.outofstock .caja-loop a.button:before { left: 24% !important; }
.woocommerce.columns-12 .carrusel-destacados li.product.outofstock .caja-loop a.button:before { left:30% !important }
.archive  ul.products li.product.outofstock .caja-loop a.button:before { left: 35px !important; }
ul.products li.product.outofstock .caja-loop a.button:before { content: ''; background-image: url(public/images/arrow_upward.svg); position: absolute; width: 20px; height: 20px; left: 20px; top: 6px; }

a.add_to_cart_button { position: relative !important; padding-right: 30px !important; }
a.add_to_cart_button:before { content: ''; background-image: url(public/images/carro-de-compras.svg); position: absolute; left: 15%; width: 20px; height: 20px; background-size: contain; background-repeat: no-repeat; top: 8px; }


ul.products li.product.outofstock .button { background-color: gray !important; width: fit-content; padding: 5px 15px; margin: auto; display: block !important; margin-bottom: 10px; font-size: 1em !important; text-transform: uppercase !important; }
ul.products li.product.outofstock .button:before { content: none !important;}
ul.products li.product .button { padding: 7px 0px;  width: 100%; border-radius: 5px !important; background-color: var(--Verde) !important; color: #fff; text-transform: capitalize !important; font-weight: 700; font-size: 0.8em; line-height: normal; }
ul.products li.product .button:hover { background-color: #000 !important; }
ul.products li.product .button.button.alt:after{ content:''; background-image: url(public/images/carro-de-compras.svg); position: absolute; width: 20px; height: 20px; background-position: center; background-repeat: no-repeat; background-size: contain; top: 5px; right: 12px; }
ul.products li.product:not(.sale) .price { margin-bottom: 2em !important; }
ul.products li.product .price { order:4; display: flex !important; justify-content: center; flex-direction: column; align-items: start; } 
ul.products li.product .price ins { text-decoration: none; }
ul.products li.product .price bdi { color: #000; font-size: 1.6em; font-style: normal; font-weight: 700; line-height: normal; } 
ul.products li.product .price del { opacity: 1 !important; color: var(--Gris) !important; }
ul.products li.product .price del bdi { font-size: 1.3em; color: var(--Gris);}
ul.products li.product a.added_to_cart { text-transform: uppercase; font-size: 0.8em; display: block; background: #000; width: fit-content; padding: 4px 47px; margin: 6px auto; color: #fff; border-radius: 3px; font-weight: 700; }
.iva-incluido { color: var(--Amarillo); font-weight: 600; font-size: 1.3em;}

.dgwt-wcas-search-wrapp { margin: 0 !important; }
.dgwt-wcas-search-wrapp .dgwt-wcas-sf-wrapp { padding-left: 0 !important; }

#home-slider .carousel-control-next { right: 110px;  }
#home-slider .carousel-control-prev { left: 110px;   }

#home-slider .carousel-control-next-icon { width: 60px; height: 60px; background-image: url(public/images/flecha-slider-home.svg) !important; } 
#home-slider .carousel-control-prev-icon {  width: 60px; height: 60px; background-image: url(public/images/flecha-slider-home.svg) !important; transform: rotateY(180deg);} 

.carrusel-destacados.columns-12 .caja-loop a.btn-ver-producto:before, .carrusel-destacados.columns-12 .caja-loop a.button:before { left: 24%; } 

.caja-loop { padding-top: 0px !important; }
.button {  background-color: var(--Verde) !important; color: #fff !important; text-transform: uppercase !important; font-weight: 700 !important; font-size: 0.8em !important; line-height: normal !important; }

.btn-ver-producto { transition:1s; position:relative; padding: 4px 4px 4px 15px; border: solid 1px var(--Gris); margin-top: 5px; width: 100%; font-size: 1em; font-weight: 700; }
.btn-ver-producto:before{ content:''; background-image: url(public/images/visibility.svg); position: absolute; width: 20px; height: 20px; background-position: center; background-repeat: no-repeat; background-size: contain; top: 6px; left: 15%; }
.btn-ver-producto:hover { background-color: #000; color: #fff; }
.btn-ver-producto:hover:before { filter: invert(100%) sepia(100%) saturate(0%) hue-rotate(288deg) brightness(102%) contrast(102%); }



.woocommerce nav.woocommerce-pagination { text-align: right !important; }
.woocommerce ul.products li.product a img { padding: 20px; margin-bottom:0px !important; order:1; }

/* PRODUCTO  */


.single-product div.product .woocommerce-product-gallery .flex-viewport { width: 75%; float: right; border: solid 1px lightgray; }
.single-product div.product .woocommerce-product-gallery .flex-control-thumbs { width: 20%; float: left; overflow-y: scroll !important; max-height: 480px; }
.single-product div.product .woocommerce-product-gallery .flex-control-thumbs li { padding: 5px 0px; width: 95% !important;  border: solid 1px lightgray; margin-bottom: 10px !important; }
.single-product div.product .woocommerce-product-gallery .flex-control-thumbs li img { width: 90%; float: none; margin: auto !important;  }
.single-product div.product .woocommerce-product-gallery .flex-control-thumbs::-webkit-scrollbar { width: 5px !important; background-color: #F5F5F5 !important; }
.single-product div.product .woocommerce-product-gallery .flex-control-thumbs::-webkit-scrollbar-thumb { border-radius: 0px !important; -webkit-box-shadow: inset 0 0 6px rgb(0 0 0 / 30%) !important; background-color: var(--Verde) !important; }
.single-product div.product .woocommerce-product-gallery .flex-control-thumbs::-webkit-scrollbar-track { -webkit-box-shadow: inset 0 0 6px rgb(0 0 0 / 30%) !important; border-radius: 0px !important; background-color: #F5F5F5 !important; }

.single-product .woocommerce-notices-wrapper { width: 100%;}
.single-product  .woocommerce-breadcrumb { display: none;}
.single-product div.product div.images { width: 100% !important; height: 100%; }
.single-product div.product .product_title { color: #000; font-size: 25px; font-style: normal; font-weight: 700; line-height: normal; }
.single-product.woocommerce div.product div.images .woocommerce-product-gallery__trigger { display: none; top: 80%; right: 1%; background-image: url(public/images/lupa-pdp.svg); background-size: 75%; width: 50px; height: 50px; background-repeat: no-repeat; border-radius: 0px; background-color: transparent; }
.single-product.woocommerce div.product div.images .woocommerce-product-gallery__trigger::after, .single-product.woocommerce div.product div.images .woocommerce-product-gallery__trigger::before { content: none;}

.single-product.woocommerce .woocommerce-tabs { margin-top: 10px; margin-bottom: 10px; background: #F8F8F8; border-radius: 20px; padding: 20px; }
.single-product.woocommerce .woocommerce-tabs .up-sells li.product  .caja-loop .button:before { left: 21% !important; }
.single-product.woocommerce .woocommerce-tabs .related li.product .caja-loop .button:before { left: 21% !important; }

.woocommerce-product-gallery--with-images .woocommerce-product-gallery__wrapper { border: solid 1px lightgray; }

.single-product.woocommerce div.product .summary.entry-summary { display: flex; flex-direction: column; background: #F8F8F8; padding: 20px; border-radius: 20px; }
.single-product.woocommerce div.product .summary.entry-summary .posted_in { display: none; }
.single-product.woocommerce div.product .summary.entry-summary .product_title { order: 1; margin-bottom: 0; }
.single-product.woocommerce div.product .summary.entry-summary .product_meta { order: 2; margin-bottom: 20px; color: #000; font-size: 1.250em; font-style: normal; font-weight: 400; line-height: normal; }
.single-product.woocommerce div.product .summary.entry-summary .product_meta a { color: var(--Verde);}
.single-product.woocommerce div.product .summary.entry-summary .woocommerce-product-details__short-description { order: 3;  }
.single-product.woocommerce div.product .summary.entry-summary .woocommerce-product-details__short-description p { font-size: 1.063em; font-weight: 400; color:#000; }
.single-product.woocommerce div.product .summary.entry-summary .woocommerce-product-details__short-description p a button { background-color: #000; color: #fff; padding: 3px 23px; border-radius: 5px; }
.single-product.woocommerce div.product .summary.entry-summary .stock-bloque-pdp { display: flex; align-items: center; width: fit-content; background-color: #00A753; color: #fff; border-radius: 5px; padding: 5px 10px;}
.single-product.woocommerce div.product.outofstock .stock-bloque-pdp { background-color: var(--Rojo) !important;}
.single-product.woocommerce div.product .summary.entry-summary .price { order: 7; color: #000; display: flex; flex-direction: column; justify-content: flex-end; }
.single-product.woocommerce div.product .summary.entry-summary .price bdi { font-size: 2em; font-weight: 700; color: #000; text-decoration: none;}
.single-product.woocommerce div.product .summary.entry-summary .price del { color: var(--Gris); opacity: 1; }
.single-product.woocommerce div.product .summary.entry-summary .price ins { text-decoration: none;}
.single-product.woocommerce div.product .summary.entry-summary .price del bdi { font-size: 1.2em; font-weight: 400; color: var(--Gris);} 
.single-product.woocommerce div.product.product-type-variable .price { display: none;}
.single-product.woocommerce div.product.product-type-variable .single_variation_wrap .price { display: block !important;}
.single-product.woocommerce div.product .summary.entry-summary .stock { order: 5;  color: #A6A6A6; font-size: 1em; font-style: normal; font-weight: 700; line-height: normal; }
.single-product.woocommerce div.product .summary.entry-summary form.cart { order: 7; display: flex; align-items: center; margin-top: 20px; flex-direction: row;}
.single-product.woocommerce div.product .summary.entry-summary form.cart .quantity .qty {width: 2.5em; margin-left: 30px; margin-right: 20px;}
.single-product.woocommerce div.product .summary.entry-summary form.cart button.single_add_to_cart_button { border-radius: 5px; background: var(--Verde) !important; font-size: 0.9em;  padding: 10px 35px;  padding-left: 60px; position: relative;  }
.single-product.woocommerce div.product .summary.entry-summary form.cart button.single_add_to_cart_button:hover { background-color: #000 !important; }
.single-product.woocommerce div.product .summary.entry-summary form.cart button.single_add_to_cart_button::after { content:''; background-image: url(public/images/carro-de-compras.svg); position: absolute; width: 30px; height: 25px; background-position: center; background-repeat: no-repeat; background-size: contain; top: 9px; left: 25px; }
.single-product.woocommerce div.product .summary.entry-summary .compartir_en { order: 8; margin-top: auto;}
.single-product.woocommerce .summary .caja-mas-menos .minus { left: 5px !important; }
.single-product.woocommerce .summary .caja-mas-menos .plus { right: 0px; }


.single-product.woocommerce div.product .woocommerce-tabs ul.tabs li { padding: 0; margin: 0;  background-color: transparent; border: none; }
.single-product.woocommerce div.product .woocommerce-tabs ul.tabs li:first-child {  }
.single-product.woocommerce div.product .woocommerce-tabs ul.tabs li a { font-size: 1em; font-style: normal; font-weight: 600 !important; line-height: normal; }
.single-product.woocommerce div.product .woocommerce-tabs ul.tabs li.active { color: var(--NegroGrafito) !important; background:none;}

.up-sells .relacionados li.product { width: 90% !important;}
.single-product.woocommerce div.product .summary.entry-summary form.cart button.wpcbn-btn.wpcbn-btn-single { border: solid 1px #000 !important; border-radius: 5px !important; background-color: transparent !important; color: #000 !important; margin-left: 20px;     padding-left: 60px !important; padding-right: 25px !important; }
.single-product.woocommerce div.product .summary.entry-summary form.cart button.wpcbn-btn.wpcbn-btn-single:hover{ background-color: #00A753 !important; color: #fff !important; border-color: #fff !important; }
.single-product.woocommerce div.product .summary.entry-summary form.cart button.wpcbn-btn.wpcbn-btn-single:hover::before { filter: invert(100%) sepia(100%) saturate(0%) hue-rotate(288deg) brightness(102%) contrast(102%); }
.single-product.woocommerce div.product .summary.entry-summary form.cart button.wpcbn-btn.wpcbn-btn-single:before { content: ''; background-image: url('public/images/flecha_compra.svg') !important; background-size: cover; width: 25px; height: 20px; position: absolute; left: 25px; top: 15px; background-repeat: no-repeat; background-position: center; }
.single-product.woocommerce div.product .summary.entry-summary form.cart button.wpcbn-btn.wpcbn-btn-single:after { content: none; }

.iva-pdp { order: 4; color: var(--Amarillo); margin-top: -8px;}

.single-product.woocommerce .fotos { position: relative;}
.single-product.woocommerce .fotos .onsale { top: 12px; position: absolute; right: 4%; width: fit-content; padding: 0px 10px; border-radius: 0; left: unset; background-color: var(--Amarillo); height: 30px !important; min-height: fit-content; display: flex; justify-content: center; align-items: center; border-radius: 5px; }
.single-product.woocommerce .related.products { position: relative; display: block;} 
.single-product.woocommerce .related.products:after { content: '';}
.single-product.woocommerce .related.products h2 {text-align: left; font-weight: 700; padding-bottom: 10px; margin-top: 20px; margin-bottom: 15px; }

.single-product.woocommerce .up-sells.products li.product { width: 100%; }

/* MANUALES  */
#tab-manual .row { margin-bottom: 20px; padding: 20px; text-align: center; }
#tab-manual .row .pdf { }
#tab-manual .row .ver { }
#tab-manual .row a { font-weight: 400; color: #000; text-decoration: none; font-size: 1.1em; } 

.woocommerce-tabs.wc-tabs-wrapper { position: relative; }
.woocommerce-tabs.wc-tabs-wrapper .wc-tabs { padding: 0 !important; align-items: center; justify-content: start !important; background-color: transparent; margin-bottom: 0px !important; gap: 10px;}
.woocommerce-tabs.wc-tabs-wrapper .wc-tabs:before, .woocommerce-tabs.wc-tabs-wrapper .wc-tabs:after { content: none !important; }
.woocommerce-tabs.wc-tabs-wrapper .wc-tabs li { }
.woocommerce-tabs.wc-tabs-wrapper .wc-tabs li:before, .woocommerce-tabs.wc-tabs-wrapper .wc-tabs li:after { content: none !important; }
.woocommerce-tabs.wc-tabs-wrapper .wc-tabs li a { border-radius: 10px; color: #fff !important; padding: 15px 35px !important; background: #8B8B8B; margin-bottom: 7px; }
.woocommerce-tabs.wc-tabs-wrapper .wc-tabs li.active { }
.woocommerce-tabs.wc-tabs-wrapper .wc-tabs li.active a {  background: var(--NegroGrafito);  box-shadow: 0px 4px 4px rgba(0, 0, 0, 0.25); margin-bottom: 7px;}
/* .woocommerce-tabs.wc-tabs-wrapper:after { content: '';      position: absolute; background: #EDEDED; top: 20px; bottom: 0; left: 0; right: 0; z-index: -1; } */
.woocommerce table.shop_attributes { border:none !important; }
.woocommerce table.shop_attributes tr:nth-child(even) td, .woocommerce table.shop_attributes tr:nth-child(even) th { background: #fff !important; }
.woocommerce table.shop_attributes th, .woocommerce table.shop_attributes td { border-bottom: 1px solid #aaaaaa !important; }
.woocommerce table.shop_attributes th { width: 25%; }
/* BOTONES DE + Y -  */
.caja-mas-menos { float: left; margin-right: 20px; position: relative;}
.caja-mas-menos .minus { position: absolute; top: 17px; left: 8px; border: none; color:  #fff; font-size: 1em; background: #000; }
.caja-mas-menos .plus { position: absolute; top: 17px; right: 8px; border: none; color: #fff; font-size: 1em; background-color: #000; }
.caja-mas-menos div.quantity{ float: none; margin: 0; display: inline-block; }
.caja-mas-menos .button, .caja-mas-menos button { border-radius: 50%; vertical-align: middle; float: none; height: 25px; width: 26px; display: flex; justify-content: center; align-items: center; }
.caja-mas-menos div.quantity input.qty::-webkit-outer-spin-button, .caja-mas-menos div.quantity input.qty::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.caja-mas-menos div.quantity input.qty[type=number] { -moz-appearance: textfield;     border-radius: 5px; width: 45px; }


/* MENSAJES DE CHECKOUT  */
.woocommerce-message { border-top-color: var(--Verde) !important; }
.woocommerce-message::before {  color: var(--Verde) !important; }
.woocommerce-info { border-top-color: var(--Verde) !important;  }
.woocommerce-info::before  { color: var(--Verde) !important; }

/* CHECKOUT  */
.woocommerce-checkout input, .woocommerce-checkout select, .woocommerce-checkout textarea, .woocommerce-checkout .select2-selection__rendered { background-color: #EFEFEF; padding: 10px; border: none; color: #454040; }
.woocommerce-checkout span.select2-selection.select2-selection--single { height: 50px; border: none; }
.woocommerce-checkout h3 {font-size: 1.2em; text-transform: uppercase; font-weight: 700; }
.woocommerce-checkout div#customer_details { margin-bottom: 30px; }
.woocommerce-checkout table.shop_table thead th.product-name, .woocommerce-checkout table.shop_table thead th.product-total { background: var(--Verde); color: #fff; }
.woocommerce-checkout table.shop_table td.product-total { min-width: 220px; }
.form-row-primero {     width: 47% !important; overflow: visible; float: left;}
.form-row-ultimo {     width: 47% !important; overflow: visible; float: right;}
.form-row-primero.form-row-wide, .form-row-ultimo.form-row-wide { clear: none !important; }
.woocommerce-checkout .facturas { margin-top: 20px;}

/* CARRO  */
.ventasCruzadas li { width: 100% !important; }
.woocommerce-cart table.cart img { width: 100px !important; border: solid 1px var(--Gris2); padding: 5px; }
.woocommerce-cart table.cart td.product-price, .woocommerce-cart table.cart td.product-subtotal {     font-size: 1.250em; font-weight: 700; line-height: normal; }
.woocommerce-cart table.cart td.product-name a{ color: #000; font-size: 1em; font-style: normal; font-weight: 400; line-height: normal; text-decoration: none; }
.woocommerce-cart h2 { text-transform: uppercase; font-weight: 700; font-size: 1.2em !important; }
.woocommerce table.cart td.actions .input-text { min-width: 350px;}
.woocommerce-cart a.checkout-button { width: fit-content; float: right; }

.woocommerce-cart .wc-block-cart__submit-container { text-align: right; }
.woocommerce-cart .wc-block-cart__submit-container a {     background: var(--Verde); width: fit-content; padding: 7px 15px; color: #fff; text-decoration: none; border-radius: 10px; }
.woocommerce-cart .wc-block-cart-items a.wc-block-components-product-name { color: #000; text-decoration: none; }

.woocommerce-cart .coupon button[type=submit] {     text-transform: capitalize !important; background-color: var(--Verde) !important; height: 35px; }
.woocommerce-cart .coupon input[name=coupon_code] { background: #F3F0F0; color: #787878; border: none !important; }
.woocommerce-cart button[name=update_cart] { background: #fff !important; color: var(--Verde) !important; border: solid 1px var(--Verde) !important; text-transform: capitalize !important; }

/* OWL CARROSUEL GENERAL  */
.owl-carousel.products .owl-nav { position: absolute; top: 30%; width: 100%; }
.owl-carousel.products .owl-nav button { font-size: 6em; position: absolute; font-weight: 200;}
.owl-carousel.products .owl-nav button.owl-next {  right: -30px;}
.owl-carousel.products .owl-nav button.owl-prev { left: -30px;}


/* THANK YOU PAGE */
.woocommerce-order-received .woocommerce-order { text-align: center; width: 70%; margin: auto; }
.woocommerce-order-received .woocommerce-order .foto { max-width: 100px; }
.woocommerce-order-received .woocommerce-order .woocommerce-order-overview.woocommerce-thankyou-order-details { margin: 0 auto; padding: 30px 0; text-align: center; display: flex; justify-content: center; border-bottom: solid 1px lightgray; }
.woocommerce-order-received .woocommerce-order .wc-bacs-bank-details-heading, 
.woocommerce-order-received .woocommerce-order .woocommerce-order-details__title
 { color: var(--Verde); padding-bottom: 10px; border-bottom: solid 1px var(--Gris2); margin-bottom: 20px; margin-top: 20px; }
 .woocommerce-order-received .woocommerce-order .woocommerce-customer-details { display: none; }

/* FILTRADOR  */
.woocommerce-ordering select { background-color: #fff; padding: 10px; border: solid 1px; color: #454040; }

/* PAGINACION PLP  */
.woocommerce-pagination span.page-numbers.current { background: var(--Verde) !important; color: #fff !important;  }
.woocommerce-pagination ul.page-numbers { border: none !important; }
.woocommerce-pagination ul.page-numbers li { border: none !important;  margin-right: 20px !important; background: transparent; color: #000 !important; }
.woocommerce-pagination a.page-numbers, .woocommerce-pagination span.page-numbers { padding: 10px 15px !important; font-size: 1.2em !important; color: #000 !important;}
.woocommerce-pagination a.page-numbers:hover { background-color: var(--Verde) !important; color: #fff !important; }

/* MENU DE TEMPLATE DE 2 COLUMNAS */
#menu-menu-paginas { display: flex; list-style: none; margin: 0; padding: 0; flex-direction: column; justify-content: space-between; margin-bottom: 50px;}
#menu-menu-paginas li { margin-bottom: 10px; }
#menu-menu-paginas li a { border:solid 1px #010101; display: block; color: #010101; text-decoration: none; font-size: 1em; font-style: normal; font-weight: 500; line-height: normal; background-color: #fff; padding: 10px 20px; border-radius: 5px; }
#menu-menu-paginas li.current-menu-item a, #menu-menu-paginas li a:hover { border:solid 1px var(--Verde) !important; color: #fff !important;background-color: var(--Verde) !important;  }
#menu-menu-paginas li.current-menu-item a img, #menu-menu-paginas li a:hover img { filter: invert(98%) sepia(99%) saturate(0%) hue-rotate(326deg) brightness(107%) contrast(101%); } 
#menu-menu-paginas li a img { margin-right: 10px; } 
/* MI CUENTA  */
.woocommerce-account h3 { text-transform: uppercase; font-weight: 700; font-size: 1.2em; }
.woocommerce-account .woocommerce-MyAccount-content a { font-weight: 500; color: var(--Verde);}
.woocommerce-account .woocommerce-MyAccount-navigation ul { list-style: none;  margin-left: 0; padding: 0;}
.woocommerce-account .woocommerce-MyAccount-navigation ul li { position: relative; margin-left: 30px; margin-bottom: 15px; border-bottom: solid 1px #EFEFEF; padding-bottom: 5px; }
.woocommerce-account .woocommerce-MyAccount-navigation ul li:after { opacity: 0.4; content:''; position: absolute; width: 25px; height: 25px; left: -35px; background-position: center; background-size: contain; background-repeat: no-repeat;}
.woocommerce-account .woocommerce-MyAccount-navigation ul li.is-active:after { opacity: 1 !important;}
.woocommerce-account .woocommerce-MyAccount-navigation ul li:hover:after { opacity: 1 !important; }
.woocommerce-account .woocommerce-MyAccount-navigation li a { text-decoration: none; color: #DEDEDE; font-size: 1.250em; font-style: normal; font-weight: 400; line-height: normal; }
.woocommerce-account .woocommerce-MyAccount-navigation li.is-active a, .woocommerce-account .woocommerce-MyAccount-navigation li a:hover { color: #000; font-weight: 500; } 
.woocommerce-account form input {     border: none; background: #EFEFEF; padding: 6px; border-radius: 8px; }

.woocommerce-account .woocommerce-MyAccount-navigation-link--dashboard:after { background-image: url(public/images/info-general.svg); }
.woocommerce-account .woocommerce-MyAccount-navigation-link--orders:after { background-image: url(public/images/mispedidos.svg); }
.woocommerce-account .woocommerce-MyAccount-navigation-link--edit-address:after { background-image: url(public/images/direecciones.svg); }
.woocommerce-account .woocommerce-MyAccount-navigation-link--edit-account:after { background-image: url(public/images/detalles-de-cuenta.svg); }
.woocommerce-account .woocommerce-MyAccount-navigation-link--customer-logout:after { background-image: url(public/images/cerrar-sesion.svg); }
.woocommerce-account .woocommerce-MyAccount-navigation-link--downloads { display: none; }

.zona-menus { display: flex; flex-direction: column; justify-content: end; }

body.post-type-archive a.add_to_cart_button:before, body.tax-product_cat a.add_to_cart_button:before { left: 12% !important;}
body.post-type-archive .btn-ver-producto:before , body.tax-product_cat .btn-ver-producto:before  { left: 12% !important;}

/* FOOTER  */
.f-size { font-size: 0.8em !important; }

footer {position: relative; color: #000;}
footer .logo_footer{max-width: 180px;}
footer .wpcf7-spinner { position: absolute; }
footer .menu-footer2 { display: flex;     flex-direction: column; align-items: self-start; }
footer .menu-footer2 li a { color: #000; display:block; text-decoration: none; font-size: 0.8em; font-weight: 600;}
footer .menu-footer li a, footer .sucursales p { margin-right: 15px; color: var(--fff); margin-bottom: 0.7em; font-size: 0.8em; display: inline-block; text-decoration: none; font-weight: 400; }
footer .menu-footer li a:hover { color: var(--Azul); }
footer .siguenos_en {     margin-right: 10px; font-size: 1.2em; font-style: normal; line-height: normal; color: #000; text-decoration: none; }
footer .rrss { justify-content: start; display: flex; margin: 0px;}
footer .rrss li a { margin-bottom: 0px;}
footer .menu-footer.rrss a { margin-right: 5px !important; }
footer .caja-medios { display: flex; align-items: center; }
footer .caja-medios a { margin-right: 10px; font-size: 1.2em; font-style: normal; line-height: normal; color: #000; text-decoration: none;}
footer .caja-medios .webpay {}
footer .bg-gris-footer {background-color: #f8f8f8;}
footer .bg-blanco {background-color: #fff;}
footer .copyright {color: var(--Azul);}
footer .sucursales .texto {display: flex; flex-direction: column;}
footer .sucursales .direccion, footer .sucursales .horario {display: flex; justify-content: start; align-items: center;}
footer .medios_pago img {max-width: 90px;}
footer .suscribirse { text-align: left; }
footer .suscribirse h3 { font-size: 1.2em; color: #000; }
footer .caja-siguenos-en { display: flex; align-items: center; justify-content: start;}
footer .caja-siguenos-en img {max-width: 45px;}

.subir-bloque { margin-top: -65px; }

.wp-block-woocommerce-cart .wp-block-woocommerce-cart-cross-sells-block .cross-sells-product .wc-block-components-product-button__button {
    background-color: var(--Verde); color: #fff; padding: 8px 20px; width: 100%; border-radius: 5px;
}
.wp-block-woocommerce-cart .wp-block-woocommerce-cart-cross-sells-block .cross-sells-product div .wc-block-components-product-name {
    font-weight: 900 !important; text-decoration: none;     font-size: 1em !important;
}
.wp-block-woocommerce-cart .wp-block-woocommerce-cart-cross-sells-block .cross-sells-product div .wc-block-components-product-price {
    text-align: left;
}
.wc-block-components-formatted-money-amount { font-size: 1.3em; color: var(--Verde); font-weight: 700; }
.wc-block-components-product-image img { width: 75% !important; }

.cross-sells-product { margin: auto; border: solid 1px #ffff; border-radius: 5px; padding: 9px; padding-right: 1% !important;}
.cross-sells-product h3 { min-height: 48px; text-align: left; }
.cross-sells-product .wc-block-components-product-image a { min-height: 200px; }

#billing-city-select { padding-top: 18px; width: 100%; border: solid 1px; border-radius: 5px; min-height: 50px; background: transparent; }
.wc-block-components-checkout-place-order-button {     background: var(--Verde); border-radius: 10px; color: #fff; font-size: 1.3em; padding: 10px !important; min-height: 1em !important; }
.wc-block-components-checkout-place-order-button:hover { background-color: var(--Amarillo);}
.categorias-home svg { width: 30px !important;  margin-right: 10px;}
.caja-categorias-home .categorias-home span.elementor-button-icon{ margin-left: 10px; }
.caja-categorias-home .categorias-home span.elementor-button-text{ min-width: 90px; text-align: left; }
.caja-categorias-home .categorias-home .elementor-button-wrapper a { min-height: 60px !important; display: flex; justify-content: center; align-items: center; min-width: 240px; }
.caja-categorias-home .categorias-home .elementor-button-wrapper a > span { align-items: center; }

    .escaleras-icono a span.elementor-button-text { margin-top: 7px; }
.wc-block-components-price-slider--is-input-inline .wc-block-components-price-slider__controls .wc-block-components-price-slider__amount { max-width: 100px !important; }

/* Grid en 2 columnas */
.grid-2 {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
}

/* Labels ordenados */
.wpcf7 form label {
    font-weight: 600;
    display: block;
    margin-bottom: 5px;
}

/* Inputs iguales al diseño */
.wpcf7 form input[type="text"],
.wpcf7 form input[type="email"],
.wpcf7 form input[type="tel"],
.wpcf7 form textarea {
    width: 100%;
    border: 1px solid #ddd;
    border-radius: 6px;
    padding: 12px;
    font-size: 14px;
    background: #f8f8f8;
}

/* Textarea misma estética */
.wpcf7 form textarea {
    height: 120px;
    resize: none;
}

/* Botón igual que la imagen */
.btn-centro {
    text-align: center;
    margin-top: 20px;
}

.wpcf7 form input[type="submit"] {
    background: #27ae60;
    color: white;
    border: none;
    padding: 12px 40px;
    font-size: 16px;
    border-radius: 6px;
    cursor: pointer;
}

.wpcf7 form input[type="submit"]:hover {
    background: #219150;
}

/* Responsive: columnas a 1 columna en móvil */
@media (max-width: 768px) {
    .grid-2 {
        grid-template-columns: 1fr;
    }
}


/* Preguntas Frecuentes */
.page-id-417 .menu-interes a[href*="page_id=417"] .elementor-icon-list-text,
.page-id-417 .menu-interes a[href*="page_id=417"] .elementor-icon-list-icon svg,
.page-id-417 .menu-interes a[href*="page_id=417"] .elementor-icon-list-icon svg * {
    color: #00AEEF !important;
    fill: #00AEEF !important;
    stroke: #00AEEF !important;
    font-weight: 600;
}

/* Condiciones de Despacho */
.page-id-447 .menu-interes a[href*="page_id=447"] .elementor-icon-list-text,
.page-id-447 .menu-interes a[href*="page_id=447"] .elementor-icon-list-icon svg,
.page-id-447 .menu-interes a[href*="page_id=447"] .elementor-icon-list-icon svg * {
    color: #00AEEF !important;
    fill: #00AEEF !important;
    stroke: #00AEEF !important;
    font-weight: 600;
}
/* Cambios y Devoluciones */
.page-id-454 .menu-interes a[href*="page_id=454"] .elementor-icon-list-text,
.page-id-454 .menu-interes a[href*="page_id=454"] .elementor-icon-list-icon svg,
.page-id-454 .menu-interes a[href*="page_id=454"] .elementor-icon-list-icon svg * {
    color: #00AEEF !important;
    fill: #00AEEF !important;
    stroke: #00AEEF !important;
    font-weight: 600;
}
/* Términos y Condiciones */
.page-id-581 .menu-interes a[href*="page_id=581"] .elementor-icon-list-text,
.page-id-581 .menu-interes a[href*="page_id=581"] .elementor-icon-list-icon svg,
.page-id-581 .menu-interes a[href*="page_id=581"] .elementor-icon-list-icon svg * {
    color: #00AEEF !important;
    fill: #00AEEF !important;
    stroke: #00AEEF !important;
    font-weight: 600;
}

/* -----------------------------
   FORMULARIO LOGIN/REGISTRO REDOFFICE
--------------------------------*/

/* CONTENEDOR GENERAL */
.redoffice-login-container {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 30px;
  margin: 50px auto;
  max-width: 950px;
}

/* CADA COLUMNA (LOGIN / REGISTRO) */
.redoffice-column {
  flex: 1 1 400px;
  background: #fff;
  border-radius: 10px;
  padding: 30px 35px;
  box-shadow: 0 3px 8px rgba(0, 0, 0, 0.06);
}

/* TÍTULOS DE CADA COLUMNA */
.redoffice-title {
  font-size: 18px;
  color: #111;
  font-weight: 600;
  margin-bottom: 20px;
  text-align: left;
}

/* CAMPOS DE FORMULARIO */
.woocommerce-form-row {
  margin-bottom: 15px;
}

.woocommerce-form-row label {
  display: block;
  font-size: 14px;
  color: #333;
  font-weight: 500;
  margin-bottom: 6px;
}

.woocommerce-form-row input.input-text {
  width: 100%;
  padding: 10px;
  border-radius: 8px;
  border: 1px solid #ccc;
  background-color: #fff;
  transition: border-color 0.2s;
}

.woocommerce-form-row input.input-text:focus {
  border-color: #28a745;
  outline: none;
}

/* CHECKBOX Y ACCIONES */
.redoffice-actions {
  margin-bottom: 10px;
}

/* BOTÓN PRINCIPAL (verde) */
.redoffice-btn {
  background-color: #28a745;
  color: #fff;
  font-weight: bold;
  padding: 10px 25px;
  border: none;
  border-radius: 6px;
  cursor: pointer;
  transition: background-color 0.2s ease;
  width: 100%;
  text-transform: uppercase;
}

.redoffice-btn:hover {
  background-color: #218838;
}

/* ENLACE RECUPERAR CONTRASEÑA */
.lost_password {
  margin-top: 10px;
  text-align: left;
}

.lost_password a {
  color: var(--Celeste);
  text-decoration: none;
  font-size: 13px;
}

.lost_password a:hover {
  text-decoration: underline;
}

/* BOTONES GOOGLE (solo estos en blanco) */
.google-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  margin: 15px auto 0;
  width: 100%;
  max-width: 250px;
  height: 40px;
  background-color: #ffffff !important;
  border: 1px solid #ccc !important;
  border-radius: 6px;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05);
  cursor: pointer;
  font-size: 16px;
  font-weight: 600;
  color: #3c4043 !important;
  transition: all 0.2s ease;
  text-transform: none!important;
  text-decoration: none;
}

.google-btn:hover {
  background-color: #f7f8f8 !important;
  border-color: #d2e3fc !important;
  box-shadow: 0 0 3px rgba(66, 133, 244, 0.4);
}

.google-btn img,
.google-icon {
  width: 18px;
  height: 18px;
}

/* TÍTULO PRINCIPAL CELESTE */
.redoffice-main-title {
  text-align: center;
  color: #00AEEF;
  font-size: 28px;
  font-weight: 700;
  margin-bottom: 25px;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 8px;
}

.redoffice-main-title i {
  color: #00AEEF;
  font-size: 28px;
}

div#modalLoginWP .modal-content {
    border-radius: 15px;
    padding: 10%;
    background-color: #f2F2F2;
}
div#modalLoginWP .modal-header {
    position: relative;
    border: none;
}
div#modalLoginWP .modal-header .btn-close {
    position: absolute;
    top: -10px;
    right: -10px;
    background-color: red!important;
    border-radius: 50%;
    padding: 7px;
    background: transparent url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23fff'%3e%3cpath d='M.293.293a1 1 0 011.414 0L8 6.586 14.293.293a1 1 0 111.414 1.414L9.414 8l6.293 6.293a1 1 0 01-1.414 1.414L8 9.414l-6.293 6.293a1 1 0 01-1.414-1.414L6.586 8 .293 1.707a1 1 0 010-1.414z'/%3e%3c/svg%3e") center / 1em auto no-repeat;
    opacity: 1;
}
div#modalLoginWP button.button.redoffice-btn {
    border-radius: 30px;
}
div#modalLoginWP .woocommerce-form-row input.input-text{
    border-radius: 30px;
}
div#modalLoginWP .modal-header {
    padding-bottom: 0px;
}
div#modalLoginWP .registrate a {
    color: #212529;
}
/* RESPONSIVE */
@media (max-width: 768px) {
  .redoffice-login-container {
    flex-direction: column;
  }

  .redoffice-column {
    width: 100%;
  }
}





.woocommerce-MyAccount-navigation ul {
    display: flex !important;
    flex-direction: column !important;
}

.woocommerce-MyAccount-navigation-link--customer-logout {
    order: 100 !important;
}

/* Seleccionar sucursal */
.sucursal-overlay {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.4);
    z-index: 9998;
}
.sucursal-popup {
    display: none;
    position: fixed;
    z-index: 9999;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    max-width: 320px;
    width: 90%;
    background: #fff;
    border-radius: 8px;
    box-shadow: 0 10px 30px rgba(0,0,0,0.2);
    padding: 16px 20px 12px;
}
.sucursal-popup-inner {
    position: relative;
}
.sucursal-popup-close {
    position: absolute;
    top: 4px;
    right: 4px;
    border: none;
    background: transparent;
    font-size: 20px;
    line-height: 1;
    cursor: pointer;
}
.sucursal-popup-title {
    margin: 0 0 10px;
    font-size: 16px;
    font-weight: 600;
}
.sucursal-lista {
    list-style: none;
    margin: 0;
    padding: 0;
    max-height: 240px;
    overflow-y: auto;
}
.sucursal-option {
    width: 100%;
    text-align: left;
    border: none;
    background: #f5f5f5;
    padding: 8px 10px;
    margin-bottom: 6px;
    border-radius: 4px;
    cursor: pointer;
    font-size: 14px;
}
.sucursal-option:hover {
    background: #e2e2e2;
}
.sucursal-option.is-active {
    background: var(--Celeste);
    color: #fff;
}




/*  PlP pagina */

.shop-container {
    display: grid;
    grid-template-columns: 260px 1fr; 
    gap: 30px;
    max-width: 1300px;
    margin: 30px auto;
    padding: 0 15px;
}

.shop-sidebar { background: transparent; }
.shop-content { width: 100%; }

html, body { overflow-x: hidden !important; }

/*  LISTA DE PRODUCTOS  */
body.woocommerce-shop .ro-products-list,
body.tax-product_cat .ro-products-list {
    display: grid !important;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); 
    gap: 20px;
    padding: 0;
    margin: 0;
    list-style: none;
}


/*  TARJETA DE PRODUCTO  */
.ro-product-card {
    background: #fff;
    border-radius: 12px;
    border: 1px solid #e6e6e6;
    padding: 12px 12px 0 12px;
    display: flex;
    flex-direction: column;
    position: relative;
    box-shadow: 0 4px 14px rgba(0,0,0,0.05);
    transition: .2s;
    overflow: hidden;
}

.ro-product-card:hover {
    box-shadow: 0 8px 22px rgba(0,0,0,0.10);
    transform: translateY(-3px);
}

.ro-product-image img {
    width: 100%;
    height: 150px; 
    object-fit: contain;
    margin-bottom: 8px;
}
.ro-badge {
    position: absolute; top: 8px; left: 8px;
    background: #FFE352; padding: 2px 8px;
    border-radius: 50px; font-size: 10px; font-weight: 700;
    z-index: 5;
}
.ro-product-brand { font-weight: 800; margin-bottom: 2px; font-size: 11px; color: #777; }
.ro-product-title { 
    font-size: 13px; 
    margin-bottom: 4px; 
    color: #222; 
    text-decoration: none;
    line-height: 1.2;
    height: 32px; 
    overflow: hidden;
}
.ro-sku { color: #999; font-size: 10px; margin-bottom: 6px; }
.ro-product-price { margin-bottom: 8px; }
.ro-new-price { font-size: 15px; font-weight: 800; color: #222; }
.ro-old-price { color:#F44336; text-decoration: line-through; margin-right: 5px; font-size: 12px; }

/*   2. CAJA DE BOTONES  */
.ro-bottom-box {
    background: #F5F5F5;
    padding: 6px;
    border-radius: 0 0 12px 12px;
    margin-top: auto;
    display: flex; 
    align-items: center;
    justify-content: space-between; 
    gap: 5px; 
}

/* Wrapper de Cantidad  */
.ro-bottom-box .redoffice-qty-wrapper {
    display: flex;
    align-items: center;
    background: #fff;
    border: 1px solid #ddd;
    border-radius: 6px;
    overflow: hidden;
    height: 28px !important; 
    flex-shrink: 0;
    width: auto !important;
    padding: 0 !important; 
    gap: 0 !important; 
}

/* Botones +/-  */
.ro-bottom-box .redoffice-qty-wrapper .qty-btn {
    width: 22px !important; 
    height: 100% !important;
    background: transparent;
    border: none;
    font-size: 14px !important;
    font-weight: 700;
    color: #555;
    cursor: pointer;
    padding: 0 !important;
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
}
.ro-bottom-box .redoffice-qty-wrapper .qty-btn:hover { background: #f0f0f0; }

/*  Input número */
.ro-bottom-box .redoffice-qty-wrapper input.qty {
    width: 24px !important;
    height: 100% !important;
    text-align: center;
    border: none;
    background: transparent;
    font-size: 13px !important;
    font-weight: 700;
    padding: 0 !important;
    margin: 0;
    -moz-appearance: textfield;
}
.ro-bottom-box .redoffice-qty-wrapper input.qty::-webkit-outer-spin-button,
.ro-bottom-box .redoffice-qty-wrapper input.qty::-webkit-inner-spin-button {
    -webkit-appearance: none; margin: 0;
}

/*  Botón AGREGAR   */
.ro-bottom-box .ro-add-btn {
    background: #2EB64B !important;
    color: #fff !important;
    border: none;
    border-radius: 6px !important;
    height: 28px !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    padding: 0 8px !important;
    display: flex !important;
    align-items: center;
    justify-content: center;
    gap: 4px;
    flex-grow: 1; 
    white-space: nowrap;
    cursor: pointer;
    max-width: 100%;
}
.ro-bottom-box .ro-btn-icon { width: 12px; height: 12px; fill: white; }


/*   3. RESPONSIVE  */
@media (max-width: 991px) {
    .shop-container { grid-template-columns: 1fr !important; }
}

@media (max-width: 480px) {
    .ro-products-list {
        grid-template-columns: repeat(2, 1fr); 
        gap: 10px;
    }
    /* Ajuste para móviles muy pequeños */
    .ro-bottom-box .redoffice-qty-wrapper .qty-btn { width: 20px !important; }
    .ro-bottom-box .redoffice-qty-wrapper input.qty { width: 20px !important; font-size: 12px !important; }
    .ro-bottom-box .ro-add-btn { 
        font-size: 10px !important; 
        padding: 0 4px !important; 
    }
}

/* filtro 4 */
.ro-filter-box {
    background: #fff;
    padding: 20px;
    border-radius: 8px;
    border: 1px solid #eee;
}

.ro-group-title {
    font-size: 16px;
    font-weight: 700;
    margin-bottom: 15px;
    color: #333;
}

/* Buscador interno */
.ro-search-filter {
    width: 100%;
    padding: 8px 10px;
    border: 1px solid #ddd;
    border-radius: 4px;
    margin-bottom: 10px;
    font-size: 13px;
}

/* Caja con Scroll (Scrollbar personalizado) */
.ro-filter-scrollbox {
    max-height: 220px; /* Altura máxima antes del scroll */
    overflow-y: auto;
    padding-right: 5px;
    margin-bottom: 10px;
}

/* Diseño del Scrollbar fino y gris */
.ro-filter-scrollbox::-webkit-scrollbar { width: 6px; }
.ro-filter-scrollbox::-webkit-scrollbar-track { background: #f1f1f1; }
.ro-filter-scrollbox::-webkit-scrollbar-thumb { background: #ccc; border-radius: 10px; }
.ro-filter-scrollbox::-webkit-scrollbar-thumb:hover { background: #bbb; }

/* Items Checkbox */
.ro-checkbox-item {
    display: flex;
    align-items: center;
    cursor: pointer;
    font-size: 14px;
    color: #555;
    margin-bottom: 8px;
    user-select: none;
    transition: 0.2s;
}

.ro-checkbox-item:hover { color: #000; }

/* Ocultar checkbox nativo  */
.ro-checkbox-item input {
    position: absolute;
    opacity: 0;
    cursor: pointer;
    height: 0;
    width: 0;
}

/* Custom Checkbox (Cuadrito) */
.checkmark {
    height: 18px;
    width: 18px;
    background-color: #fff;
    border: 2px solid #ccc; 
    border-radius: 3px;
    margin-right: 10px;
    position: relative;
    flex-shrink: 0;
}

/* Cuando está checked */
.ro-checkbox-item input:checked ~ .checkmark {
    background-color: #00AEEF; 
    border-color: #00AEEF;
}

/* El ticket (checkmark icon) */
.checkmark:after {
    content: "";
    position: absolute;
    display: none;
}
.ro-checkbox-item input:checked ~ .checkmark:after {
    display: block;
}
.ro-checkbox-item .checkmark:after {
    left: 5px;
    top: 1px;
    width: 4px;
    height: 9px;
    border: solid white;
    border-width: 0 2px 2px 0;
    transform: rotate(45deg);
}

/* Contador (cantidad) */
.ro-checkbox-item .count {
    font-size: 11px;
    color: #999;
    margin-left: 5px;
}

/* Enlace ver más */
.ro-show-more {
    font-size: 13px;
    color: #00AEEF;
    font-weight: 600;
    text-decoration: none;
    display: inline-block;
    margin-top: 5px;
}

/*   5. ESTILOS DE PÁGINA SINGLE PRODUCT*/

.custom-single-product-layout .product-main-content-wrapper {
    display: flex;
    gap: 40px; 
    margin-bottom: 30px; 
}
.custom-single-product-layout .product-gallery-column {
    flex: 0 0 50%;
    max-width: 50%;
    position: relative;
}
.custom-single-product-layout .product-summary-column {
    flex: 1;
    display: flex;
    flex-direction: column;
}

/* Marca, SKU, Titulo Single */
.product-brand-sku { font-size: 0.9em; color: #555; margin-bottom: 5px; font-weight: bold; }
.product-brand-sku .sku-number { margin-left: 10px; font-weight: normal; color: #888; }
.custom-single-product-layout .product-summary-column .product_title {
    font-size: 2em; 
    font-weight: bold;
    margin-top: 5px;
    margin-bottom: 10px;
    line-height: 1.2;
}

/* Botón Compartir */
.share-button {
    position: absolute; top: 0; right: 0;
    border: 1px solid #ccc; border-radius: 4px;
    padding: 5px 10px; font-size: 0.9em; cursor: pointer;
    display: flex; align-items: center; gap: 5px;
    color: #555; background-color: white; 
}

.product-short-description { font-size: 0.95em; color: #444; line-height: 1.6; margin-bottom: 15px; }

.ultimas-unidades-badge {
    background-color: #5bc0de !important; color: white !important;
    padding: 5px 10px !important; border-radius: 4px !important; 
    font-size: 14px !important; font-weight: bold !important;
    display: inline-block !important; margin-bottom: 15px !important;
    text-transform: uppercase !important; line-height: 1.2 !important; border: none !important;
}
.product-gallery-column .ultimas-unidades-badge.top-left {
    position: absolute; top: 10px; left: 10px; z-index: 10;
}

/* Garantías y Precio */
.product-guarantees-icons {
    display: flex; justify-content: space-between;
    padding: 20px 0; border-top: 1px solid #eee; border-bottom: 1px solid #eee; 
    margin: 20px 0; width: 100%;
}
.guarantee-item { text-align: center; flex: 1; padding: 0 5px; font-size: 0.85em; }
.guarantee-item .title { display: block; font-weight: bold; color: #333; margin-top: 5px; }
.guarantee-item .subtitle { display: block; color: #666; font-size: 0.9em; }
.product-guarantees-icons .guarantee-icon { display: block; margin: 0 auto; max-width: 30px; height: auto; }

.product-price-section { margin: 15px 0; font-size: 2.2em; font-weight: bold; color: #333; }

/* Tabs */
.woocommerce-tabs ul.wc-tabs { display: flex; list-style: none; padding: 0; margin: 0; border-bottom: 1px solid #eee; }
.woocommerce-tabs ul.wc-tabs li {
    margin-right: 5px; padding: 10px 15px; cursor: pointer;
    font-weight: bold; color: #888; background-color: #f5f5f5;
    border: 1px solid #eee; border-bottom: none; border-radius: 4px 4px 0 0;
}
.woocommerce-tabs ul.wc-tabs li.active { color: #61b34c; background-color: white; border-bottom: 1px solid white; }
.woocommerce-tabs .woocommerce-Tabs-panel { padding: 20px;  }


/* Fin PlP pagina */


/* --- PDP --- */
/* Info Principal */
.ro-info-col { flex: 1 1 50%; }
.ro-header-flex { display: flex; justify-content: space-between; align-items: center; margin-bottom: 10px; }
.ro-brand { color: #00AEEF; font-weight: 700; text-transform: uppercase; }
.ro-share-btn { background: #fff; border: 1px solid #ddd; border-radius: 20px; padding: 5px 15px; font-size: 12px; cursor: pointer; }
.ro-product-title { font-size: 24px; font-weight: 700; margin: 5px 0; line-height: 1.2; }
.ro-sku { color: #999; font-size: 13px; margin-bottom: 15px; }
.ro-short-desc { color: #555; margin-bottom: 15px; }
.ro-badge-inline {width: fit-content; order:4; background-color: #00AEEF; color: #fff; font-weight: 700; padding: 4px 12px; font-size: 12px; border-radius: 4px; display: inline-block; margin-bottom: 20px; }
.ro-guarantees { order:5; display: flex; justify-content: space-between; }
.ro-g-item { text-align: center; flex: 1;     background: #fff; padding: 15px; border-radius: 10px; margin-right: 10px; }
.ro-g-item img { height: 30px; display: block; margin: 0 auto 5px; }
.ro-g-item strong { display: block; font-size: 12px; }
.ro-g-item span { font-size: 11px; color: #777; }


/* TABS */
.ro-tabs-wrapper { margin-top: 50px; background: #fff; padding: 20px; }
.ro-tabs-nav { list-style: none; padding: 0; display: flex; gap: 20px; border-bottom: 2px solid #eee; margin-bottom: 20px; }
.ro-tabs-nav li { font-weight: 700; color: #888; padding-bottom: 10px; cursor: pointer; }
.ro-tabs-nav li.active { color: #2dad4b; border-bottom: 3px solid #2dad4b; margin-bottom: -2px; }
.ro-tab-content { display: none; }
.ro-tab-content.active { display: block; }
table.shop_attributes th { background-color: #f8f9fa; color: #333; width: 30%; padding: 10px; }
table.shop_attributes td { background-color: #fff; padding: 10px; border-bottom: 1px solid #eee; }
table.shop_attributes { width: 100%; border-collapse: collapse; border: 1px solid #eee; }

/* CARRUSEL */
.ro-carousel-section { margin-top: 40px; padding: 30px 0; text-align: center; background: #fdfdfd; }
.ro-carousel-header h2 { font-size: 22px; font-weight: 700; margin: 10px 0 5px 0; color: #333; }
.ro-carousel-header .ro-header-subtitle { display: block; color: #00AEEF; font-size: 14px; font-weight: 700; text-transform: uppercase; margin-bottom: 30px; }
.ro-header-icon { font-size: 24px; }
.ro-carousel-container { display: flex; align-items: center; position: relative; max-width: 1200px; margin: 0 auto; gap: 15px; }


/* --- TOAST NOTIFICATION (ALERTA) --- */
.ro-toast {
    position: fixed;
    bottom: 20px;
    right: 20px;
    background-color: #fff;
    border-radius: 8px;
    box-shadow: 0 4px 15px rgba(0,0,0,0.15);
    padding: 15px 20px;
    display: flex;
    align-items: center;
    gap: 15px;
    z-index: 9999;
    transform: translateX(120%);
    transition: transform 0.4s cubic-bezier(0.68, -0.55, 0.27, 1.55);
    border-left: 4px solid #2dad4b;
    max-width: 300px;
}

.ro-toast.show {
    transform: translateX(0);
}

.ro-toast-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    color: #2dad4b;
    background: #eef9f0;
    border-radius: 50%;
    width: 32px;
    height: 32px;
    flex-shrink: 0;
}

.ro-toast-body {
    display: flex;
    flex-direction: column;
}

.ro-toast-title {
    font-weight: 700;
    font-size: 14px;
    color: #333;
    margin-bottom: 2px;
}

.ro-toast-link {
    font-size: 12px;
    color: #00AEEF;
    text-decoration: none;
    font-weight: 600;
}

.ro-toast-link:hover {
    text-decoration: underline;
}

/* --- Fin PDP --- */




/* --- cart --- */
.cart-master-container { 
    font-family: 'Arial', sans-serif; 
    color: #333; 
    max-width: 96%; 
    margin: 30px auto; 
    padding: 0 10px; 
    width: 100%; 
}

/* --- CABECERA --- */
.cart-master-container .cart-custom-header { display: flex; align-items: center; gap: 20px; margin-bottom: 25px; }
.cart-master-container .btn-volver-pill { background: #fff; border: 1px solid #333; border-radius: 50px; padding: 6px 20px; color: #333; text-decoration: none; font-weight: 700; font-size: 14px; display: flex; align-items: center; gap: 5px; transition: all 0.2s; white-space: nowrap; }
.cart-master-container .btn-volver-pill:hover { background: #333; color: #fff; }
.cart-master-container .cart-custom-title { color: #00AEEF; font-size: 24px; font-weight: 700; margin: 0; display: flex; align-items: center; gap: 8px; }
.cart-master-container .cart-custom-title .dashicons { font-size: 28px; width: 28px; height: 28px; }

/* --- LAYOUT GRID --- */
.cart-master-container .cart-layout-grid { display: flex; gap: 30px; align-items: flex-start; }
.cart-master-container .cart-col-products { flex: 1; }
.cart-master-container .cart-col-totals { width: 380px; min-width: 380px; position: sticky; top: 20px; }

/* --- ESTILOS PRODUCTOS (IZQ) --- */
.cart-master-container .cart-products-box { background: #fff; border-radius: 12px; box-shadow: 0 4px 20px rgba(0,0,0,0.05); padding: 0; overflow: hidden; }
.cart-master-container .cart-custom-table { width: 100%; border-collapse: collapse; margin: 0; border: none; }
.cart-master-container .cart-custom-table th { background: transparent; padding: 20px 25px; font-size: 13px; font-weight: 700; color: #222; text-transform: none; border-bottom: 1px solid #f0f0f0; text-align: left; }
.cart-master-container .cart-custom-table td { padding: 25px; vertical-align: middle; border-bottom: 1px solid #f9f9f9; background: #fff; }

/* IMAGENES GRANDES */
.cart-master-container .img-wrapper-forced {
    width: 100px; height: 100px; display: flex; align-items: center; justify-content: center;
    border: 1px solid #eee; border-radius: 8px; background: #fff; overflow: hidden;
}
.cart-master-container .img-wrapper-forced img {
    width: 100% !important; height: 100% !important; object-fit: contain !important;
    margin: 0 !important; padding: 5px !important;
}

/* Textos */
.cart-master-container .brand-blue { color: #00AEEF; font-weight: 800; text-transform: uppercase; font-size: 14px; margin-bottom: 5px; }
.cart-master-container .product-title-link { color: #333; font-weight: 700; font-size: 16px; text-decoration: none; display: block; line-height: 1.3; }
.cart-master-container .product-sku { color: #888; font-size: 13px; }
.cart-master-container .product-price, .cart-master-container .product-subtotal { font-weight: 800; font-size: 16px; color: #222; }
.cart-master-container .product-subtotal { color: #28a745; }

/* --- BOTÓN VER ALTERNATIVA --- */
.woocommerce-cart .woocommerce-cart-form__cart-item .product-name .brand-blue {
    color: #00AEEF !important; font-weight: 800 !important; text-transform: uppercase !important;
    font-size: 14px !important; display: block !important; margin-bottom: 5px !important;
}

.woocommerce-cart .woocommerce-cart-form__cart-item .product-name a:not(.btn-ver-alternativa) {
    color: #000000 !important; font-weight: 400 !important; font-size: 14px !important;
    text-decoration: none !important; display: block !important; margin-bottom: 10px !important;
    line-height: 1.3 !important;
}

.cart-master-container .btn-ver-alternativa {
    display: inline-flex !important; align-items: center !important; justify-content: center !important;
    background-color: #ffffff !important; border: 1px solid #cccccc !important; border-radius: 50px !important;
    color: #666666 !important; padding: 5px 15px !important; font-size: 11px !important; font-weight: 600 !important;
    text-decoration: none !important; line-height: 1 !important; white-space: nowrap !important;
    transition: all 0.2s ease !important; margin-top: 5px !important; width: auto !important; min-width: 120px !important; height: auto !important;
}

.cart-master-container .btn-ver-alternativa .dashicons {
    font-size: 14px !important; color: #666666 !important; margin-left: 6px !important; line-height: 1 !important;
    position: relative !important; top: 1px !important;
}

.cart-master-container .btn-ver-alternativa:hover {
    border-color: #999999 !important; background-color: #f5f5f5 !important; color: #333333 !important;
}
.cart-master-container .btn-ver-alternativa:hover .dashicons { color: #333333 !important; }

/* BOTONES CANTIDAD FORZADOS PEQUEÑOS */
.cart-master-container .qty-input-forced::-webkit-inner-spin-button, .cart-master-container .qty-input-forced::-webkit-outer-spin-button { -webkit-appearance: none; margin: 0; }
.cart-master-container .qty-input-forced { -moz-appearance: textfield; }
.cart-master-container .qty-capsule-forced {
    display: flex; align-items: center; border: 1px solid #ccc; border-radius: 6px;
    background: #fff; width: 100px; height: 32px; overflow: hidden; padding: 0;
}
.cart-master-container .qty-btn-forced {
    width: 30px !important; height: 100% !important; background: transparent !important;
    border: none !important; color: #333 !important; font-size: 18px !important; font-weight: bold !important;
    cursor: pointer; padding: 0 !important; display: flex; align-items: center; justify-content: center;
}
.cart-master-container .qty-btn-forced:hover { background-color: #f0f0f0 !important; }
.cart-master-container .qty-input-forced {
    width: 40px !important; height: 100% !important; border: none !important;
    border-left: 1px solid #eee !important; border-right: 1px solid #eee !important;
    background: transparent !important; text-align: center !important;
    font-weight: 700 !important; font-size: 14px !important; padding: 0 !important; margin: 0 !important; outline: none !important;
}

.cart-master-container .remove-icon { color: #ff4d4d !important; font-size: 20px; width: 30px; height: 30px; display: flex; align-items: center; justify-content: center; text-decoration: none; border: 1px solid #ffebeb; border-radius: 4px; }
.cart-master-container .remove-icon:hover { background: #ffebeb; }

/* --- BOTONES ABAJO (SEGUIR COMPRANDO / ACTUALIZAR) --- */
/* Forzado para que no se partan en dos líneas */
.cart-master-container .cart-bottom-actions { display: flex; justify-content: space-between; margin-top: 25px; align-items: center; }

.cart-master-container .btn-action-white { 
    background: #fff !important; 
    color: #333 !important; 
    border: 1px solid #333 !important; 
    padding: 8px 20px !important; /* Padding equilibrado */
    border-radius: 6px !important; 
    font-weight: 700; 
    font-size: 13px !important; 
    text-decoration: none; 
    display: inline-flex; 
    align-items: center; 
    justify-content: center;
    gap: 8px; 
    box-shadow: 0 2px 5px rgba(0,0,0,0.05); 
    transition: all 0.3s ease;
    white-space: nowrap !important; /* OBLIGA A UNA SOLA LÍNEA */
    height: 40px !important; /* Altura controlada */
    line-height: 1 !important;
}
.cart-master-container .btn-action-white:hover { 
    background: #333 !important; color: #fff !important; border-color: #333 !important; 
    box-shadow: 0 4px 12px rgba(0,0,0,0.15); 
}
/* FORZADO DE ALINEACIÓN HORIZONTAL - RED OFFICE */

/* 1. Contenedor Maestro de la barra de compra */
.cart-master-container .ro-buy-bar {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: nowrap !important; /* Impide que el botón baje */
    align-items: center !important;
    justify-content: space-between !important;
    gap: 6px !important;
    padding: 15px !important;
    width: 100% !important;
    box-sizing: border-box !important;
    margin-top: auto !important;
}

/* 2. El selector de cantidad */
.cart-master-container .ro-qty-layout {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    border: 1px solid #ddd !important;
    border-radius: 4px !important;
    height: 36px !important;
    min-width: 80px !important;
    width: 80px !important;
    background: #fff !important;
    overflow: hidden !important;
}

.cart-master-container .ro-qty-layout button {
    width: 25px !important;
    height: 100% !important;
    background: #f8f8f8 !important;
    border: none !important;
    padding: 0 !important;
    margin: 0 !important;
    cursor: pointer !important;
    font-size: 16px !important;
    line-height: 1 !important;
}

.cart-master-container .ro-qty-input {
    width: 30px !important;
    height: 100% !important;
    border: none !important;
    text-align: center !important;
    font-size: 13px !important;
    padding: 0 !important;
    margin: 0 !important;
    background: #fff !important;
}

/* 3. El botón de Agregar (Forzado total) */
.cart-master-container .ro-add-to-cart-btn {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    flex: 1 !important; /* Ocupa el resto del espacio */
    height: 36px !important;
    background-color: #2dad4b !important;
    color: #ffffff !important;
    border-radius: 4px !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    text-decoration: none !important;
    text-transform: uppercase !important;
    white-space: nowrap !important;
    margin: 0 !important;
    padding: 0 10px !important;
}


/* =========================================================
   CARRUSEL  ========================================================= */

/* ---------- CONTENEDOR ---------- */
.cart-master-container .ro-cart-carousel-wrap{
  margin-top: 26px;
  background: #fff;
  border-radius: 14px;
  padding: 18px 16px 24px;
  box-shadow: 0 6px 18px rgba(0,0,0,.06);
  position: relative;
}

/* ---------- ENCABEZADO CENTRADO ---------- */
.cart-master-container .ro-cart-carousel-header-center{
  text-align: center;
  padding: 6px 16px 16px;
}

.cart-master-container .ro-cart-carousel-kicker{
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-weight: 800;
  font-size: 18px;
  color: #00AEEF;
  margin-bottom: 6px;
}

.cart-master-container .ro-kicker-icon{
  font-size: 20px;
  line-height: 1;
}

.cart-master-container .ro-cart-carousel-title{
  margin: 0;
  font-size: 42px;
  font-weight: 800;
  line-height: 1.15;
  color: #222;
}

/* ---------- CARRIL ---------- */
.cart-master-container .ro-cart-carousel{
  display: flex;
  flex-wrap: nowrap;
  gap: 14px;

  overflow-x: auto;
  overflow-y: hidden;
  scroll-behavior: smooth;

  padding: 8px 64px; /* espacio real para flechas */
  -webkit-overflow-scrolling: touch;

  align-items: stretch;
}

/* Ocultar scrollbar */
.cart-master-container .ro-cart-carousel{
  scrollbar-width: none;
  -ms-overflow-style: none;
}
.cart-master-container .ro-cart-carousel::-webkit-scrollbar{
  display: none;
}

/* ---------- CARD ---------- */
.cart-master-container .ro-carousel-item{
  flex: 0 0 220px;
  min-width: 220px;
  max-width: 220px;

  border: 1px solid rgba(0,0,0,.08);
  border-radius: 14px;
  background: #fff;
  overflow: hidden;

  text-decoration: none !important;
  color: inherit !important;

  display: flex;
  flex-direction: column;
}

/* Imagen */
.cart-master-container .ro-carousel-img{
  height: 160px;
  background: #f7f7f7;
  padding: 12px;

  display: flex;
  align-items: center;
  justify-content: center;
}

.cart-master-container .ro-carousel-img img{
  width: 100% !important;
  height: 100% !important;
  object-fit: contain !important;
  margin: 0 !important;
}

/* Meta */
.cart-master-container .ro-carousel-meta{
  padding: 12px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  flex: 1;
}

.cart-master-container .ro-carousel-brand{
  font-weight: 800;
  font-size: 12px;
  letter-spacing: .3px;
  color: #00AEEF;
  text-transform: uppercase;
}

.cart-master-container .ro-carousel-name{
  font-size: 13px;
  font-weight: 700;
  line-height: 1.2;
  min-height: 38px;
  color: #222;
}

.cart-master-container .ro-carousel-price{
  font-size: 14px;
  font-weight: 900;
  color: #111;
}

.cart-master-container .ro-carousel-cta{
  margin-top: auto;
  font-size: 12px;
  font-weight: 800;
  border-radius: 999px;
  padding: 10px;
  text-align: center;
  border: 1px solid rgba(0,0,0,.12);
  background: #fff;
  color: #222;
}

/* ---------- FLECHAS (CLAVE DEL PROBLEMA) ---------- */
/* Overlay completo centrado verticalmente */
.cart-master-container .ro-cart-carousel-nav{
  position: absolute;
  left: 8px;
  right: 8px;
  top: 50%;
  transform: translateY(-50%);
  display: flex;
  justify-content: space-between;
  align-items: center;
  pointer-events: none; /* no bloquea scroll */
  z-index: 30;
}

/* Botones */
.cart-master-container .ro-cart-carousel-nav .ro-carousel-btn{
  pointer-events: auto;
  width: 46px;
  height: 46px;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,.12);
  background: #fff;

  display: flex;
  align-items: center;
  justify-content: center;

  box-shadow: 0 6px 18px rgba(0,0,0,.12);
  cursor: pointer;
}

.cart-master-container .ro-cart-carousel-nav .dashicons{
  font-size: 22px;
  width: 22px;
  height: 22px;
}

/* ---------- RESPONSIVE ---------- */
@media (max-width: 768px){
  .cart-master-container .ro-cart-carousel-title{
    font-size: 26px;
  }
}

@media (max-width: 480px){
  .cart-master-container .ro-cart-carousel{
    padding-left: 56px;
    padding-right: 56px;
  }
  .cart-master-container .ro-carousel-item{
    flex: 0 0 175px;
    min-width: 175px;
    max-width: 175px;
  }
  .cart-master-container .ro-carousel-img{
    height: 130px;
  }
}



/*    DISEÑO BARRA LATERAL (TOTALES) - DEFINITIVO */

/* 1. TÍTULO "TOTAL" */
body .cart_totals h2 {
    text-align: center !important;
    font-size: 18px !important;
    font-weight: 800 !important;
    text-transform: uppercase !important;
    border: none !important;
    margin-bottom: 20px !important;
    color: #000 !important;
    padding: 0 !important;
}

/* 2. CAJA DE PRODUCTOS */
body .sidebar-product-box {
    background: #fff !important;
    border: 1px solid #ccc !important;
    border-radius: 8px !important;
    padding: 15px !important;
    margin-bottom: 20px !important;
}
body .sidebar-item-row {
    display: flex !important; justify-content: space-between !important;
    margin-bottom: 10px !important; font-size: 13px !important;
    border-bottom: 1px solid #f5f5f5 !important; padding-bottom: 10px !important;
}
body .sidebar-item-row:last-child { border: none !important; margin: 0 !important; padding: 0 !important; }
body .si-name strong { font-weight: 700 !important; color: #333 !important; display: block !important; }
body .si-sku { color: #888 !important; font-size: 11px !important; }
body .si-price { text-align: right !important; white-space: nowrap !important; }

/* 3. CUPÓN */
body .coupon-block { margin-bottom: 20px !important; }
body .coupon-label { font-weight: 700 !important; font-size: 12px !important; color: #333 !important; margin-bottom: 5px !important; display: block !important; }
body .coupon-flex { display: flex !important; width: 100% !important; }
body .coupon-flex input#coupon_code {
    border: 1px solid #aaa !important; border-right: none !important;
    border-radius: 6px 0 0 6px !important; padding: 0 10px !important;
    height: 40px !important; flex: 1 !important; font-size: 13px !important;
}
body .coupon-flex button.btn-apply-coupon {
    background-color: #438e28 !important; color: #fff !important;
    border: 1px solid #438e28 !important; border-radius: 0 6px 6px 0 !important;
    padding: 0 15px !important; height: 40px !important; font-weight: 700 !important;
    text-transform: uppercase !important; cursor: pointer !important; display: flex !important; align-items: center !important;
}
body .coupon-flex button.btn-apply-coupon::before {
    content: '\f467' !important; font-family: 'dashicons' !important; margin-right: 5px !important;
}

/* 4. CAJA SUBTOTAL (BORDE NEGRO REDONDEADO) */
body .cart-subtotal-box {
    background: #fff !important;
    border: 1px solid #333 !important; 
    border-radius: 8px !important;
    padding: 15px !important;
    margin-bottom: 15px !important;
    display: flex !important; justify-content: space-between !important; align-items: center !important;
}
body .subtotal-row { display: flex !important; width: 100% !important; justify-content: space-between !important; align-items: center !important; }
body .subtotal-row .label { font-weight: 700 !important; font-size: 14px !important; color: #333 !important; }
body .subtotal-row .value { font-weight: 800 !important; font-size: 16px !important; color: #000 !important; }

/* 5. CAJA TOTAL A PAGAR  */
body .total-pay-box {
    background-color: #eafff0 !important; 
    border: 1px dashed #28a745 !important; 
    border-radius: 8px !important;
    padding: 15px !important;
    margin-bottom: 20px !important;
    text-align: center !important;
    color: #006837 !important;
}
body .total-center-content {
    display: flex !important; justify-content: center !important; align-items: center !important; gap: 10px !important;
}
body .total-pay-box .dashicons { font-size: 24px !important; width: 24px !important; height: 24px !important; }
body .total-label { font-size: 16px !important; font-weight: 700 !important; }
body .total-amount .amount { font-size: 20px !important; font-weight: 800 !important; color: #006837 !important; }

/* 6. BOTÓN IR A PAGAR */
body .wc-proceed-to-checkout { 
    padding: 0 !important; 
    margin-top: 15px !important; 
}


body .wc-proceed-to-checkout a.redoffice-checkout-btn {
    background-color: #28a745 !important;
    color: #fff !important;
    width: 100% !important;
    
    display: flex !important; 
    align-items: center !important; 
    justify-content: center !important; 
    
  
    height: 40px !important; 
    padding: 0 !important; 
    margin: 0 !important;
    
    /* TEXTO */
    font-size: 15px !important;
    font-weight: 700 !important;
    border-radius: 6px !important;
    text-transform: none !important;
    text-decoration: none !important;
    line-height: 1 !important; 
}

body .wc-proceed-to-checkout a.redoffice-checkout-btn:hover { 
    background-color: #218838 !important; 
}


body .wc-proceed-to-checkout a.redoffice-checkout-btn::after,
body .wc-proceed-to-checkout a.redoffice-checkout-btn::before {
    content: none !important;
    display: none !important;
}

/* --- Fin cart --- */




/*  Formulario */
.checkout-section-box {
    background-color: #ffffff;
    border-radius: 15px;
    padding: 40px;
    box-shadow: 0 4px 15px rgba(0,0,0,0.05);
    border: 1px solid #eaeaea;
    margin-bottom: 30px;
}


.custom-checkout-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 25px;
    padding-bottom: 15px;
    border-bottom: 1px solid #f0f0f0;
}
.btn-volver-checkout {
    border: 1px solid #ccc;
    color: #555;
    border-radius: 50px;
    padding: 6px 20px;
    text-decoration: none;
    font-size: 13px;
    font-weight: 600;
}
.section-title-blue {
    color: #00c3ff; 
    font-size: 18px;
    font-weight: 700;
    margin: 0;
}

.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.select2-container--default .select2-selection--single {
    background-color: #f2f2f2 !important; 
    border: none !important;
    border-radius: 6px !important;
    padding: 12px 15px !important;
    color: #333;
    min-height: 48px;
}

.select2-container .select2-selection--single {
    height: 48px !important; 
    display: flex;
    align-items: center;
}
.select2-container--default .select2-selection--single .select2-selection__arrow {
    height: 46px !important;
}


.woocommerce form .form-row label {
    font-weight: 700;
    color: #333;
    font-size: 13px;
    margin-bottom: 5px;
    display: block;
}


.woocommerce-billing-fields__field-wrapper {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 15px 0; 
}

.woocommerce-billing-fields__field-wrapper p.form-row {
    margin: 0 !important;
}


#billing_first_name_field, #billing_last_name_field, 
#billing_phone_field, #billing_rut_field,            
#billing_address_1_field, #billing_address_2_field,  
#billing_city_field, #billing_state_field {            
    width: 48% !important;
    display: inline-block;
}


#billing_email_field {
    width: 100% !important;
}


#billing_address_2_field label {
    display: none; 
}

#billing_address_2_field {
    align-self: flex-end; 
}


@media (max-width: 768px) {
    .col2-set {
        flex-direction: column;
    }
 
    #billing_first_name_field, #billing_last_name_field,
    #billing_phone_field, #billing_rut_field,
    #billing_address_1_field, #billing_address_2_field,
    #billing_city_field, #billing_state_field {
        width: 100% !important;
        margin-bottom: 15px !important;
    }
    .custom-checkout-header {
        flex-direction: column-reverse;
        align-items: flex-start;
        gap: 15px;
    }
}
/* Fin Formulario */




/*  Resumen Orden*/
.woocommerce-checkout-review-order table,
.woocommerce-checkout-review-order th,
.woocommerce-checkout-review-order td,
.woocommerce-checkout-review-order tr {
    border: none !important;
    background: #ffffff !important; 
}

.woocommerce-checkout-review-order table thead th {
    background-color: #ffffff !important;
    color: #222 !important;
    font-weight: 800 !important;
    font-size: 12px !important;
    text-transform: capitalize !important;
    border-bottom: 1px solid #eee !important;
    padding: 15px 5px !important;
}

.woocommerce-checkout-review-order table thead th.product-sku,
.woocommerce-checkout-review-order table thead th.product-unit-price,
.woocommerce-checkout-review-order table thead th.product-quantity {
    text-align: center !important;
}

.woocommerce-checkout-review-order table tbody td {
    padding: 15px 5px !important;
    vertical-align: middle !important;
    border-bottom: 1px solid #f5f5f5 !important;
}

tr.order-total,
tr.order-total th,
tr.order-total td {
    background-color: #eafbf1 !important; 
    border-top: 1px solid #ddd !important;
}

tr.order-total th {
    color: #000 !important;
    font-weight: 800 !important;
    text-transform: uppercase !important;
    font-size: 16px !important;
    padding: 25px 20px !important;
    text-align: left !important;
}

tr.order-total td {
    text-align: right !important;
    padding: 25px 20px !important;
}

tr.order-total td span, 
tr.order-total td strong {
    color: #000 !important;
    font-size: 24px !important; 
    font-weight: 900 !important;
}

#shipping_method {
    text-align: right !important;
    display: flex;
    flex-direction: column;
    align-items: flex-end;
}
#shipping_method li {
    margin-bottom: 5px !important;
    text-align: right !important;
}

/* --- RESPONSIVE --- */
@media (max-width: 768px) {
    .woocommerce-checkout-review-order table thead {
        display: none;
    }

    .woocommerce-checkout-review-order table tr,
    .woocommerce-checkout-review-order table td {
        display: block;
        text-align: left !important;
    }

    #shipping_method {
        align-items: flex-start !important;
        text-align: left !important;
        width: 100%;
    }
}
/* Fin Resumen Orden*/







/*Medios de pago */

#order_review_heading {
    display: none !important;
}

.woocommerce-checkout-review-order > h3 {
    display: none !important;
}

.checkout-order-header {
    display: block !important;
    text-align: center;
    padding-bottom: 20px;
}
.checkout-order-header h3 {
    display: block !important;
    color: #00bfff !important; 
    font-size: 18px !important;
    font-weight: 700 !important;
    text-transform: uppercase;
    margin: 0;
}

.woocommerce-checkout-review-order table.shop_table thead th,
.woocommerce-checkout-review-order table.shop_table thead td {
    background-color: #ffffff !important;
    background: #ffffff !important;
    color: #222 !important; 
    border-bottom: 2px solid #f0f0f0 !important;
    border-top: none !important;
    border-left: none !important;
    border-right: none !important;
}

.woocommerce-checkout-review-order table.shop_table tbody td {
    background-color: #ffffff !important;
    border-bottom: 1px solid #f5f5f5 !important;
}

#payment.custom-payment-box {
    background: #fff !important;
    border: 1px solid #eee !important;
    padding: 20px !important;
    margin-top: 20px;
}

.payment-methods-wrapper {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center; 
    gap: 20px;
}

ul.wc_payment_methods {
    display: flex !important;
    flex-wrap: wrap;
    gap: 15px !important;
    padding: 0 !important;
    margin: 0 !important;
    list-style: none !important;
}

ul.wc_payment_methods li {
    background: #ffffff !important;
    border: 1px solid #ddd !important; 
    border-radius: 8px !important;
    padding: 5px 15px !important;
    display: flex !important;
    align-items: center !important;
    margin: 0 !important;
    min-height: 50px;
}

ul.wc_payment_methods li input[type="radio"] {
    opacity: 1 !important; 
    position: static !important; 
    width: auto !important;
    margin-right: 10px !important;
    display: inline-block !important;
    accent-color: #28a745; 
}

ul.wc_payment_methods li label {
    margin: 0 !important;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 14px;
    font-weight: 600;
    color: #333;
}
ul.wc_payment_methods li label img {
    max-height: 25px !important; 
    width: auto !important;
    margin: 0 !important;
}

.payment-total-box {
    background-color: #eafbf1 !important;
    color: #000 !important;
    font-weight: 800 !important;
    padding: 10px 20px;
    border-radius: 5px;
    font-size: 15px;
    border: 1px solid #c3e6cb;
    white-space: nowrap;
}

div.payment_box {
    display: none !important;
}

/* --- RESPONSIVE --- */
@media (max-width: 768px) {
    .payment-methods-wrapper {
        flex-direction: column;
        align-items: stretch;
    }

    ul.wc_payment_methods {
        flex-direction: column !important;
        gap: 10px !important;
    }

    ul.wc_payment_methods li {
        width: 100% !important;
        justify-content: flex-start !important;
    }

    .payment-total-box {
        width: 100%;
        text-align: center;
        white-space: normal;
    }
}
/* Fin Medios de pago */



/* login*/
.ro-login-wrapper {
    max-width: 900px;
    margin: 50px auto 80px;
    font-family: 'Arial', sans-serif;
}

.ro-login-top {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 8px;
    margin-bottom: 40px;
    font-size: 20px;
}

.ro-login-icon {
    width: 28px;
    height: 28px;
    color: #00AEEF;
    stroke-width: 2.5;
}

.ro-login-top a {
    font-weight: 700;
    color: #00AEEF !important;
    text-decoration: none;
    font-size: 20px;
}

.ro-login-divider {
    color: #00AEEF;
    font-weight: 400;
    margin: 0 5px;
    font-size: 20px;
}

.ro-login-columns {
    display: flex;
    gap: 30px;
    justify-content: center;
    align-items: stretch; 
    flex-wrap: wrap;
}

.ro-login-card {
    background: #f3f3f3;
    padding: 40px 35px;
    border-radius: 8px;
    width: 45%;
    min-width: 320px;
    border: none;
    display: flex;
    flex-direction: column; 
}

.ro-login-title {
    font-size: 15px;
    font-weight: 700;
    color: #333;
    margin-bottom: 25px;
    margin-top: 0;
}

.ro-form-group {
    margin-bottom: 15px;
}

.ro-form-group input:not([type="checkbox"]):not([type="radio"]) {
    width: 100%;
    background-color: #ffffff !important;
    padding: 0 15px;
    border-radius: 6px;
    border: 1px solid #e0e0e0;
    font-size: 14px;
    color: #555;
    box-shadow: none;
    box-sizing: border-box;
    height: 45px;
}

.ro-form-group input:-webkit-autofill,
.ro-form-group input:-webkit-autofill:hover, 
.ro-form-group input:-webkit-autofill:focus, 
.ro-form-group input:-webkit-autofill:active {
    -webkit-box-shadow: 0 0 0 30px white inset !important;
    -webkit-text-fill-color: #555 !important;
    transition: background-color 5000s ease-in-out 0s;
}

.ro-form-group input::placeholder {
    color: #aaa;
}

.ro-form-group input:focus {
    background-color: #fff !important;
    border-color: #00AEEF;
    outline: none;
}

div.ro-phone-group {
    display: flex;
    align-items: center;
    background: #ffffff !important;
    border: 1px solid #e0e0e0;
    border-radius: 6px;
    padding: 0 15px;
    height: 45px;
    box-sizing: border-box;
}

.ro-phone-prefix {
    color: #888;
    font-weight: 600;
    font-size: 14px;
    white-space: nowrap;
}

.ro-phone-sep {
    color: #ccc;
    margin: 0 12px;
    font-weight: 300;
    font-size: 18px;
}

div.ro-phone-group input {
    border: none !important;
    background: transparent !important;
    padding: 0 !important;
    margin: 0 !important;
    height: 100% !important;
    width: 100% !important;
    outline: none !important;
    box-shadow: none !important;
}

div.ro-phone-group:focus-within {
    border-color: #00AEEF;
}


.ro-rememberme,
.ro-newsletter {
    margin: 15px 0 20px;
    font-size: 13px;
    color: #666;
}

.ro-rememberme label,
.ro-newsletter label {
    display: flex;
    align-items: center;
    gap: 8px;
    cursor: pointer;
}

input[type="checkbox"] {
    accent-color: #2faa45;
    width: 16px;
    height: 16px;
}

.ro-forgot {
    display: block;
    margin: 15px 0 20px;
    font-size: 13px;
    color: #00AEEF;
    font-weight: 600;
    text-decoration: none;
}

.ro-btn-green {
    width: 100%;
    padding: 0;
    background: #2faa45 !important;
    color: #fff !important;
    font-weight: 700;
    font-size: 14px;
    border-radius: 6px;
    border: none;
    cursor: pointer;
    text-transform: uppercase;
    height: 45px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-top: 10px;
}

.ro-btn-green:hover {
    background: #26963a !important;
}

.ro-google-btn {
    margin-top: 15px;
    width: 100%;
    background: #ffffff;
    border: 1px solid #e0e0e0;
    padding: 0;
    height: 45px;
    border-radius: 6px;
    font-weight: 700;
    display: flex;
    justify-content: center;
    gap: 10px;
    align-items: center;
    color: #444;
    text-decoration: none;
    font-size: 14px;
    box-shadow: 0 2px 5px rgba(0,0,0,0.05);
}

.ro-google-btn img {
    width: 18px;
    height: 18px;
}


@media (max-width: 768px) {
    .ro-login-card {
        width: 100%;
    }
}



/*  Olvido Contraseña */
.ro-lostpass-wrapper {
    max-width: 800px;
    margin: 60px auto 100px;
    font-family: 'Arial', sans-serif;
    text-align: center;
}

.ro-lostpass-header {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 10px;
    margin-bottom: 30px;
    color: #00AEEF;
}

.ro-lostpass-header svg {
    stroke: #00AEEF;
    width: 28px;
    height: 28px;
}

.ro-lostpass-header h1 {
    font-size: 26px;
    font-weight: 700;
    color: #00AEEF;
    margin: 0;
    text-transform: none;
    border: none;
}

.ro-lostpass-card {
    background: #f3f3f3; /* Gris claro */
    padding: 60px 20px;
    border-radius: 8px;
    max-width: 600px;
    margin: 0 auto;
    display: flex; /* Flexbox para centrar todo */
    flex-direction: column;
    align-items: center;
}


.ro-lostpass-text {
    font-size: 16px;
    color: #333;
    font-weight: 600;
    margin-bottom: 25px;
    text-align: center;
}


.ro-lostpass-card form.woocommerce-ResetPassword {
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
    padding: 0 !important;
    margin: 0 !important;
    width: 100%;
    max-width: 400px;
}


.ro-form-group {
    margin-bottom: 20px;
    width: 100%;
}

.ro-lostpass-card input[type="text"] {
    width: 100%;
    background: #ffffff !important;
    border: 1px solid #e0e0e0;
    padding: 12px 15px;
    border-radius: 6px;
    height: 45px;
    color: #555;
    text-align: left; 
    margin: 0;
    box-sizing: border-box;
}


.ro-form-btn {
    text-align: center;
    margin-top: 10px;
}

.ro-lostpass-card button[type="submit"] {
    width: 100%;
    max-width: 250px; 
    background: #2faa45 !important;
    color: #fff !important;
    border: none;
    padding: 12px;
    font-weight: 700;
    text-transform: capitalize;
    border-radius: 6px;
    font-size: 16px;
    cursor: pointer;
}

.ro-lostpass-card button[type="submit"]:hover {
    background: #26963a !important;
}


.ro-back-link {
    display: block;
    margin-top: 25px;
    color: #00AEEF !important;
    text-decoration: none;
    font-weight: 600;
    font-size: 14px;
}

.ro-back-link:hover {
    text-decoration: underline;
}
li.stock-critico .redoffice-qty-wrapper,
li.stock-critico .caja-mas-menos {
    display: none !important;
}

li.stock-critico .button.alt {
		width: auto !important;
    height: 28px !important;
		margin: 0 auto !important; 
    padding: 0px 34px 0px 8px!important;

}

.ro-products-list {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;

}
a.lista-escolar , .title-list{
	background: #00AEEF;
	color:white;
}

/*CSS JH*/
.woocommerce-account table.woocommerce-orders-table {
  border-spacing: 0 20px; 
	width: 850px;
}
.woocommerce table.shop_table tbody{
	background: #F9F9F9 !important; 
}
.woocommerce-MyAccount-content-wrapper{
	border: none !important;
}
.woocommerce-account .woocommerce-orders-table td.woocommerce-orders-table__cell-order-actions{
  display: flex !important;
  gap: 18px; 
}
.woocommerce-account table.woocommerce-orders-table,
.woocommerce-account table.woocommerce-orders-table th,
.woocommerce-account table.woocommerce-orders-table td {
  border: none !important;
}
.woocommerce-account table.woocommerce-orders-table tbody tr td:first-child {
  border-top-left-radius: 20px;
  border-bottom-left-radius: 20px;
}
td.woocommerce-orders-table__cell-order-actions
{
	height: 118px !important;
}

/* Contenedor Acciones */
table.woocommerce-orders-table td.woocommerce-orders-table__cell-order-actions{
  align-items: center !important;
}

/* Estilo Botones Acciones */
table.woocommerce-orders-table td.woocommerce-orders-table__cell-order-actions a.woocommerce-button{
  display: inline-flex !important;
  justify-content: center !important;
  align-items: center !important;
  width: 67px !important;   
  height: 26px !important;   
  padding: 0 !important;
  margin: 0 !important;
  border-radius: 10px !important;
}

/*CSS JH mi cuenta*/
.woocommerce-MyAccount-navigation{
	transform: translateX(-80px);
	transform: translateY(30px);
}
.woocommerce-button button pay{
	width: 20px !important;
	height: 20px !important;
}
.woocommerce-account .woocommerce-MyAccount-navigation ul li a{
  background: transparent !important;
	font-size: 20px !important;
}
.woocommerce-account .woocommerce-MyAccount-navigation
li.woocommerce-MyAccount-navigation-link--downloads{
  display: none !important;
}
.titulo-myaccount-con-icono{
	margin-left: 20px !important;
	margin-bottom: -10px !important;
}

/*BOTONES ACCIONES*/
td.woocommerce-orders-table__cell-order-actions a.woocommerce-button.pay {
	background-color:#2BA84A !important;
	border-color: #2BA84A !important;
	font-size: 10px !important;
}
td.woocommerce-orders-table__cell-order-actions a.woocommerce-button.view {
  background: #000000 !important;
  border-color: #000000 !important;
  color: #ffffff !important;
	font-size: 10px !important;
}

.woocommerce-account.woocommerce-orders 
td.woocommerce-orders-table__cell-order-actions a.woocommerce-button.cancel {
  background: #FF0000 !important;
  border-color: #FF0000 !important;
  color: #ffffff !important;
	font-size: 10px !important;
}
/*CSS JH CARRITO Y BOTON ARTICULOS*/

/*CSS CART JH*/
.qty-btn-forced , .minus ,.plus{
}
.shop_table , .cart-custom-table{
	background:#F8F8F8;
	padding: 20px 20px 20px 20px !important;
	border: none !important;
}
/* SOLO carrito */
.woocommerce-cart td.product-quantity .ro-minus,
.woocommerce-cart td.product-quantity .ro-plus {
    position: relative;
    top: 14px; 
}
.cart_totals {
	background:#F8F8F8;
	padding: 20px 30px 20px 30px !important;
	border-radius: 20px
}
/*CSS BTN ARTICULOS Y CONTADOR*/
/* Texto dinámico*/
a.abrir-sidecart.xoo-wsc-cart-trigger::after{
    content: attr(data-count) " Artículos";
}
/* Ocultar si carrito vacío */
a.abrir-sidecart.xoo-wsc-cart-trigger:not(.has-items){
    display: none;
}

table.shop_table.cart-custom-table {
	border-spacing: 0 20px; 
	
}
/* Quitar bordes de la tabla del carrito */
.shop_table,
.shop_table th,
.shop_table td,
.shop_table tr {
    border: none !important;
}
.shop_table tr:first-child td:first-child {
    border-top-left-radius: 14px;
		border-bottom-left-radius: 14px;
}

.shop_table tr:first-child td:last-child {
    border-top-right-radius: 14px;
		border-bottom-right-radius: 14px;
}

.shop_table tr:last-child td:first-child {
    border-bottom-left-radius: 14px;
		border-top-left-radius: 14px;
}

.shop_table tr:last-child td:last-child {
    border-bottom-right-radius: 14px;
		border-top-right-radius: 14px;
}
.cart-products-box{
	background: #F8F8F8 !important;
	box-shadow: none !important;
}


/* 1. Hace que el contenedor del menú no empuje el contenido hacia abajo */
.ubermenu-main {
    position: absolute !important; 
    z-index: 99999 !important;
    width: auto !important;
}

/* 2. Configuración del Submenú  */
.ubermenu .ubermenu-submenu.ubermenu-submenu-type-mega {
    position: absolute !important;
    top: 0 !important;
    left: 100% !important; 
    background-color: #f4f6f9 !important; 
    width: 70vw !important;
    max-width: 1000px !important;
    box-shadow: 10px 5px 25px rgba(0,0,0,0.2) !important; 
    padding: 30px !important;
}

/* 3. Columna de Menús Padres (Blanco) */
.ubermenu .ubermenu-item-level-0 {
    background-color: #ffffff !important; 
    width: 250px !important; 
}

/* 4. Distribución de 3 arriba y 2 abajo */
.ubermenu .ubermenu-item-level-1 {
    width: 30% !important;
    margin-right: 2% !important;
    margin-bottom: 30px !important;
    display: inline-block !important;
    vertical-align: top !important;
}
