html {
  scroll-behavior: smooth;
}
body{
    overflow-y:scroll;
    color: var(--body-txt-default-color);
    background:var(--body-bg);
    font-family: var(--body-font-family);
}

body .bs-main{
    padding:0;
}

/****************
Sitio En construcción
*******************/

.bs-construction-page {
    height:100%;
    display: flex;
    align-items: center;
}
.fondo-construccion {
    background: url(texturaseda.jpeg);
}

/* titles */
h1,h2,h3,h4,h5,h6{
    font-family:var(--title-font-family);
}
.bs-title{
    font-weight: var(--title-weight, var(--font-bold));
    text-align:center;
}
.bs-title-background{
    position:relative;
    backdrop-filter: none;
}
.bs-title-background::before{
    content:
    " ";
    display:
    block;
    background: transparent;
    border-radius:
    var(--default-border-radius);
    opacity: 0.3;
    position:
    absolute;
    top:0;
    right:0;
    bottom:0;
    left:0;
}
.bs-title-background span,
.bs-title-background a,
.bs-title-background a:hover{
    z-index:10;
    position:relative;
    color: var(--color, white);
}


/********************
contenedor 
********************/
  .container-xxl, .container{
        max-width:1320px;
        width:100%;
        margin-left:auto;
        margin-right:auto;
        padding-right: 15px;
        padding-left: 15px;
    }   
 
/**********************************
    Migas de Pan
***********************************/
.bs-breadcrumb .dropdown-item:active {
    background-color: var(--primary-color);
}

.bs-breadcrumb {
    background: var(--breadcrumb-bg-color);
    border-radius: 0.25rem;
    width: 100%;
}

.breadcrumb {
    display: flex;
    align-items: center;
    min-height: 32px;
    margin-bottom: 0;
    padding: 0.5rem 1rem;
    font-size: 0.875rem;
    background: var(--breadcrumb-bg-color);
}

.breadcrumb-item {
    line-height: 2;
}

.breadcrumb-item a {
    display: flex;
    align-items: center;
    text-decoration: none;
    color: #696969;
    cursor:pointer;
}

.breadcrumb-item a:hover {
    text-decoration: underline;
}

.breadcrumb-item + .breadcrumb-item::before {
    content: '>';
    color: #6c757d;
    padding: 0 5px;
}

.breadcrumb-item.active {
    color: rgb(69 69 69);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    display: block;
    max-width: 30%;
    padding-bottom: 1px;
}

.icon {
    width: 16px;
    height: 16px;
    margin-right: 5px;
    fill: currentColor;
}

/* Estilos para pantallas pequeñas */
@media (max-width: 768px) {
    .breadcrumb {
        min-height: 28px;
        font-size: 0.75rem;
        padding: 0.25rem 0.5rem;
        margin-left: 0;
        justify-content: flex-start;
    }
    
    .breadcrumb-item.active {
        max-width: 50%; 
    }
    
    .breadcrumb-item + .breadcrumb-item::before {
        padding: 0 3px;
    }

    .icon {
        width: 12px;
        height: 12px;
        margin-right: 3px;
    }

    /* Agrega scroll al dropdown en mobile */
    .breadcrumb-item .dropdown-menu {
        max-height: 200px;
        overflow-y: auto;
        -webkit-overflow-scrolling: touch; /* Para mejor scroll en iOS */
    }

    /* Estilizar scrollbar para móviles que lo soporten */
    .breadcrumb-item .dropdown-menu::-webkit-scrollbar {
        width: 4px;
    }

    .breadcrumb-item .dropdown-menu::-webkit-scrollbar-track {
        background: #f1f1f1;
    }

    .breadcrumb-item .dropdown-menu::-webkit-scrollbar-thumb {
        background: #888;
        border-radius: 4px;
    }
}
 /***********************
 pagination
 ***********************/
  .pagination{
      display:flex;
  }
 .pagination .page-item.active .page-link{
     background:var(--pagination-active-bg);
     color:var(--pagination-active-color);
     border-color:var(--pagination-active-bg);
 }
  .pagination .page-item .page-link{
     background:var(--pagination-bg);
     color:var(--pagination-color);
 }
  .pagination .page-item:not(.active) .page-link:hover{
     background:var(--pagination-hover-bg);
     color:var(--pagination-hover-color);
 }

 /*promotion*/
 .bs-promotion__item{
        display:block;
        overflow:hidden;
        border-radius: var(--default-border-radius);
        position:relative;
    }
 .bs-promotion__img:hover{
     transform: scale(1.05);
    transition: 0.8s ease;
}
.bs-promotion__title{
    position:absolute;
    bottom: var(--gap);
    left:var(--gap);
    padding: calc(var(--gap)/2)
}
 /******************
 jumbotron
 *******************/
 .jumbotron{
     background: var(--element-bg);
 }
 
/***********************
marcas home
************************/
.bs-brands__item{
    background: var(--body-bg);
    display:
    block;
    padding: var(--slider-margin);
    border-radius: var(--default-border-radius);
    position:
    relative;
    overflow:
    hidden;
}
.bs-brands__item::after{
    transition:all .25s ease;
    content:"";
    position:absolute;
    top:0;
    bottom:0;
    left:0;
    right:0;
    background:rgba(0,0,0,0.125);
    opacity:0;
}
.bs-brands__item:hover::after{
    opacity:1
}

/*******************
discount 
*******************/
.bs-discount{
    font-size:var(--discount-font-size, 1em);
    background:var(--discount-bg-color, var(--primary-color));
    color:var(--discount-txt-color, var(--primary-color));
    
}
.bs-discount.template{
    font-weight: var(--weight);
    border-radius:var(--border-radius, .75rem);
    text-align:center;
    padding :var(--padding, .75em 2em);
}
/********************
    img blur 
*********************/
.img-bg-blur img{
    z-index:10;
}
.img-bg-blur::before,
.img-bg-blur::after{
    display:block;
    position:absolute;
    top:0;
    left:0;
    right:0;
    bottom:0;
    z-index:0;
    content:"";
}
.img-bg-blur::before{
    z-index:0;
    background-image: var(--img-bg-blur);
    background-size:cover;
}
.img-bg-blur::after{
    backdrop-filter: blur(10px);
    background:rgba(0,0,0,0.1);
}

/********************************************************************
MEDIA QUERIES
*********************************************************************/ 
.bs-img-square::after{padding-bottom: calc( var(--aspect-ratio,1) * 100%);}

@media screen and (min-width:576px){
    /* font body */ 
    :root{font-size: var(--body-font-size-sm, var(--body-font-size));}
    /* descuento */ 
    .bs-discount{font-size:var(--discount-font-size-sm, var(--discount-font-size, 1.4rem));}
    .bs-cart.bs-discount{font-size:var(--cart-discount-font-size-sm, var(--cart-discount-font-size, .6rem));}
    /* --aspect-ratio */
    .bs-img-square::after{padding-bottom: calc( var(--aspect-ratio-sm,var(--aspect-ratio,1)) * 100%);}
}
@media screen and (min-width:768px){
    /* font body */
    :root{font-size: var(--body-font-size-md, var(--body-font-size-sm, var(--body-font-size)));}
    /* descuento */ 
    .bs-discount{font-size:var(--discount-font-size-md, var(--discount-font-size-sm, var(--discount-font-size, 1.4rem)));}
    .bs-cart.bs-discount{font-size:var(--cart-discount-font-size-md, var(--cart-discount-font-size-sm, var(--cart-discount-font-size, .6rem)));}
    /* --aspect-ratio */
    .bs-img-square::after{padding-bottom: calc( var(--aspect-ratio-md,var(--aspect-ratio-sm,var(--aspect-ratio,1))) * 100%);}
}
@media screen and (min-width:992px){
    /* font body */
    :root{font-size: var(--body-font-size-lg, var(--body-font-size-md, var(--body-font-size-sm, var(--body-font-size))));}
    /* descuento */ 
    .bs-discount{font-size:var(--discount-font-size-lg, --var(--discount-font-size-md, var(--discount-font-size-sm, var(--discount-font-size, 1.4rem))));}
    .bs-cart.bs-discount{font-size:var(--cart-discount-font-size-lg, var(--cart-discount-font-size-md, var(--cart-discount-font-size-sm, var(--cart-discount-font-size, .6rem))));}
    /* --aspect-ratio */
    .bs-img-square::after{padding-bottom: calc( var(--aspect-ratio-lg,var(--aspect-ratio-md,var(--aspect-ratio-sm,var(--aspect-ratio,1)))) * 100%);}
}
@media screen and (min-width:1200px){
    /* font body */
    :root{font-size: var(--body-font-size-xl, var(--body-font-size-lg, var(--body-font-size-md, var(--body-font-size-sm, var(--body-font-size)))));}
    /* descuento */ 
    .bs-discount{font-size:var(--discount-font-size-xl, var(--discount-font-size-lg, --var(--discount-font-size-md, var(--discount-font-size-sm, var(--discount-font-size, 1.4rem)))));}
    .bs-cart.bs-discount{font-size:var(--cart-discount-font-size-xl, var(--cart-discount-font-size-lg, var(--cart-discount-font-size-md, var(--cart-discount-font-size-sm, var(--cart-discount-font-size, .6rem)))));}
    /* --aspect-ratio */
    .bs-img-square::after{padding-bottom: calc( var(--aspect-ratio-xl,var(--aspect-ratio-lg,var(--aspect-ratio-md,var(--aspect-ratio-sm,var(--aspect-ratio,1))))) * 100%);}
}

/* imagen degradado transparente */
:root{
    --img-gradient: rgba(0, 0, 0, 1) 0%,rgba(0, 0, 0, 1) 60%,rgba(0, 0, 0, 0.1) 80%,rgba(0, 0, 0, 0) 100%;
}

.imagen-gradient-top-down{
    --degree:180deg;
    -webkit-mask-image: linear-gradient(var(--degree),var(--img-gradient));
    mask-image:  linear-gradient(var(--degree),var(--img-gradient));
}
.imagen-gradient-down-top{
    --degree:0deg;
    -webkit-mask-image: linear-gradient(var(--degree),var(--img-gradient));
    mask-image:  linear-gradient(var(--degree),var(--img-gradient));
}
.imagen-gradient-left-right{
    --degree:90deg;
    -webkit-mask-image: linear-gradient(var(--degree),var(--img-gradient));
    mask-image:  linear-gradient(var(--degree),var(--img-gradient));
}
.imagen-gradient-right-left{
    --degree:-90deg;
    -webkit-mask-image: linear-gradient(var(--degree),var(--img-gradient));
    mask-image:  linear-gradient(var(--degree),var(--img-gradient));
}
@media screen and (min-width:576px){
    .imagen-gradient-sm-top-down{
        --degree:180deg;
        -webkit-mask-image: linear-gradient(var(--degree),var(--img-gradient));
        mask-image:  linear-gradient(var(--degree),var(--img-gradient));
    }
    .imagen-gradient-sm-down-top{
        --degree:0deg;
        -webkit-mask-image: linear-gradient(var(--degree),var(--img-gradient));
        mask-image:  linear-gradient(var(--degree),var(--img-gradient));
    }
    .imagen-gradient-sm-left-right{
        --degree:90deg;
        -webkit-mask-image: linear-gradient(var(--degree),var(--img-gradient));
        mask-image:  linear-gradient(var(--degree),var(--img-gradient));
    }
    .imagen-gradient-sm-right-left{
        --degree:-90deg;
        -webkit-mask-image: linear-gradient(var(--degree),var(--img-gradient));
        mask-image:  linear-gradient(var(--degree),var(--img-gradient));
    }
}
@media screen and (min-width:768px){
    .imagen-gradient-md-top-down{
        --degree:180deg;
        -webkit-mask-image: linear-gradient(var(--degree),var(--img-gradient));
        mask-image:  linear-gradient(var(--degree),var(--img-gradient));
    }
    .imagen-gradient-md-down-top{
        --degree:0deg;
        -webkit-mask-image: linear-gradient(var(--degree),var(--img-gradient));
        mask-image:  linear-gradient(var(--degree),var(--img-gradient));
    }
    .imagen-gradient-md-left-right{
        --degree:90deg;
        -webkit-mask-image: linear-gradient(var(--degree),var(--img-gradient));
        mask-image:  linear-gradient(var(--degree),var(--img-gradient));
    }
    .imagen-gradient-md-right-left{
        --degree:-90deg;
        -webkit-mask-image: linear-gradient(var(--degree),var(--img-gradient));
        mask-image:  linear-gradient(var(--degree),var(--img-gradient));
    }
}
@media screen and (min-width:992px){
    .imagen-gradient-lg-top-down{
        --degree:180deg;
        -webkit-mask-image: linear-gradient(var(--degree),var(--img-gradient));
        mask-image:  linear-gradient(var(--degree),var(--img-gradient));
    }
    .imagen-gradient-lg-down-top{
        --degree:0deg;
        -webkit-mask-image: linear-gradient(var(--degree),var(--img-gradient));
        mask-image:  linear-gradient(var(--degree),var(--img-gradient));
    }
    .imagen-gradient-lg-left-right{
        --degree:90deg;
        -webkit-mask-image: linear-gradient(var(--degree),var(--img-gradient));
        mask-image:  linear-gradient(var(--degree),var(--img-gradient));
    }
    .imagen-gradient-lg-right-left{
        --degree:-90deg;
        -webkit-mask-image: linear-gradient(var(--degree),var(--img-gradient));
        mask-image:  linear-gradient(var(--degree),var(--img-gradient));
    }
}
@media screen and (min-width:1200px){
    .imagen-gradient-xl-top-down{
        --degree:180deg;
        -webkit-mask-image: linear-gradient(var(--degree),var(--img-gradient));
        mask-image:  linear-gradient(var(--degree),var(--img-gradient));
    }
    .imagen-gradient-xl-down-top{
        --degree:0deg;
        -webkit-mask-image: linear-gradient(var(--degree),var(--img-gradient));
        mask-image:  linear-gradient(var(--degree),var(--img-gradient));
    }
    .imagen-gradient-xl-left-right{
        --degree:90deg;
        -webkit-mask-image: linear-gradient(var(--degree),var(--img-gradient));
        mask-image:  linear-gradient(var(--degree),var(--img-gradient));
    }
    .imagen-gradient-xl-right-left{
        --degree:-90deg;
        -webkit-mask-image: linear-gradient(var(--degree),var(--img-gradient));
        mask-image:  linear-gradient(var(--degree),var(--img-gradient));
    }
}
/******************
        Sucursales tabla 
*******************/
/* Estilos para la tabla estática */
.bs-table-sucursal-static table {
    width: 100%;
    max-width: 800px;
    margin: 20px auto;
    border-collapse: separate;
    border-spacing: 0;
    font-size: 14px;
    text-align: left;
    background-color: #ffffff;
    border: 1px solid rgba(0, 0, 0, 0.1); 
    border-radius: 8px;
    overflow: hidden;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
}

/* Estilos para la tabla en el acordeón */
.bs-table-sucursal-accordion table {
    width: 100%;
    margin: 1px auto;
    border-collapse: separate;
    border-spacing: 0;
    font-size: 14px;
    text-align: left;
    background-color: #ffffff;
    border: 1px solid rgb(248 249 250);
    border-radius: 8px;
    overflow: hidden;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

/* Encabezado de la tabla */
.bs-table-sucursal-static thead, .bs-table-sucursal-accordion thead {
    background-color: #f8f9fa; 
    color: #333;
}

.bs-table-sucursal-static th, .bs-table-sucursal-accordion th {
    padding: 6px;
    border-bottom: 1px solid rgba(0, 0, 0, 0.1);
    text-transform: capitalize;
    font-weight: bold;
}

/* Filas de la tabla */
.bs-table-sucursal-static td, .bs-table-sucursal-accordion td {
    padding: 12px;
    border-bottom: 1px solid rgba(0, 0, 0, 0.05); /* Borde sutil */
}

.bs-table-sucursal-static tbody tr:last-child td, .bs-table-sucursal-accordion tbody tr:last-child td {
    border-bottom: none;
}

.bs-table-sucursal-static tbody tr:hover, .bs-table-sucursal-accordion tbody tr:hover {
    background-color: #f5f5f5; /* Efecto hover */
    transition: background-color 0.3s ease;
}

/* Estilos para el acordeón */
.stock-accordion .stock-card {
    border: 1px solid rgba(0, 0, 0, 0.1);
    border-radius: 7px;
    margin: 8px 0;
    width: 70%;
}

.stock-card-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 10px 15px;
    background-color: #f8f9fa;
    border-bottom: 1px solid rgba(0, 0, 0, 0.1);
    font-weight: bold;
    color: #333;
}

.stock-accordion-title {
    margin: 0;
    font-size: 16px;
    font-weight: bold;
}

.stock-accordion-btn {
    background-color: var(--primary-color);
    border: 2px solid var(--primary-color);
    border-radius: 50%;
    color: var(--primary-contrast);
    font-size: 18px;
    cursor: pointer;
    width: 30px;
    height: 30px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.3s ease;
}

.stock-accordion-btn:hover {
    background-color: var(--primary-hover-color);
    border-color: var(--primary-hover-color);
    color: white;
}

.stock-toggle-icon {
    font-size: 18px;
}

.collapse.show + .stock-card-header .stock-accordion-btn .stock-toggle-icon {
    content: "-";
}

.stock-card-body {
    flex: 1 1 auto;
    min-height: 1px;
    padding: 0px;
}

.stock-accordion-body {
    padding: 10px 20px;
    font-size: 14px;
    background-color: #ffffff;
    color: #333;
}
/************************************
Chat Widget
*************************************/
.chat-widget .dropdown-toggle::after {
    display: none; /* Oculta el dropdown-toggle solo dentro del widget */
}

.chat-widget {
    --box-shadow-widget: rgba(50, 50, 93, 0.25) 0px 6px 12px -2px, rgba(0, 0, 0, 0.3) 0px 3px 7px -3px;
    position: fixed;
    bottom: 100px;
    z-index: 1000;
    right: 10px; /* Por defecto, ajusta a la izquierda si se requiere */
}

.chat-widget .chat-widget__close-icon { display: none; }
.chat-widget.show .chat-widget__close-icon { display: inline; }
.chat-widget .chat-widget__chat-icon { display: inline; }
.chat-widget.show .chat-widget__chat-icon { display: none; }

.chat-widget .dropdown-menu.show {
    box-shadow: var(--box-shadow-widget);
    width: auto;
}

.chat-widget__btn {
    background: var(--primary-color);
    box-shadow: var(--box-shadow-widget);
    color: white;
    width: 1.5em;
    height: 1.5em;
    font-size: 36px;
    display: flex;
    justify-content: center;
    align-items: center;
    border-radius: 100px;
    border: solid 1px rgba(255, 255, 255, 0.3); 

}
.chat-widget__btn:hover {
    background: var(--primary-hover-color);
    transition: 0.3s;
    box-shadow: 0px 6px 12px rgba(0, 0, 0, 0.2), 0px 2px 6px rgba(0, 0, 0, 0.1); 

}
.chat-widget__content {
    background: white;
    width: 100%;
    min-width: 260px;
    display: grid;
    grid-template-columns: 48px 1fr;
    gap: 10px;
    padding: 10px;
}

.chat-widget__img {
    width: 48px;
    height: 48px;
    object-fit: contain;
}

.chat-widget__message {
    box-sizing: border-box;
    border: silver 1px solid;
    padding: 6px;
    border-radius: var(--default-border-radius);
}

.chat-widget__chat-list {
    grid-column: 2 / 3;
    display: flex;
    flex-wrap: wrap;
}

.chat-widget__whatsapp,
.chat-widget__facebook {
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 1.5rem;
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 100px;
}

.chat-widget__whatsapp {
    background: linear-gradient(0deg, rgb(32,176,56) 0%, rgb(96,214,106) 100%);
    color: white;
    margin-left: 6px;
}

.chat-widget__whatsapp:hover {
    color: white;
    outline: 4px rgba(96,214,106, 0.6) solid;
}

.chat-widget__facebook {
    background: linear-gradient(0deg, rgba(0,98,224,1) 0%, rgba(25,175,255,1) 100%);
    color: white;
    margin-left: 4px;
}

.chat-widget__facebook:hover {
    color: white;
    outline: 4px rgba(25,175,255, 0.6) solid;
}

@media screen and (min-width: 768px) {
    .chat-widget { bottom: 30%; }
}
/*********************************
formulario
**********************************/
.texto-form {
    font-size: 10px;
}

/* Estilos base para el jumbotron de mensaje */
.jumbotron.formulario-mensaje-personalizado {
    border: 1px solid #e1e5ec;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
    background-color: #ffffff;
    padding: 1.5rem;
    border-radius: 8px;
    margin-bottom: 1.5rem;
    font-family: 'Roboto', sans-serif;
    display: flex;
    flex-direction: column;
    justify-content: center;
    height: 200px;
}

/* Estilos específicos para mensajes de error */
.jumbotron.formulario-mensaje-error {
    background-color: #fef2f2;
    border-color: #f5c6cb;
    color: #721c24;
}

/* Estilos específicos para mensajes de éxito */
.jumbotron.formulario-mensaje-exito {
    background-color: #ffffff;
    border-color: #c3e6cb;
    color: #155724;
    box-shadow: 0 4px 15px rgba(40, 167, 69, 0.1);
}

/* Estilo de los encabezados dentro del mensaje */
.jumbotron.formulario-mensaje-personalizado h1.display-4 {
    font-size: 1.8rem;
    font-weight: var(--font-light);
    margin-bottom: 0.5rem;
    color: var(--body-txt-default-color);
}

.jumbotron.formulario-mensaje-personalizado p.lead {
    font-size: 1rem;
    margin-bottom: 0.5rem;
    color: #555;
}

/* Media Query para pantallas pequeñas */
@media (max-width: 768px) {
    .jumbotron.formulario-mensaje-personalizado {
        padding: 1rem;
        height: auto;
    }

    .jumbotron.formulario-mensaje-personalizado h1.display-4 {
        font-size: 1.6rem;
    }

    .jumbotron.formulario-mensaje-personalizado p.lead {
        font-size: 0.9rem;
    }
}