
/* GENERAL */

body {
    font-family: 'Open Sans', sans-serif;
    overflow-x: hidden;
}

body.blur .blur {
    filter: blur(1.5px);
}

a:hover, a:focus  { 
    color: inherit;
}
a.noa {
    color: inherit;
    text-decoration: none;
}

small, .small {
    font-size: 13px !important;
}
@media only screen and (min-width: 1024px) {
    small, .small {
        font-size: 14px !important;
    }
}

.logo {
    pointer-events: none;
    max-width: 210px;
    height: 35px;

}

@media only screen and (min-width: 375px) {
    .logo {
        pointer-events: none;
        max-width: 240px;
    }
}

/* HEADER */
@media only screen and (max-width: 341px) {
    .social-break-fix {
        display:block !important;
    }
    .social { font-size: 12px !important; }
    .d-smxs-none { display:none !important; }
}

/* BOOTSTRAP OVERWRITE */

.bg-light {
    background-color: #F5F5F5 !important;
}
.bg-extra-light {
    background-color: #FCFCFC !important;
}
a {
    color: #3483FA;
}
.border, .border-bottom, .border-top, .border-start, .border-end {
    border-color: #F5F5F5 !important;
}
.fw-semibold {
    font-weight: 600 !important;
}
.cursor-pointer {
    cursor: pointer;
}
.text-rs {
    color: #DA064A !important;
}
.text-rs svg,
.text-rs path {
    fill: #DA064A !important;
}
.text-success:not(.bs) {
    color: #61C554 !important;
}
.text-info:not(.bs) {
    color: #3483FA !important;
}
.text-secondary:not(.bs) {
    color: #bbb !important;
}
.btn:not(.bs) {
    border-radius: 0px;
}
.btn-group {
    width: 100%;
}
.btn-group .btn:has(> i) { 
    width: 56px;
    max-width: 56px;
    padding-left: 0px;
    padding-right: 0px;
}
.btn-rs {
    color: #fff !important;
    background: linear-gradient(92deg, #81256B 0%, #E30347 100%);
    border: 0px;
    font-weight: 500 !important;
}
.btn-rs:hover {
    color: #fff !important;
    background: linear-gradient(92deg, #742061 0%, #bf023b 100%);
    border-color: #E30347;
}
.btn-rs-primary {
    color: #FFF !important;
    background: #E00548;
    border: 0px;
    font-weight: 500 !important;
    border-color: #E30347;
    box-shadow: 0px 3px 13px #e3034676;
    border-radius: 5px !important;
}
.btn-rs-secondary {
    color: #898989 !important;
    background: #FFF;
    border: 0px;
    font-weight: 500 !important;
    border-color: #E30347;
    box-shadow: 0px 2px 6px #00000056;
    border-radius: 5px !important;
}
.btn-rs-primary:hover {
    color: #fff !important;
    background: #E30347;
}
.btn-light-rs {
    color: #9c9c9c !important;
    background-color: #f5f5f5 !important;
    border-color: #ebebeb !important;
    font-weight: 500;
}
.btn-outline-rs {
    color: #DA064A !important;
    background-color: #fff;
    border-color: #DA064A  !important;
}
.btn-outline-rs:hover {
    color: #fff !important;
    background-color: #DA064A;
    border-color: #DA064A;
}
.btn-success:not(.bs) {
    color: #fff;
    background-color: #61C554 !important;
    border-color: #61C554;
}
.btn-success:not(.bs):hover {
    color: #fff !important;
    background-color: #157347 !important;
    border-color: #157347;
}
.btn-outline-success:not(.bs) {
    color: #61C554;
    background-color: #fff;
    border-color: #61C554;
}
.btn-outline-success:not(.bs):hover {
    color: #FFF !important;
    background-color: #61C554;
    border-color: #61C554;
}
.btn-primary:not(.bs) {
    color: #fff !important;
    background-color: #3483FA !important;
    border-color: #3483FA;
}
.btn-primary:not(.bs):hover {
    color: #fff !important;
    background-color: #0b5ed7 !important;
    border-color: #0b5ed7;
}
.btn-outline-primary:not(.bs) {
    color: #3483FA;
    background-color: #fff;
    border-color: #3483FA;
}
.btn-outline-primary:not(.bs):hover {
    color: #FFF !important;
    background-color: #3483FA;
    border-color: #3483FA
}
.btn-secondary:not(.bs) {
    color: #fff !important;
    background-color: #888 !important;
    border-color: #888;
}
.btn-secondary:not(.bs):hover {
    color: #fff !important;
    background-color: #212529 !important;
    border-color: #212529;
}
.btn-outline-secondary:not(.bs) {
    color: #888;
    background-color: #fff;
    border-color: #888;
}
.btn-outline-secondary:not(.bs):hover {
    color: #FFF !important;
    background-color: #888;
    border-color: #888;
}
.btn-dark:not(.bs) {
    color: #fff !important;
    background-color: #000 !important;
    border-color: #000;
}
.btn-dark:not(.bs):hover {
    color: #fff !important;
    background-color: #000 !important;
    border-color: #000;
}
.btn-outline-dark:not(.bs) {
    color: #000;
    background-color: #fff;
    border-color: #000;
}
.btn-outline-dark:not(.bs):hover {
    color: #FFF !important;
    background-color: #000;
    border-color: #000;
}

label.radio-rs:has(input:checked) {
    border-left: 4px solid #a7185d !important;
}

label.radio-rs.br:has(input:checked) {
    border-right: 4px solid #a7185d !important;
    border-left: 0px !important;
}

label.radio-rs input:checked {
    background-color: #a7185d !important;
}
.bg-dark {
    background-color: #000 !important;
}

/* CARRITO */

#cart {
    position: relative;
}
#cart-items {
    font-size: 10px !important;
    position: absolute;
    top: -8px;
    right: -7px;
    padding: 3px 5px !important;
    border-radius: 10px !important;
    background-color: #C90B4F !important;
}

.cart-add {
    display: block;
    transform: translate(0%, 0%);
    animation: rotateAnimation 0.3s ease-in-out 2;
}

@keyframes rotateAnimation {
  0% {
    transform: translate(0%, 0%) rotate(0deg);
  }
  20% {
    transform: translate(15%, 0%) rotate(-15deg);
  }
  80% {
    transform: translate(-15%, 0%) rotate(15deg);
  }
  100% {
    transform: translate(0%, 0%) rotate(0deg);
  }
}

/* PRESUPUESTO (partials/presupuesto) */

.productos > :last-child {
    border-bottom: none !important;
    margin-bottom: 12px;
}
.productos > :first-child {
    margin-top: 8px;
}
.flechas-y { 
    display: inline-block;
    margin-top: -2px;
    width: 9px !important;
    max-height: 19px !important;
}
.flechas-x { 
    display: inline-block;
    margin-top: -3px;
    width: 23px !important;
    max-height: 11px !important;
}


/* FOOTER */

footer {
    background: #F5F5F5;
}
footer p {
    color: #AAA;
    font-weight: 300;
    margin: 10px 0;
}
footer a {
    text-decoration: none;
    color: #3E3E3E;
}
footer .logo {
    width: 220px;
}
footer .fab {
    font-size: 16px;
    margin-right: 10px;
}

/* VARIANTES DESKTOP */
@media only screen and (min-width:981px) {
    footer {
        background-image: url('/2021/img/fondo_footer_desktop.jpg');
    }
    
    .tipo-icon { height:38px; }

}

/* VARIANTES MOBILE */
@media only screen and (max-width:980px) {
    footer {
        background-image: url('/2021/img/fondo_footer_mobile.jpg');
    }
}

/* Navegacion */
.contenedor-nav {
    width: 60%;
}
.contenedor-nav ul.nav { 
    justify-content: space-evenly; 
}
.contenedor-nav ul.dropdown-menu li {
    min-width: 300px;
    min-height: 58px;
    align-items: center;
}
.contenedor-nav .dropdown-menu {
    z-index: 1100 !important;
}

.contenedor-nav .dropdown-menu .nav-item:focus, 
.contenedor-nav .dropdown-menu .nav-item:hover {
    color: #1e2125;
    background-color: #e9ecef; 
}
.contenedor-nav .dropdown-menu .nav-item {
   background-color:#fff;
   border: 0;
}
.contenedor-nav .dropdown-menu .nav-item a:hover {
    background-color:#FFF;
}
.contenedor-nav .dropdown-menu .nav-item {
    border-left: solid 4px transparent;
}
.contenedor-nav .dropdown-menu .nav-item:hover {
    border-left: solid 4px #e6521c;
    background-color:#fff;
}
.contenedor-nav ul.nav li a * {
    display: inline-block;
}
.navbar-light .navbar-toggler {
    border: none;
}

/* Barra de valor */
.barra-valor {
    background-color: #F5F5F5;
}
.barra-valor .carousel-item > div {
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

/* breadcum sitio tela y familia */
.breadcrumb-box {
    background-color: #FFF;
}
.breadcrumb-box .btn-volver {
    font-size: .9em;
    color: #CECECE;
    text-decoration: none;
    margin-top:2px;
}
.breadcrumb-box .breadcrumb {
    margin-bottom: 0;
    padding: .7rem 0;
}
.breadcrumb-box .breadcrumb-item.active {
    color: #000;
    font-size: .9rem;
}
.tipo-icon { margin-right:5px; }


/* hack para evitar que el webchat de botmaker bloquee por superposicion objetos de fondo */
body > div[style*="height: 110px;"] {
    height: 60px !important;
}

/* whatsapp widget */
/* Widget container */
.whatsapp-widget {
    position: fixed;
    bottom: 20px;
    right: 20px;
    z-index: 2000;
}

/* Bubble button */
.whatsapp-bubble {
    width: 60px;
    height: 60px;
    background-color: #61C554;
    border-radius: 50%;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
    display: flex;
    justify-content: center;
    align-items: center;
    cursor: pointer;
    animation: bounce 1.5s infinite;
}

.whatsapp-bubble img {
    width: 35px;
    height: 35px;
}

/* Chat box */
.chat-box {
    position: absolute;
    bottom: 80px;
    right: 0;
    width: 300px;
    background: #fff;
    border: 1px solid #ddd;
    border-radius: 8px;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
    display: none;
    flex-direction: column;
}

.chat-header {
    background-color: #61C554;
    color: white;
    padding: 10px;
    border-radius: 8px 8px 0 0;
    font-size: 16px;
    font-weight: bold;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.chat-header .close-btn {
    background: none;
    border: none;
    color: white;
    font-size: 16px;
    cursor: pointer;
}

.chat-body {
    padding: 10px;
    font-size: 14px;
}

.chat-footer {
    display: flex;
    align-items: center;
    padding: 10px;
    border-top: 1px solid #ddd;
}

.chat-footer input {
    flex: 1;
    padding: 8px;
    border: 1px solid #ddd;
    border-radius: 4px;
    font-size: 14px;
}

.chat-footer button {
    background-color: #61C554;
    color: white;
    border: none;
    border-radius: 4px;
    padding: 8px 12px;
    margin-left: 8px;
    cursor: pointer;
    font-size: 14px;
}

.chat-footer button:hover {
    background-color: #20B857;
}

/* Bounce animation */
@keyframes bounce {
    0%, 100% {
    transform: translateY(0);
    }
    50% {
    transform: translateY(-10px);
    }
}
/* End whatsapp widget */