 
/*-------------------------------------
		1.General css (Reset code)
--------------------------------------*/
@import url('https://fonts.googleapis.com/css2?family=Inter:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&family=Nunito+Sans:ital,opsz,wght@0,6..12,200..1000;1,6..12,200..1000&family=Nunito:ital,wght@0,200..1000;1,200..1000&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&family=Quicksand:wght@300..700&display=swap');
*{
    padding: 0;
    margin: 0;
}

*{
	-webkit-box-sizing:border-box;
	-moz-box-sizing:border-box;
	-o-box-sizing:border-box;
	-ms-box-sizing:border-box;
	box-sizing:border-box;
}
body{
	font-family: 'Roboto', sans-serif;
	font-size:16px;
	color:#a09e9c;
	background: #fafafa; 
    max-width:1920px;
    margin:0 auto;
	overflow-x:hidden;
} 

a,a:active,a:focus {
	display:inline-block;
	text-decoration:none;  
}

#relatedRoot h2{
  padding-bottom: 30px;
}

a:hover{
    text-decoration: none;
}

h1,h2,h3,h4,h5,h6 { 
	margin: 0;
	color:#5f5b57;
    font-size: 18px;
    font-weight: 500;
}
p {
	margin: 0;
	color:#a09e9c;
	font-size:16px;
    line-height: 1.8;
}
img{border:none;max-width:100%; height:auto;}
ul{
	padding: 0;
    margin: 0 auto;
    list-style: none;
}
ul li {
	list-style: none;
	
}
select,input,textarea,button{box-shadow:none;outline:0!important;}
button {background: transparent;border: 0;}

html,body{height: 100%;}

[placeholder]:focus::-webkit-input-placeholder {
  -webkit-transition: opacity 0.3s 0.3s ease; 
  -moz-transition: opacity 0.3s 0.3s ease; 
  -ms-transition: opacity 0.3s 0.3s ease; 
  -o-transition: opacity 0.3s 0.3s ease; 
  transition: opacity 0.3s 0.3s ease; 
  opacity: 0;
}

/* section-header */
.section-header{
    position: relative;
    text-align: center;
}
.section-header h2{
    font-size: 24px;
    font-weight: 500;
}
.section-header h2 span{text-transform: lowercase;}
 
/* section-header */

/*=============Style css=========*/

/*-------------------------------------
        2. Top-area
--------------------------------------*/
 /*-------------------------------------
        NAVBAR (limpio y optimizado)
--------------------------------------*/

nav.navbar.bootsnav {
  background: transparent;
  border: none;
  box-shadow: 0 4px 6px rgba(0,0,0,0.1);
  position: relative;
  z-index: 10;
}

/* sticky */
.wrap-sticky nav.navbar.bootsnav.sticked {
  background: #fff;
  box-shadow: 0 2px 5px rgba(0,0,0,.2);
}

/* logo */
.navbar-header a.navbar-brand {
  display: inline-flex;
  align-items: center;
  color: #616060;
  font-size: 24px;
  font-weight: 500;
  text-transform: capitalize;
  height: 80px;
  padding: 0;
}
.navbar-brand img {
  height: 60px;
  margin: 0;
}

/* menú principal */
nav.navbar.bootsnav ul.nav > li > a {
  color: #616060;
  font-size: 14px;
  font-weight: 500;
  text-transform: capitalize;
  transition: color .3s linear;
  padding: 0 15px;
  line-height: 80px;
}
nav.navbar.bootsnav ul.nav > li > a:hover,
nav.navbar.bootsnav ul.nav > li > a:focus,
nav.navbar.bootsnav ul.nav > li.active > a {
  color: #e92e2e;
}

/* íconos derecha */
.attr-nav {
  position: relative;
  top: 0;
}
.attr-nav > ul > li > a {
  color: #616060;
  font-size: 18px;
  font-weight: 500;
  padding: 0 12px;
  height: 80px;
  line-height: 80px;
  display: inline-flex;
  align-items: center;
}
.attr-nav > ul > li > a:hover { color: #e92e2e; }

 

/* scroll menú móvil */
@media (min-width: 992px) {
  .menu-ui-design {
    overflow: visible;
    height: auto;
  }
}

/* botón hamburguesa */
nav.navbar.bootsnav .navbar-toggle {
  background: transparent;
  border: 1px solid #e92e2e;
  padding: 10px;
}
nav.navbar.bootsnav .navbar-toggle i {
  color: #e92e2e;
}

/* ========== NAVBAR ALIGN FIX (mínimo) ========== */

/* Desktop */
@media (min-width: 992px) {
  /* Quita el empuje de los íconos */
  .attr-nav { top: 0 !important; }

  /* Logo: sin padding raro y centrado verticalmente */
  .navbar-header a.navbar-brand {
    padding: 0 !important;
    height: 80px;                /* alto del navbar */
    line-height: 80px;
    display: inline-flex;
    align-items: center;
  }
  .navbar-brand img {
    margin: 0 !important;        /* antes tenía -21px */
    display: block;
  }

  /* Menú (Inicio, Destacados, etc.) centrado vertical */
  nav.navbar.bootsnav ul.nav > li > a {
    padding: 0 15px;             /* solo lateral */
    line-height: 80px;           /* centra el texto */
  }

  /* Íconos de la derecha alineados */
  .attr-nav > ul > li > a {
    padding: 0 12px !important;  /* antes tenía 44px vertical */
    height: 80px;
    line-height: 80px;
    display: inline-flex;
    align-items: center;
  }

  /* Evita scroll innecesario del menú en desktop */
  .menu-ui-design {
    overflow: visible;
    height: auto;
  }
}
 
.packages-price p{
    position: relative;
    color: #616060;
    font-size: 16px;
    font-weight: 500;
}
.packages-price del,.packages-price span {
    color: #bbb9b9;
    font-size: 16px;
    font-weight: 500;
}
.packages-price del{margin-left: 10px;}
 

 .welcome-hero {
    position: relative;
    z-index: 1;
    background: #f8f9fd;
}
.header-area{position: absolute;top:0;left:0;width: 100%;z-index: 99;}
.single-slide-item{
    position: relative;
    background-size: cover;
    background-position: center;
}
.single-slide-item.slide1{background:transparent;}
.single-slide-item.slide2{background:transparent;}
.single-slide-item.slide3{background:transparent;}

/*welcome-hero-content*/
.single-welcome-hero{
    display: flex;
    align-items: center;
    flex-direction: column;
    justify-content: center;
    height: 920px;
}
.welcome-hero-txt h4 {
    color: #998d80;
    font-size: 24px;
    font-weight: 400;
}
.welcome-hero-txt h2 {
    font-size: 35px;
    color: #616060;
    font-weight: 6500;
    margin: 20px 0 22px;
}
.welcome-hero-txt p{margin: 35px 0 20px;}
.welcome-hero-txt .packages-price p {
    margin: 0;
    padding-left: 35px;
}
.packages-price p:before {
    position:  absolute;
    content:  "";
    width:  25px;
    height:  1px;
    background:  #616060;
    top: 45%;
    left: 0;
}
.btn-cart.welcome-add-cart,.btn-cart.welcome-add-cart.welcome-more-info {
    width: 170px;
    height: 60px;
    line-height: 60px;
    border-radius: 1px;
    font-size: 16px;
    font-weight: 500;
    display: inline-block;
    margin-top: 34px;
    -webkit-transition: 0.3s linear; 
    -moz-transition: 0.3s linear; 
    -ms-transition: 0.3s linear; 
    -o-transition: 0.3s linear; 
    transition: 0.3s linear;
}
.btn-cart.welcome-add-cart span {text-transform:  lowercase;}
.btn-cart.welcome-add-cart span.lnr.lnr-plus-circle {
    position:  relative;
    top: 0px;
    font-size: 16px;
    margin-right: 5px;
}
.btn-cart.welcome-add-cart.welcome-more-info{
    color: #e92e2e;
    background: transparent;
    border:transparent;
}
.btn-cart.welcome-add-cart:hover{
    color: #e92e2e;
    background: transparent;
    border: 1px solid #e92e2e;
}
.btn-cart.welcome-add-cart.welcome-more-info:hover{
    background: transparent;
    color: #e92e2e;
    border: 1px solid #e92e2e;
}
/*welcome-hero-content*/

/* .carousel-indicators */
.carousel-indicators {bottom: 4.5%;}
.carousel-indicators li {
    position: relative;
    display: inline-block;
    width: 8px;
    height: 8px;
    margin: 12px 10px 0 0;
    text-indent: -999px;
    cursor: pointer;
    background-color: transparent;
    border: 1px solid #e92e2e;
    border-radius:50%;
}
.carousel-indicators li>span.small-circle{
    position: absolute;
    top: -1px;
    left: -1px;
    display: inline-block;
    width: 8px;
    height: 8px;
    background-color:transparent;
    border: 1px solid #e92e2e;
    border-radius:50%;
}
.carousel-indicators li.active>span.small-circle{
    top: 3px;
    left: 3px;
    background-color: #e92e2e;
}
.carousel-indicators .active {
    position: relative;
    top: 4px;
    width: 16px;
    height: 16px;
    margin:12px 10px 0 0;
    background-color: transparent;
    border:1px solid #e92e2e;
}
/* .carousel-indicators */

/* .carousel-fade */
.carousel-fade .carousel-inner .item {
  -webkit-transition-property: opacity;
  transition-property: opacity;
}
.carousel-fade .carousel-inner .item,
.carousel-fade .carousel-inner .active.left,
.carousel-fade .carousel-inner .active.right {
  opacity: 0;
}
.carousel-fade .carousel-inner .active,
.carousel-fade .carousel-inner .next.left,
.carousel-fade .carousel-inner .prev.right {
  opacity: 1;
}
.carousel-fade .carousel-inner .next,
.carousel-fade .carousel-inner .prev,
.carousel-fade .carousel-inner .active.left,
.carousel-fade .carousel-inner .active.right {
  left: 0;
  -webkit-transform: translate3d(0, 0, 0);
          transform: translate3d(0, 0, 0);
}
.carousel-fade .carousel-control {
  z-index: 2;
}
/* .carousel-fade */
 

/*-------------------------------------
        5. New-arrivals 
--------------------------------------*/
.new-arrivals {padding:85px 0 70px;}
.new-arrivals-content{margin-top: 80px;}

.single-new-arrival{margin-bottom: 50px;text-align: center;}
.single-new-arrival-bg {
    position: relative;
    min-height: 310px;
    background: #f8f9fc;
    display: flex;
    align-items: center;
    justify-content:center;
    overflow:hidden;
}
.single-new-arrival-bg img{
    width:160px;
    height:160px;
    -webkit-transition: .3s linear;
    -moz-transition: .3s linear;
    -ms-transition: .3s linear;
    -o-transition: .3s linear;
    transition: .3s linear;
}
.single-new-arrival-bg:hover  img{
    -webkit-transform:scale(1.3);
    -moz-transform:scale(1.3);
    -ms-transform:scale(1.3);
    -o-transform:scale(1.3);
    transform:scale(1.3);
}
.single-new-arrival-bg-overlay{
    position: absolute;
    content: "";
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    background: rgba(106, 119, 129, 0);
    -webkit-transform:scale(0);
    -moz-transform:scale(0);
    -ms-transform:scale(0);
    -o-transform:scale(0);
    transform:scale(0);
    -webkit-transition: .3s linear;
    -moz-transition: .3s linear;
    -ms-transition: .3s linear;
    -o-transition: .3s linear;
    transition: .3s linear;
}
.single-new-arrival-bg:hover .single-new-arrival-bg-overlay{
    -webkit-transform:scale(1);
    -moz-transform:scale(1);
    -ms-transform:scale(1);
    -o-transform:scale(1);
    transform:scale(1);
}
.sale {
    position: absolute;
    top: 10px;
    right: 0;
    width: 60px;
    height: 30px;
    line-height: 30px;
    text-align: center;
}
.sale p{color: #fff;font-weight: 500;font-size:14px;line-height: 2.2;}

.sale.bg-1{background: #d84c4c;
border-top-left-radius: 10px;
border-bottom-left-radius: 10px;
}
.sale.bg-2{background: #d84c4c;
border-top-left-radius: 10px;
border-bottom-left-radius: 10px;
}

.new-arrival-cart {
    position: absolute;
    bottom: -14px;
    z-index: 0;
    left: 0;
    width: 100%;
    height: 35px;
    background: #33383c;
    -webkit-transition: .3s linear;
    -moz-transition: .3s linear;
    -ms-transition: .3s linear;
    -o-transition: .3s linear;
    transition: .3s linear;
    opacity:0;
    visibility:hidden;
}
.new-arrival-cart p {
    float: left;
    margin-left: 20px;
    color: #fff;
    font-size: 12px;
    line-height: 3;
}
.new-arrival-cart p a{color: #fff;font-weight: 400;font-size: 12px;}
.new-arrival-cart p span.lnr.lnr-cart {margin-right: 10px;}
.new-arrival-cart p span{text-transform: lowercase;}
p.arrival-review span {margin-right: 15px;}
.single-new-arrival-bg:hover .new-arrival-cart {
    opacity:1;
    visibility:visible;
    bottom:0px;
}
.single-new-arrival  h4 a{
    color:#5f5b57;
    font-size:16px;
    font-weight:500;
    margin:26px 0 12px;
}
.arrival-product-price{
    color:#5f5b57;
    font-size: 16px;
    font-weight: 400;
}
.single-new-arrival:hover h4 a{color:#e92e2e;}

/*Wpp*/
.btn-wpp {
  position: fixed;
  width: 40px;
  height: 40px;
  bottom: 80px;
  right: 30px;
  background-color: #25d366;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0px 4px 6px rgba(0,0,0,0.3);
  z-index: 1000;
  transition: transform 0.3s ease;
}

.btn-wpp img {
  width: 25px;
  height: 25px;
}
 


/*-------------------------------------
        6. Sofa-coolection
--------------------------------------*/
#sofa-collection {
    position: relative;
    z-index: -1;
}
.sofa-collection{
    position: relative;
    display: flex;
    align-items: center;
    height: 600px;
    background-position: center;
    background-size: cover;
}
.sofa-collection.collectionbg1{background: url(../images/collection/table-banner.png)no-repeat;
background-size: cover;}
.sofa-collection.collectionbg2{background: url(../images/collection/table-banner.png)no-repeat;background-size: cover;}

.sofa-collection:before,.sofa-collection:after {
    position: absolute;
    content: "";
    top: 0;
    left: 0;
    height: 100%;
    width: 33.4%;
    background: rgba(51,59,62,.95);
}
.sofa-collection:after {
    background: rgba(106,119,129,.3);
    left: auto;
    right: 0;
    width: 66.6%;
}
.sofa-collection-txt {
    position: relative;
    max-width: 596px;
    z-index: 1;
}
.sofa-collection-txt h2 {
    font-size: 30px;
    color: #fff;
    font-weight: 700;
}
.sofa-collection-txt h4 {
    font-size: 16px;
    color: #fff;
    font-weight: 700;
}
.sofa-collection-txt h4 span{
font-weight: bold;}

.prc{
    font-size: 20px;
    color: whitesmoke;
}

.sofa-collection-txt p {
    font-size: 16px;
    color: #fff;
    font-weight: 500;
    margin: 25px 0 10px;
}
.sofa-collection-price { margin-bottom: 3px;}

.btn-cart.welcome-add-cart.sofa-collection-btn{height: 50px;line-height: 50px;}

.map-container {
  width: 100%;
  max-width: 100%;
  margin: 0;
}
iframe {
  display: block;
}

/*-------------------------------------
        7. Features
--------------------------------------*/
.feature {padding:110px 0 70px;}

.feature-content,.blog-content{margin-top: 75px;}
.single-feature,.single-blog {margin-bottom:30px;}

/*.single-feature-txt */
.single-feature-txt,.single-blog-txt{margin-top: 25px;}
.single-feature-txt p i {
    color:  #efce4a;
    margin-left:  5px;
}
span.spacial-feature-icon i {color:  #a9a9a9;}
span.feature-review {margin-left: 10px;}
.single-feature-txt p {font-size: 14px;}
.single-feature-txt h3 a ,.single-blog-txt h2 a{
    color: #5f5b57;
    margin: 10px 0px 15px;
}
.single-feature-txt h5 {
    color:  #5f5b57;
    font-weight:  400;
}

.single-feature img{
    height: 300px;
    width: 250px;
}
/*contacto*/
/* ===== CONTACTO ===== */
#contacto {
    padding: 64px 20px 100px 20px;
    background: transparent;
}

.contacto-wrapper {
  max-width: 1100px;
  margin: 0 auto;
}

.contacto-titulo {
    text-align: center;
    font-size: 26px;
    margin-bottom: 40px;
    letter-spacing: 0.3px;
    color: #1111118a;
}

.contacto-grid {
    display: grid
;
    grid-template-columns: 1.1fr 0.9fr;
    gap: 110px;
    align-items: start;
}

.campo {
  display: grid;
  gap: 8px;
  margin-bottom: 16px;
}

.campo label {
  font-size: 14px;
  color: #333;
}

.campo input {
  height: 46px;
  padding: 0 14px;
  border-radius: 12px;
  border: 1px solid #e6e8ee;
  background: #fafbff;
  outline: none;
  transition: border-color .2s, box-shadow .2s;
  font-size: 15px;
}

.campo input:focus {
  border-color: #e92e2e;           /* verde suave */
  box-shadow: 0 0 0 4px rgba(36,160,111,.12);
  background: #fff;
}

.btn-enviar {
  margin-top: 6px;
  height: 35px;
  width: 120px;
  border: none;
  border-radius: 12px;
  background: #e92e2e;
  color: #fff;
  font-weight: 600;
  font-size: 13px;
  cursor: pointer; 
}

.contacto-info{
    margin-top: 27px;
}

.btn-enviar:hover {
  background: #e92e2ed2;
}
 
.sociales {
  display: flex;
  gap: 12px;
  margin-bottom: 16px;
}

.btn-social {
  width: 48px;
  height: 48px;
  display: grid;
  place-items: center;
  border-radius: 12px;
  border: 1px solid #e6e8ee;
  background: #fafbff;
  font-size: 20px;
  color: #222;
}

.datos {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 10px;
}

.datos li {
  display: grid;
  grid-template-columns: 22px 1fr;
  align-items: start;
  gap: 10px;
  color: #333;
  font-size: 15px;
}

.datos i {
  color: #e92e2e;
  margin-top: 2px;
}

.datos a { 
  text-decoration: none;
} 
/* Responsive */
@media (max-width: 900px) {
  .contacto-grid {
    grid-template-columns: 1fr;
  }
  .sociales {
    justify-content: flex-start;
  }
}

/*-------------------------------------
        9. Clients
--------------------------------------*/
.clients {
    background: #f8f9fd;
    display: flex;
    align-items: center;
    height: 220px;
}
.clients .item {text-align: center;}
/*-------------------------------------
        10. News-letter
--------------------------------------*/
.newsletter{padding:120px 0 75px;}

.hm-footer-widget{margin-bottom: 30px;}
.hm-foot-title h4 {
    font-size: 18px;
    font-weight: 700;
    margin-bottom: 45px;
}
.hm-foot-menu ul li a {
    color: #a09e9c;
    font-size: 16px;
    font-weight: 400;
    margin-bottom: 15px;
    -webkit-transition: .3s; 
    -moz-transition:.3s; 
    -ms-transition:.3s; 
    -o-transition:.3s;
    transition: .3s;
}
.hm-foot-menu ul li a:hover{
    color: #e92e2e;
    -webkit-transform:translateX(10px);
    -moz-transform:translateX(10px);
    -ms-transform:translateX(10px);
    -o-transform:translateX(10px);
    transform:translateX(10px);
}
.hm-foot-para p {
    font-size: 14px;
    text-transform: initial;
    margin-bottom: 25px;
}

/*hm-foot-email*/
.hm-foot-email{position: relative;}
.foot-email-box .form-control {
    background:#fff;
    display: block;
    padding:25px 15px;
    outline:0!important;
    box-shadow:0 5px 15px rgba(0,0,0,.2);
    border:0;
}
.foot-email-box input[type="text"]{
    font-size: 14px;
    color: #bcb7b2;
}
.foot-email-subscribe {
    position: absolute;
    top: 0;
    right: 0;
    width: 50px;
    height: 100%;
    background: transparent;
    color: #e92e2e;
    font-size: 22px;
    display: flex;
    align-items: center;
    justify-content: center;
}
.foot-email-box .form-control:hover{
    box-shadow:0 5px 15px rgba(0,0,0,.4);
}
/*hm-foot-email*/

.clients .item img{
    opacity: 0.4;
}
/*-------------------------------------
        11. Footer
--------------------------------------*/
.footer {
    background: #f8f9fd;
    display: flex;
    align-items: center;
    height: 154px;
}
.hm-footer-copyright p,.hm-footer-copyright p a {
    color: #a5adb3;
    font-size: 14px;
    font-weight: 400;
}
.footer-social a i {
    color: #a4aaaf;
    margin: 0 18px 24px 0;
    -webkit-transition: .3s; 
    -moz-transition:.3s; 
    -ms-transition:.3s; 
    -o-transition:.3s;
    transition: .3s;
}
.footer-social i:hover{color: #e92e2e;}

/*===============================
    Scroll Top
===============================*/
#scroll-Top  .return-to-top {
    position: fixed;
    right: 30px;
    bottom: 30px;
    display: none;
    width: 40px;
    line-height: 40px;
    height: 40px;
    text-align: center;
    font-size: 20px;
    cursor: pointer;
    color: #fff;
    background:#e92e2e;
	border:1px solid #e92e2e;
	border-radius:50%;
	-webkit-transition: .5s; 
	-moz-transition:.5s; 
	-ms-transition:.5s; 
	-o-transition:.5s;
    transition: .5s;
	z-index: 2;
}
#scroll-Top  .return-to-top:hover {
    background:#fff;
    color: #e92e2e;
	border:1px solid #e92e2e;
}

#scroll-Top  .return-to-top i{
    position:relative;
    bottom:0;

}

#scroll-Top  .return-to-top i{
    position: relative;
    animation-name: example;
    animation-direction: alternate;
    animation-iteration-count: infinite;
    animation-duration:1s;
}
@keyframes example {
    0%   {bottom:0px;}
    100%  {bottom:7px;}
}
/* Ocultar .navbar-brand cuando la pantalla sea 700px o menor */
@media (max-width: 700px) {
  .navbar-brand {
    display: none !important;
  }
}

/*chat personalizado*/
/* ===== FAB (burbuja) ===== */
  .chat-fab {
    position: fixed;
    font-size: 13px;
    font-weight: 500;
    color: white;
    right: 80px; bottom: 80px;
    width: 100px; height: 35px;
    border-radius: 10px;
    background: #d32525c4;
    display: grid; place-items: center;
    box-shadow: 0 8px 24px rgba(0,0,0,.25);
    cursor: pointer; z-index: 1000;
    transition: transform .2s ease;
  }
  .chat-fab:hover { transform: scale(1.06); }
  .chat-fab svg { width: 30px; height: 30px; fill: #fff; }

  /* ===== Ventana de chat ===== */
  .chatbox {
    position: fixed;
    right: 170px; bottom: 120px;
    width: 330px; max-height: 50vh;
    background: #fff; border-radius: 16px;
    box-shadow: 0 16px 40px rgba(0,0,0,.25);
    overflow: hidden; z-index: 1000;
    display: none; /* oculto por defecto */
    font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  }
  .chatbox.open { display: flex; flex-direction: column; }

  .chat-header {
    background: #1e2728; color: #fff;
    padding: 14px 16px; display: flex; align-items: center; gap: 10px;
  }
  .chat-header .title { font-weight: 600; font-size: 15px; }
  .chat-header .status {
    font-size: 12px; opacity: .8;
  }
  .chat-header .close-btn {
    margin-left: auto; background: transparent; border: none; color: #fff;
    font-size: 20px; cursor: pointer; line-height: 1;
  }

  .chat-body {
    padding: 12px; background: #f7f7f7;
    overflow-y: auto; flex: 1;
  }
  .msg { display: flex; margin: 8px 0; }
  .msg.bot { justify-content: flex-start; }
  .msg.user { justify-content: flex-end; }
  .bubble {
    max-width: 80%;
    padding: 10px 12px; border-radius: 12px;
    font-size: 14px; line-height: 1.35;
    box-shadow: 0 2px 6px rgba(0,0,0,.08);
    white-space: pre-wrap;
  }
  .bot .bubble { background: #fff; color: #111; border: 1px solid #eee; }
  .user .bubble { background: #d9fdd3; color: #111; }

  .quick-replies {
    display: flex; flex-wrap: wrap; gap: 8px; margin-top: 6px;
  }
  .chip {
    border: 1px solid #e3e3e3; background: #fff;
    padding: 6px 10px; border-radius: 999px; font-size: 12px; cursor: pointer;
  }
  .chip:hover { background: #f1f1f1; }

  .chat-footer {
    display: grid; grid-template-columns: 1fr auto;
    gap: 8px; padding: 10px; background: #fff; border-top: 1px solid #eee;
  }
  .chat-footer input[type="text"]{
    border: 1px solid #ddd; border-radius: 10px; padding: 10px 12px; font-size: 14px;
    outline: none;
  }
  .chat-footer button{
    background: #25d366; color: #fff; border: none; border-radius: 10px;
    padding: 10px 14px; font-weight: 600; cursor: pointer;
  }
  .chat-footer button:hover{ filter: brightness(.95); }

  /* Móvil: ancho completo */
  @media (max-width: 420px){
    .chatbox { right: 10px; left: 10px; width: auto; }
  }

  /* productos */
   /* Ajustes mínimos para la vista de producto (puedes mover a tu CSS) */
    .container--product{max-width:1100px;    margin: 200px auto;padding:0 1rem}
    .breadcrumb{font-size:.9rem;margin-bottom:1rem}
    .product{display:grid;grid-template-columns:1fr 1fr;gap:2rem}
    .product__gallery{display:flex;flex-direction:column;gap:1rem}
    .gallery__main img{width:100%;height:auto;object-fit:contain;border-radius:8px}
    .gallery__thumbs{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:.5rem}
    .gallery__thumbs img{width:100%;height:80px;object-fit:cover;border:2px solid transparent;border-radius:6px;cursor:pointer}
    .gallery__thumbs img.is-active{border-color:#0d6efd}
    .product__info h1{font-size:1.6rem;margin:0 0 .5rem}
    .price{display:flex;align-items:center;gap:.75rem;margin:.5rem 0 1rem}
    .price .current{font-size:1.6rem;font-weight:700}
    .price .old{text-decoration:line-through;opacity:.6}
    .badge-off{background:#e03131;color:#fff;border-radius:6px;padding:.1rem .5rem;font-size:.85rem}
    .meta{color:#666;font-size:.95rem;margin-bottom:1rem}
    .actions{display:flex;flex-wrap:wrap;gap:.5rem;margin:1rem 0}
    .btn-outline{display:inline-flex;align-items:center;gap:.5rem;padding:.6rem 1rem;border-radius:8px;border:1px solid #d62c2cd2; background-color: #d62c2cd2; color: white; font-weight: 500; font-size: 14px; margin-left: 10px; width: 80px; display: flex; align-items: center; justify-content: center;}
    .desc{margin-top:1rem;line-height:1.6}
    .related{margin-top:3rem}
    .grid-related{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:1rem}
    .card{display:block;overflow:hidden;text-decoration:none;color:inherit}
    .card__media img{width:100%;height:170px;object-fit:cover}
    .card__body{padding:.75rem}
    @media (max-width: 900px){ .product{grid-template-columns:1fr} }

  /*catalogo*/

  :root{
  --bg:#f8f9fb;
  --card-bg:#fff;
  --text:#111;
  --muted:#6b7280;
  --border:#e9eef5;              /* gris muy claro */
  --brand:#24a06f;               /* verde suave */
  --radius:14px;
  --shadow:0 10px 24px rgba(0,0,0,.05);
}

*{box-sizing:border-box}
body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,'Helvetica Neue',Arial,sans-serif;color:var(--text);background:var(--bg)}

.catalogo-container{
  max-width:1200px;
  margin: 70px auto;
  padding:24px 16px;
  display:grid;
  grid-template-columns: 1fr;    /* mobile */
  gap:24px;
}

/* ===== SIDEBAR (misma estructura HTML) ===== */ 
.sidebar{
  position: sticky;
  top: 96px;
  align-self: start;
  padding-right: 12px;
  color:#222;
  font-size:14px; 
}
.sidebar__title{
  font-size:18px;
  font-weight:600;
  margin:0 0 12px;
  color:#222;
}
.sidebar__title + .filtros{
  border-top:1px solid #eee;
  padding-top:12px;
}
.filtros{
  list-style:none;
  margin:0;
  padding:0;
  display:grid;
  gap:15px;
}
.filtro-btn{
  width:100%;
  display:block;
  text-align:left;
  padding:0;
  background:none;
  border:0;
  color:#333;
  cursor:pointer;
  font: inherit;
  line-height:1.4;
  transition: color .15s ease, text-decoration-color .15s ease;
}
.filtro-btn:hover{
  color:#111;
  text-decoration: underline;
  text-underline-offset: 2px;
}
.filtro-btn.is-active{
  font-weight:700; /* más negrita cuando activa */
  color:#111;
  text-decoration: none;
}

/* Indicador ▼ si tiene subcategorías */
.filtro-btn.has-sub{
  position:relative;
  padding-right:18px;
}
.filtro-btn.has-sub::after{
  content:"▾";
  position:absolute;
  right:0; top:0;
  transform: translateY(2px) rotate(0deg);
  transition: transform .15s ease;
  font-size:12px;
}
.filtro-btn.has-sub[aria-expanded="true"]::after{
  transform: translateY(2px) rotate(-180deg);
}

/* Subfiltros colapsables */
.subfiltros{
  margin:6px 0 8px 10px;
  padding-left:10px;
  border-left:2px solid #eee;
  list-style:none;
  display:grid;
  gap:8px;
  max-height:0;
  overflow:hidden;
  opacity:0;
  transition: max-height .25s ease, opacity .2s ease;
}
.subfiltros.open{
  max-height:400px;
  opacity:1;
}
.subfiltro-btn{
  display:block;
  padding:0;
  background:none;
  border:0;
  color:#555;
  text-align:left;
  cursor:pointer;
  font:inherit;
  line-height:1.4;
  transition: color .15s ease, text-decoration-color .15s ease;
}
.subfiltro-btn:hover{ color:#222; text-decoration:underline; }
.subfiltro-btn.is-active{ font-weight:600; color:#111; }

/* ===== Botón filtros y offcanvas móvil ===== */
.btn-filtros{
  display:none; 
  color:#444;
  font-weight:500;
  border:1px solid rgba(128, 128, 128, 0.219);
  padding:10px 16px;
  border-radius:4px;
  cursor:pointer;
  margin-bottom:12px;
}

/* Overlay para cerrar tocando afuera */
#overlay{
  display:none;
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.4);
  z-index:999;
}
#overlay.active{ display:block; }

/* Móvil: sidebar como panel deslizante */
@media (max-width:599px){
  .btn-filtros{ display:block; }
  .sidebar{
    position: fixed;
    top:0;
    left:-100%;
    width: 80%;
    max-width:320px;
    height:100%; 
    box-shadow: 4px 0 20px rgba(0,0,0,.2);
    padding:20px 16px;
    overflow-y:auto;
    z-index:1000;
    transition:left .3s ease;
  }
  .sidebar.open{ left:0; background: #fff;}

  .catalogo-container{
    display: grid;
    grid-template-columns: 100%;
    gap: 16px;
    margin: 130px auto;
  }
}

/* (Opcional) Cards: asegurar título en una línea con ... */
.card__title{
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Overlay detrás del sidebar */
#overlay{
  display:none;
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.4);
  z-index:999;
}
#overlay.active{ display:block; }


/* layout existente */
@media (min-width:900px){
  .catalogo-container{
    display: grid;
    grid-template-columns: 25% 75%;
    align-items:start;
    gap: 24px;
    margin: 130px auto;
  }
}

.listado__header{
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  gap:12px;
  margin-bottom:12px;
}
.listado__header h1{
  margin:0;
  font-size:clamp(20px,3.2vw,28px);
}
.count {
    color: var(--muted);
    font-size: 14px;
    display: flex;
    justify-content: end;
    padding-bottom: 15px;
}

/* Ajustes layout existentes */
@media (min-width:900px){
  .catalogo-container{
    grid-template-columns: 25% 75%;
    align-items:start;
    margin: 130px auto;
  }
}
/* Grilla de 4 por fila dentro del 75% */
.grid{
  display:grid;
  grid-template-columns: repeat(2, 1fr); /* mobile */
  gap:14px;
}
@media (min-width:680px){
  .grid{ grid-template-columns: repeat(3, 1fr); }
}
@media (min-width:1024px){
  .grid{ grid-template-columns: repeat(4, 1fr); } /* 4 por fila */
}
/* Cards */
.card {
  background: #fff; 
  overflow: hidden;
  display: flex;
  flex-direction: column;
  text-decoration: none;
  color: inherit;
  box-shadow: 0 2px 8px rgba(0,0,0,0.05);
  transition: transform 0.1s ease, box-shadow 0.2s ease;
}

.card:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 20px rgba(0,0,0,0.12);
}

/* Imagen cuadrada arriba */
.card__media {
  width: 100%;
  aspect-ratio: 1 / 1;
  background: #fff;
  display: grid;
  place-items: center;
  overflow: hidden;
}

.card__media img {
  width: 100%;
  height: 100%;
  object-fit: contain; /* evita recortes de la imagen */
  display: block;
}

/* Contenido */
.card__body {
  padding: 10px;
  display: grid; 
  text-align: center; /* centramos el texto como en la referencia */ 
}

.card__title {
  font-family: "Nunito", Helvetica, sans-serif;
  font-size: 14px; 
  margin: 0; 
  white-space: nowrap;        /* 👉 siempre una sola línea */
  overflow: hidden;           /* 👉 oculta lo que sobra */
  text-overflow: ellipsis;    /* 👉 agrega "..." */
  transition: all .2s 
ease-in-out;
    color: #222;
    outline: none !important; 
    line-height: 24px;
}


.card__price {
  font-size: 1.3rem;
  font-weight: 700; 
  color: #c00; /* rojo precio */
    font-family: "Nunito", Helvetica, sans-serif;
}

.card__old {
    font-family: "Nunito", Helvetica, sans-serif;
  color: #888;
  text-decoration: line-through;
  font-size: 12px;
  margin-left: 6px;
}

.card__discount {
  color: #0a7a52;
  font-weight: 600;
  font-size: 12px;
  margin-left: 6px;
}

/* Botón comprar */
.btnComprar {
  margin-top: 6px;
  display: inline-block;
  text-align: center;
  background-color: #099e54;
  border: none;
  padding: 6px 12px;
  font-size: 14px;
  line-height: 1.42857143;
  border-radius: 4px;
  color: #fff;
  font-weight: 500;
  cursor: pointer;
  transition: background-color .2s;
}

.btnComprar:hover {
  background-color: #077a40;
} 

/*========================Thank you=================