
/*--------------------------------------------------------------------- 
File Name: style.css 
---------------------------------------------------------------------*/
/* En tu archivo CSS (por ejemplo, styles.css) */
@font-face {
     font-family: 'AllRoundGothicW01-Demi';
     src: url('../fonts/All-Round-Gothic-W01-Demi.woff') format('woff'),
          url('../fonts/All-Round-Gothic-W01-Demi.ttf') format('truetype');
     font-weight: normal;
     font-style: normal;
     font-display: swap;
   }
   
   /*--------------------------------------------------------------------- 
   import Fonts 
   ---------------------------------------------------------------------*/
   
   
   /* Fuente global */
   html, body {
     font-family: 'AllRoundGothicW01-Demi', Arial, sans-serif !important;
     -webkit-font-smoothing: antialiased;
     -moz-osx-font-smoothing: grayscale;
   }


*,
*::before,
*::after {
    font-family: inherit; /* Asegura que todos los elementos hereden la fuente del body */
}
   
   /*--------------------------------------------------------------------- 
   basic 
   ---------------------------------------------------------------------*/
   
   * {
        box-sizing: border-box !important;
   }
   
   .container {
        max-width: 1170px;
   }
   
   html {
        scroll-behavior: smooth;
        overflow-x: hidden;
   }
   
   body {
        color: #fff;
        font-size: 14px;
        font-family: 'Inter', Arial, sans-serif !important;
        line-height: 1.80857;
        font-weight: normal;
        overflow-x: hidden;
        margin: 0;
        padding: 0;
        position: relative;
   }
   
   .video-background {
       position: fixed;
       top: 0;
       left: 0;
       width: 100%;
       height: 100%;
       z-index: -1;
       overflow: hidden;
   }
   
   
   .video-background::after {
     content: '';
     position: absolute;
     top: 0;
     left: 0;
     width: 100%;
     height: 100%;
     background: linear-gradient(
         rgba(74, 134, 175, 0.3),
         rgba(74, 134, 175, 0.2)
     ); /* Degradado suave */
     backdrop-filter: blur(10px);
     border: 1px solid rgba(20, 20, 20, 0.2); /* Borde sutil para un toque de cristal */
     z-index: 1;
 }
   
   .video-background video {
       min-width: 100%;
       min-height: 100%;
       width: auto;
       height: auto;
       position: absolute;
       top: 50%;
       left: 50%;
       transform: translate(-50%, -50%);
       object-fit: cover;
   }
   
   a {
        color: #1f1f1f;
        text-decoration: none !important;
        outline: none !important;
        -webkit-transition: all .3s ease-in-out;
        -moz-transition: all .3s ease-in-out;
        -ms-transition: all .3s ease-in-out;
        -o-transition: all .3s ease-in-out;
        transition: all .3s ease-in-out;
   }
   
   h1,
   h2,
   h3,
   h4,
   h5,
   h6 {
        letter-spacing: 0;
        font-weight: normal;
        position: relative;
        padding: 0;
        font-weight: normal;
        line-height: normal;
        color: #fff;
        margin: 0
   }
   
   h1 {
        font-size: 24px;
   }
   
   h2 {
        font-size: 22px;
   }
   
   h3 {
        font-size: 18px;
   }
   
   h4 {
        font-size: 16px
   }
   
   h5 {
        font-size: 14px
   }
   
   h6 {
        font-size: 13px
   }
   
   *,
   *::after,
   *::before {
        -webkit-box-sizing: border-box;
        -moz-box-sizing: border-box;
        box-sizing: border-box;
   }
   
   h1 a,
   h2 a,
   h3 a,
   h4 a,
   h5 a,
   h6 a {
        color: #fff;
        text-decoration: none!important;
        opacity: 1
   }
   
   button:focus {
        outline: none;
   }
   
   ul,
   li,
   ol {
        margin: 0px;
        padding: 0px;
        list-style: none;
   }
   
   p {
        margin: 0px;
        font-weight: 400;
        font-size: 17px;
        line-height: 24px;
        color: #fff;
   }
   
   a {
        color: #222222;
        text-decoration: none;
        outline: none !important;
   }
   
   a,
   .btn {
        text-decoration: none !important;
        outline: none !important;
        -webkit-transition: all .3s ease-in-out;
        -moz-transition: all .3s ease-in-out;
        -ms-transition: all .3s ease-in-out;
        -o-transition: all .3s ease-in-out;
        transition: all .3s ease-in-out;
   }
   
   img {
        max-width: 100%;
        height: auto;
   }
   
    :focus {
        outline: 0;
   }
   
   .btn-custom {
        margin-top: 20px;
        background-color: transparent !important;
        border: 2px solid #ddd;
        padding: 12px 40px;
        font-size: 16px;
   }
   
   .lead {
        font-size: 18px;
        line-height: 30px;
        color: #767676;
        margin: 0;
        padding: 0;
   }
   
   .form-control:focus {
        border-color: #ffffff !important;
        box-shadow: 0 0 0 .2rem rgba(255, 255, 255, .25);
   }
   
   .navbar-form input {
        border: none !important;
   }
   
   .badge {
        font-weight: 500;
   }
   
   blockquote {
        margin: 20px 0 20px;
        padding: 30px;
   }
   
   button {
        border: 0;
        margin: 0;
        padding: 0;
        cursor: pointer;
   }
   
   .full {
        float: left;
        width: 100%;
   }
   
   .full {
        width: 100%;
        float: left;
        margin: 0;
        padding: 0;
   }
   
   .titlepage {
        padding-bottom: 60px;
   }
   
   .titlepage h2 {
        font-size: 40px;
        line-height: 45px;
        font-weight: bold;
        padding: 0;
        display: inline-block;
        text-transform: uppercase;
   }
   
   .d_flex {
        display: flex;
        align-items: center;
        flex-wrap: wrap;
   }
   
   .read_more {
        font-size: 17px;
        background: #4A86AF;
        max-width: 215px;
        width: 100%;
        transition: ease-in all 0.5s;
        color: #fff;
        display: block;
        height: 57px;
        line-height: 57px;
        text-align: center;
        text-transform: uppercase;
   }
   
   .read_more:hover {
        background: #ede0e0;
        color: #1a1d22;
   }
   
   .text_align_left {
        text-align: left;
   }
   
   .text_align_right {
        text-align: right;
   }
   
   .text_align_center {
        text-align: center;
   }
   
   .img_responsive {
        max-width: 100%;
   }
   
   
   /**-- heading section --**/
   
   
   /*---------------------------- preloader area ----------------------------*/
   
   .loader_bg {
        position: fixed;
        z-index: 9999999;
        background: #fff;
        width: 100%;
        height: 100%;
   }
   
   .loader {
        height: 100%;
        width: 100%;
        position: absolute;
        left: 0;
        top: 0;
        display: flex;
        justify-content: center;
        align-items: center;
   }
   
   .loader img {
        width: 280px;
   }
   
   
   /*-- header --*/
   .header .logo img {
       max-width: 50%;
       height: auto;
       display: block;
       margin: 0 auto;
   }
   
   .header {
        width: 100%;
        background: #4A86AF !important;
        height: auto !important;
        padding: 10px 0 !important;
   }

   .navigation.navbar {
        padding: 0;
        text-align: center;
   }
   
   .navigation.navbar-expand-md .navbar-collapse {
        justify-content: center;
   }
   
   .navigation .navbar-nav.mr-auto {
        margin: 0 auto;
   }
   
   .navigation .navbar-nav.mr-auto li {
        display: flex;
        align-items: center;
   }
   
   .navigation.navbar-dark .navbar-nav .nav-link,
   .navigation.navbar-dark .categories-menu .nav-link {
        padding: 12px 24px !important;
        color: #fff !important;
        font-size: 17px;
        line-height: 20px;
        font-weight: 400;
        border-radius: 20px !important;
        text-transform: uppercase;
        background: linear-gradient(145deg, #5093be, #3f7ba5) !important;
        border: 1px solid rgba(255,255,255,0.35) !important;
        box-shadow: 5px 5px 10px #386b8f, -5px -5px 10px #5ca1cf !important;
        transition: all 0.3s ease !important;
   }

   .navigation.navbar-dark .navbar-nav .nav-link:focus,
   .navigation.navbar-dark .navbar-nav .nav-link:hover,
   .navigation.navbar-dark .categories-menu .nav-link:focus,
   .navigation.navbar-dark .categories-menu .nav-link:hover {
        color: #ffff !important;
        border-color: rgba(255,255,255,0.45) !important;
        box-shadow: inset 5px 5px 10px #386b8f, inset -5px -5px 10px #5ca1cf !important;
   }

   .navigation.navbar-dark .navbar-nav .active>.nav-link,
   .navigation.navbar-dark .navbar-nav .nav-link.active,
   .navigation.navbar-dark .navbar-nav .nav-link.show,
   .navigation.navbar-dark .navbar-nav .show>.nav-link,
   .navigation.navbar-dark .categories-menu .active>.nav-link,
   .navigation.navbar-dark .categories-menu .nav-link.active {
        color: #25eeee !important;
        border: 1px solid rgba(255,255,255,0.5) !important;
        box-shadow: inset 5px 5px 10px #386b8f, inset -5px -5px 10px #5ca1cf !important;
   }

   /* Estilo de botón de tutoriales para la navegación de index */
   .index-navigation .navbar-nav .nav-link,
   .index-navigation .categories-menu .nav-link {
        padding: 0 !important;
        color: inherit !important;
        background: transparent !important;
        box-shadow: none !important;
        border: none !important;
        display: flex;
        align-items: center;
        justify-content: center;
        width: 100%;
        height: 100%;
        text-align: center;
     }

     .index-navigation .navbar-nav .nav-item,
     .index-navigation .categories-menu .nav-item {
        flex: 1;
        text-align: center;
        padding: 12px 16px;
        color: #333;
        text-decoration: none;
        border-bottom: 3px solid transparent;
        transition: all 0.3s ease;
        font-size: 15px;
        font-weight: 600;
        border-radius: 12px;
        background: rgba(255, 255, 255, 0.25);
        backdrop-filter: blur(10px);
        -webkit-backdrop-filter: blur(10px);
        border: 1px solid rgba(255, 255, 255, 0.3);
        box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
        display: flex;
        align-items: center;
        justify-content: center;
        min-width: 140px;
     }

     .index-navigation .navbar-nav .nav-item:hover,
     .index-navigation .categories-menu .nav-item:hover {
        background: rgba(255, 255, 255, 0.4);
        transform: translateY(-2px);
        box-shadow: 0 6px 20px rgba(0, 0, 0, 0.15);
     }

     .index-navigation .navbar-nav .nav-item.active,
     .index-navigation .navbar-nav .nav-item.active .nav-link,
     .index-navigation .categories-menu .nav-item.active,
     .index-navigation .categories-menu .nav-item.active .nav-link {
        background: rgba(106, 169, 176, 0.85) !important;
        color: #fff !important;
        border-bottom-color: rgba(106, 169, 176, 1) !important;
        box-shadow: 0 6px 25px rgba(106, 169, 176, 0.4) !important;
        backdrop-filter: blur(15px);
        -webkit-backdrop-filter: blur(15px);
     }

   .di_no {
        display: none;
   }
   
   ul.email {
        text-align: center;
   }
   
   ul.email li {
        padding: 0px 9px;
        display: inline-block;
   }
   
   ul.email li:last-child {
        padding-right: 0;
   }
   
   ul.email li a {
        color: #fff;
        text-transform: uppercase;
        font-size: 20px;
        line-height: 25px;
   }
   
   ul.email li a img {
        padding-left: 5px;
   }
   
   
   /** end header **/
   
   
   /** banner section **/
   
   .slider_main {
        padding-top: 13%;
   }
   
   .relative {
        left: 0;
        right: 0;
        text-align: left;
        position: inherit;
   }
   
   .carousel-item {
        height: 100%;
        width: 100%;
   }
   
   .board h1 {
        font-size: 88px;
        line-height: 90px;
        font-weight: bold;
        text-transform: uppercase;
        padding-bottom: 20px;
   }
   
   .board p {
        font-size: 17px;
        line-height: 28px;
        padding-bottom: 40px;
        display: block;
   }
   
   .board .read_more {
        display: inline-block;
        margin-right: 20px;
   }
   
   .every_img figure {
        margin: 0;
   }
   
   .slider_main .carousel-indicators {
        display: none;
   }
   
   
   #banner1 .carousel-control-prev {
        left: inherit;
        right: -6%;
        top: 30%;
   }
   
   #banner1 .carousel-control-next {
        right: -6%;
   }
   
   
   
   .banner_img {
        padding-right: 50px;
   }
   
   .banner_img figure {
        margin: 0;
   }
   
   
   /** end banner section **/
   
   
   /** about section **/
   
   .about {
        padding-top: 85px;
   }
   
   .about .titlepage {
        padding-bottom: 0px;
   }
   
   .about .titlepage h2 {
        padding-bottom: 10px;
   }
   
   .about .titlepage p {
        font-weight: 400;
        font-size: 17px;
        line-height: 30px;
        margin-bottom: 40px;
   }
   
   .about_img {
        margin-left: 50px;
   }
   
   .about_img figure {
        margin: 0;
   }
   
   .about_img figure img {
        max-width: 100%;
        border-left: #c42a18 solid 10px;
   }
   
   .about_img::before {
        position: absolute;
        content: "";
        left: 0;
        border-top: 20px;
        height: 10px;
        background: #c42a18;
        width: 25%;
        top: -10px;
   }
   
   .about_img::after {
        position: absolute;
        content: "";
        left: 0;
        border-top: 20px;
        height: 10px;
        background: #c42a18;
        width: 25%;
   }
   
   
   /** end about section **/
   
   
   /** our_fishs **/
   
   .our_fishs {
        padding-top: 95px;
   }
   
   .our_fishs .titlepage {
        padding-bottom: 40px;
   }
   
   .our_fishs .titlepage p {
        line-height: 30px;
        color: #fff;
        padding-top: 15px;
   }
   
   .ser_img figure {
        margin: 0;
   }
   
   .ser_img figure img {
        max-width: 100%;
   }
   
   
   
      /* cambios para moviles */
   @media (max-width: 767.98px) {
        .our_fishs .owl-stage-outer {
            width: 105%;
            margin-left: -4.5%;
        }
    
        .our_fishs .owl-item {
            width: 80% !important;
            margin-right: 15px;
        }
     
    
      
       /* Owl Carousel arrow styles for mobile */
   .our_fishs .owl-nav {
        right: 0; /* <-- move to right */
        left: auto;
        top: 70%;
        transform: translateY(-50%);
        position: absolute;
        display: flex !important;
        flex-direction: column;
        gap: 10px;
        width: auto;
        height: auto;
        z-index: 10;
        pointer-events: none; /* only the buttons themselves are clickable */
    }
    
      
    .our_fishs .owl-prev,
    .our_fishs .owl-next {
        position: static;
        transform: none;
        margin: 0;
        width: 65px;
        height: 65px;
        background: #4A86AF  !important;
        border-radius: 50% !important;
        box-shadow: 0 2px 5px rgb(247, 244, 244);
        display: flex !important;
        align-items: center;
        justify-content: center;
        color: #fff !important;
        font-size: 20px !important;
        transition: all 0.3s;
        pointer-events: auto;
        border: 2px solid #4A86AF;
    }
    
    .our_fishs .owl-prev:hover,
    .our_fishs .owl-next:hover {
        background: #4A86AF !important;
        color: #fff !important;
    }
    }
   
    .owl-carousel {
        position: relative;
        padding: 0 40px;
        width: 100%;
      }
      
      .owl-stage-outer {
        padding: 20px 0;
        overflow: hidden;
      }
      
      .owl-stage {
        display: flex;
        align-items: stretch;
      }
      
      .owl-item {
        display: flex;
        justify-content: center;
        padding: 0 15px;
        height: auto;
      }
   
   /* Estilo para la etiqueta de agotado */
   .agotado-tag {
     position: absolute;
     top: 15px;
     right: 15px;
     background: #ff0000;
     color: white;
     padding: 5px 10px;
     border-radius: 30px;
     font-size: 12px;
     font-weight: bold;
     text-transform: uppercase;
     z-index: 2;
     box-shadow: 0 2px 5px rgba(0,0,0,0.2);
     white-space: nowrap;
     max-width: 90px;
     text-overflow: ellipsis;
     overflow: hidden;
   }
   
   .product-name {
       color: #fff;
       font-size: 1.5rem;
       margin: 10px 0;
       font-weight: 400;
   }
   
   /* En pantallas grandes, hacer el modal más grande */
   @media (min-width: 992px) {
       .modal-content {
           max-width: 80%;
           max-height: 80vh;
       }
   }
   
   .close {
       position: absolute;
       top: 15px;
       right: 35px;
       color: #f1f1f1;
       font-size: 40px;
       font-weight: bold;
       cursor: pointer;
       z-index: 1001;
       transition: color 0.3s;
   }
   
   .close:hover {
       color: #ff4444;
   }
   
   /* Estilos para los contenedores de productos */
   .our_fishs_box {
     position: relative;
     width: 100%;
     background: linear-gradient(to right, #6AA9B0, transparent);
     border-radius: 30px;
     overflow: hidden;
     box-shadow: 0 4px 15px rgba(0,0,0,0.1);
     transition: all 0.3s ease;
     padding-top: 15px;
     display: flex;
     flex-direction: column;
     height: 100%;
     position: relative;
     margin: 0 auto;
     max-width: 350px;
     min-height: 480px; /* Altura mínima fija */
     padding-bottom: 80px; /* Espacio en la parte inferior */
   }
   
   .our_fishs_box:hover {
     transform: translateY(-5px);
   }
   
   /* Estilo específico para la descripción en los productos más vendidos */
   #masVendidos .our_fishs_box h3 {
     padding: 10px 15px;
     margin: 0;
     font-size: 14px;
     text-align: center;
     color: #fff;
     font-weight: 500;
     text-shadow: 1px 1px 2px rgba(236, 22, 22, 0.3);
     text-transform: none;
     
     /* Ajuste de altura y espaciado */
     min-height: 60px;
     max-height: 120px;
     line-height: 1.5; /* Ajustado para mejor legibilidad */
     overflow: hidden;
     
     /* Truncar texto a 4 líneas */
     display: -webkit-box;
     -webkit-box-orient: vertical;
     -webkit-line-clamp: 4;
     line-clamp: 4; /* Propiedad estándar */
     -webkit-box-align: center;
     -ms-flex-align: center;
     align-items: center;
     -webkit-box-pack: center;
     -ms-flex-pack: center;
     justify-content: center;
     
     /* Asegura que el texto se muestre correctamente */
     word-break: break-word;
     white-space: normal;
   }
   
   .our_fishs_box .read_more {
     margin: 15px auto;
     display: block;
     width: 80%;
     text-align: center;
   }
   .owl-nav {
        left: 0;
        top: 50%;
        transform: translateY(-50%);
        position: absolute;
        display: flex !important;
        flex-direction: column;
        gap: 10px;
      }
      
      .owl-prev,
      .owl-next {
        position: static;
        transform: none;
        margin: 0;
        width: 40px;
        height: 40px;
        background: #fffdfd !important;
        border-radius: 50% !important;
        box-shadow: 0 2px 5px #f2f3f3 ;
        display: flex !important;
        align-items: center;
        justify-content: center;
        color: #4A86AF !important;
        font-size: 20px !important;
        transition: all 0.3s;
        pointer-events: auto;
      }
   
   .owl-prev,
   .owl-next {
     left: 0;
     right: auto;
   }
   
   .owl-prev {
     top: 45%;
   }
   
   .owl-next {
     top: 55%;
   }
   
   .owl-prev:hover,
   .owl-next:hover {
     background: #4A86AF !important;
     color: #fff !important;
   }
   
   /* Estilos para la calculadora de acuarios en móviles */
   @media (max-width: 767.98px) {
       #calculadora-acuarios {
           padding: 20px 15px !important;
           margin: 20px auto !important;
       }
       
       #calculadora-acuarios h2 {
           font-size: 1.5rem !important;
           margin-bottom: 15px !important;
       }
       
       #calculadora-acuarios h3 {
           font-size: 1.1rem !important;
           margin-bottom: 20px !important;
       }
       
       #form-calc {
           flex-direction: column;
           gap: 15px !important;
       }
       
       #form-calc > div {
           min-width: 100% !important;
           max-width: 100% !important;
       }
       
       #resultado-calc > div {
           flex-direction: column !important;
           align-items: center !important;
           gap: 20px !important;
       }
       
       #resultado-calc > div > div {
           flex: 0 0 100% !important;
           max-width: 100% !important;
           margin-bottom: 20px;
       }
       
       .img-producto-calc {
           max-height: 150px !important;
           width: auto !important;
       }
   }
   
   /* Estilos de h3 movidos a la definición principal */
   
   .our_fishs_box strong {
     padding: 15px 0;
     color: #fff;
     font-weight: bold;
     font-size: 28px;
     display: block;
     line-height: 1.2;
     min-height: 60px;
     display: flex;
     align-items: center;
     justify-content: center;
     background: rgba(241, 7, 7, 0.2);
     margin: 10px 15px;
     border-radius: 10px;
   }
   
   .our_fishs_box strong span {
        color: #4A86AF;
   }
   
   .our_fishs_box .read_more {
     max-width: 200px;
     width: 80%;
     font-weight: bold;
     margin: 0 auto !important;
     padding: 12px 20px;
     background: #4A86AF;
     color: #fff !important;
     text-align: center;
     border-radius: 30px;
     text-decoration: none;
     transition: all 0.3s ease;
     display: block;
     font-size: 16px;
     text-transform: uppercase;
     border: 2px solid #4A86AF;
   }
   
   .our_fishs_box .read_more:hover {
     background: transparent;
     color: #4A86AF !important;
     border-color: #4A86AF;
   }
   
   .owl-item.active.center .ser_img {
        background: #db3620;
   }
   
   
   
   .owl-nav.disabled .owl-prev {
        left: 0 !important;
        position: absolute !important;
        top: 108% !important;
   }
   
   
   .our_fishs .read_more {
        margin: 0 auto;
        display: block;
   }
   
   
   /** end our_fishs **/
   
   
   /** blog section **/
   
   .blog {
        padding-top: 85px;
   }
   
   .blog .titlepage h2 {
        padding-bottom: 10px;
   }
   
   .blog .titlepage p {
        font-weight: 400;
        font-size: 17px;
        line-height: 30px;
   }
   
   .blog_img figure {
        margin: 0;
   }
   
   .blog_img figure img {
        width: 100%;
        box-shadow: 0 0 19px rgba(230, 9, 9, 0.1);
   }
   
   .fer {
        display: flex;
        justify-content: flex-start;
        flex-wrap: wrap;
        margin-top: -60px;
   }
   
   .fer span {
        background: #ff0000;
        display: block;
        text-align: left;
        padding: 25px 15px;
        font-size: 17px;
        line-height: 20px;
        font-weight: bold;
        color: #fff;
        text-transform: uppercase;
   }
   
   .blog_box h3 {
        color: #fff;
        font-size: 30px;
        line-height: 35px;
        font-weight: bold;
        margin-top: 45px;
   }
   
   .blog_box p {
        font-size: 17px;
        line-height: 35px;
        padding: 30px 0 15px 0;
   }
   
   .blog_box strong {
        font-weight: bold;
        font-size: 17px;
        padding-bottom: 10px;
        display: block;
   }
   
   .blog_box ul {
        display: flex;
        align-items: center;
        justify-content: space-between;
        z-index: 9;
        position: relative;
        flex-wrap: wrap;
   }
   
   .blog_box ul li {
        display: inline-block;
        color: #fff;
   }
   
   .blog_box ul li a {
        display: inline-block;
        color: #fff;
        font-size: 17px;
   }
   
   .blog_box ul li a:hover {
        color: #4A86AF;
   }
   
   .blog_box ul li a img {
        padding-left: 14px;
   }
   
   .fist_sec {
        padding: 60px 40px;
        background: #000000;
        margin-bottom: 30px;
   }
   
   .blog .read_more {
        margin: 0 auto;
        margin-top: 35px;
   }
   
   
   /** end blog section **/
   
   
   /** customers **/
   
   .customers {
        padding-top: 85px;
        padding-bottom: 85px;
   }
   
   .customers_banner {
        z-index: 9999;
   }
   
   .customers_banner .relative {
        position: inherit;
        bottom: 0;
        padding: 0;
   }
   
   .por_pic {
        position: relative;
        padding-left: 54px;
   }
   
   .por_pic::before {
        position: absolute;
        content: "";
        left: 0px;
        border-top: 20px;
        height: 10px;
        background: #c42a18;
        width: 12%;
        bottom: 12px;
   }
   
   .por_pic::after {
        position: absolute;
        content: "";
        left: 0px;
        border-top: 20px;
        height: 10px;
        background: #c42a18;
        width: 11%;
        top: 15px;
   }
   
   .por_pic i {
        position: relative;
   }
   
   .por_pic i::before {
        position: absolute;
        content: "";
        left: -54px;
        border-top: 20px;
        height: 188px !important;  
        background: #111;
        width: 33%;
        bottom: -87px;
        display: inline-block;
   }
   
   .por_pic i::after {
        position: absolute;
        content: "";
        left: -54px;
        border-top: 20px;
        height: 188px !important;
        background: #c42a18;
        width: 7%;
        bottom: -87px;
        display: inline-block;
   }
   
   .test_box h4 {
        font-size: 29px;
        line-height: 28px;
        font-weight: bold;
        display: flex;
        align-items: center;
        justify-content: space-between;
   }
   
   .test_box p {
        font-size: 17px;
        line-height: 30px;
        padding-top: 25px;
   }
   
   #myCarousel .carousel-indicators {
        bottom: -83px;
        right: inherit;
        margin-left: 1%;
        cursor: pointer;
   }
   
   #myCarousel .carousel-indicators .active {
        background: #4A86AF;
   }
   
   #myCarousel .carousel-indicators li {
        background: #fefeff;
        width: 20px;
        height: 20px;
        border-radius: 20px;
   }
   
   #myCarousel a.carousel-control-next,
   #myCarousel a.carousel-control-prev {
        display: none;
   }
   
   
   /** end customers **/
   
   
   /** contact **/
   
   .contact {
        padding-top: 85px;
   }
   
   .main_form .contactus {
        padding: 0px 15px;
        margin-bottom: 25px;
        width: 100%;
        height: 60px;
        background: transparent;
        font-size: 17px;
        font-weight: normal;
        border: #adafb0 solid 1px;
        color: #adafb0;
        line-height: 20px;
   }
   
   .main_form .textarea {
        margin-bottom: 20px;
        width: 100%;
        background: transparent;
        color: #adafb0;
        font-size: 17px;
        font-weight: normal;
        padding: 12px 15px 10px 15px;
        border: #adafb0 solid 1px;
        height: 155px;
   }
   
   .main_form .send_btn {
        font-size: 18px;
        transition: ease-in all 0.5s;
        background-color: #4A86AF;
        text-transform: uppercase;
        color: #fff;
        max-width: 209px;
        width: 100%;
        display: block;
        margin-top: 40px !important;
        font-weight: bold;
        height: 71px;
        line-height: 71px;
        border: 3px solid #4A86AF;
        box-sizing: border-box;
        border-radius: 8px;
   }
   
   .main_form .send_btn:hover {
        background-color: #fff;
        transition: ease-in all 0.5s;
        color: #4A86AF;
        border: 3px solid #4A86AF;
   }
   
   #request *::placeholder {
        color: #adafb0;
        opacity: 1;
   }
   
   .map_img figure {
        margin: 0;
   }
   
   .map_img figure img {
        max-width: 100%;
   }
   
   
   /** end contact **/
   
   
   /*newsletter*/
   
   .newsletter {
        padding-top: 85px; 
   }
   
   .form_newsl {
        background: #111111;
        padding: 55px 40px 30px 40px;
   }
   
   .form_newsl p {
        padding-bottom: 37px;
   }
   
   .newsl {
        margin-bottom: 30px;
        width: 100%;
        height: 64px;
        background: transparent;
        color: #fff;
        font-size: 17px;
        font-weight: normal;
        box-shadow: inherit;
        padding: 0 15px;
        border: #fff solid 1px;
   }
   
   .subsci_btn {
        font-size: 22px;
        transition: ease-in all 0.5s;
        background-color: #ff0000;
        text-transform: uppercase;
        color: #fff;
        max-width: 353px;
        width: 100%;
        display: block;
        font-weight: bold;
        height: 64px;
        line-height: 64px;
        margin: 0 auto;
   }
   
   .subsci_btn:hover {
        background-color: #fff;
        transition: ease-in all 0.5s;
        color: #111111;
   }
   
   
   /* end newsletter*/
   
   
   /** footer **/
   
   .footer {
        padding-top: 100px;
   }
   
   .logo_footer {
        margin-top: 70px;
        display: block;
   }
   .headimg_fooh3 {padding-top: 30px;}
   .headimg_fooh3 h3 {
        font-weight: bold;
        font-size: 24px;
        text-transform: uppercase;
        text-align: left;
        line-height: 24px;
        padding-bottom: 30px;
   }
   
   ul.opening li {
        display: flex;
        justify-content: space-between;
        padding-right: 24px;
        font-size: 17px;
        padding-bottom: 2px;
   }
   
   ul.conta li {
        color: #ffffff;
        text-align: left;
        padding-bottom: 15px;
        font-size: 17px;
        line-height: 18px;
        display: flex;
        align-items: center;
   }
   
   ul.conta li:last-child {
        padding-right: 0;
   }
   
   ul.conta li i {
        margin-right: 15px;
        text-align: center;
        font-size: 30px;
        color: #fff;
        display: flex;
        align-items: center;
        justify-content: center;
   }
   
   ul.conta li a {
        color: #fff;
   }
   
   ul.social_icon {
        padding-top: 20px;
   }
   
   ul.social_icon li {
        display: inline-block;
        margin-right: 15px;
   }
   
   ul.social_icon li:last-child {
        margin-right: 0;
   }
   
   ul.social_icon li a i {
        font-size: 35px;
        color: #ffffff;
        transition: ease-in all 0.5s;
   }
   
   ul.social_icon li a i:hover {
        color: #ff0000;
        transition: ease-in all 0.5s;
   }
   .copyright {
     margin-top: 100px;
     padding: 30px 0;
     background: rgba(255, 255, 255, 0.1); /* Semi-transparent white for glass effect */
     backdrop-filter: blur(10px); /* Frosted glass blur effect */
     width: 100%;
     box-sizing: border-box;
     text-align: center;
 }
.product-gallery .main-image-container img {
    width: 100%;
    border-radius: 15px;
    border: 2px solid #6AA9B0;
    background-color: rgba(255, 255, 255, 0.1);
    padding: 10px;
}

.thumbnail-images {
    display: flex;
    gap: 10px;
    margin-top: 15px;
}

.thumbnail-images .img-thumbnail {
    width: 80px;
    height: 80px;
    object-fit: cover;
    cursor: pointer;
    border: 2px solid transparent;
    border-radius: 8px;
    transition: border-color 0.3s ease;
    padding: 4px;
    background-color: rgba(255, 255, 255, 0.1);
}

.thumbnail-images .img-thumbnail.active,
.thumbnail-images .img-thumbnail:hover {
    border-color: #4A86AF;
}

.product-info-panel {
    background: rgba(0, 0, 0, 0.3);
    padding: 30px;
    border-radius: 15px;
}

.product-title {
    font-size: 2.5rem;
    font-weight: bold;
    margin-bottom: 15px;
}

.product-price {
    font-size: 2rem;
    color: #6AA9B0;
    margin-bottom: 20px;
    font-weight: bold;
}

.product-description {
    font-size: 1rem;
    line-height: 1.6;
    margin-bottom: 25px;
}

.form-group label {
    font-weight: bold;
    margin-bottom: 10px;
}

.form-control {
    background-color: rgba(255, 255, 255, 0.1);
    border: 1px solid #6AA9B0;
    color: #fff;
}

.form-control:focus {
    background-color: rgba(255, 255, 255, 0.2);
    border-color: #4A86AF;
    color: #fff;
}

.quantity-selector {
    display: flex;
    width: 150px;
}

.quantity-selector .form-control {
    border-radius: 0;
}

.quantity-selector .btn {
    border-color: #6AA9B0;
    color: #fff;
}

.btn-add-to-cart {
    background-color: #4A86AF;
    border-color: #4A86AF;
    font-weight: bold;
    text-transform: uppercase;
    padding: 15px;
    margin-top: 20px;
    width: 100%;
    transition: background-color 0.3s ease;
}

.btn-add-to-cart:hover {
    background-color: #6AA9B0;
    border-color: #6AA9B0;
}

   /* Estilos para el color del texto del horario */
   #horarioMallDelRio small,
   #horarioCentro small {
      color: white;
   }
   
   #horariosMenu .dropdown-item,
   #horariosMenu .dropdown-item:hover,
   #horariosMenu .dropdown-item:focus {
      color: white;
      background-color: transparent;
   }
   
   /* Asegurar que los menús empujen el contenido hacia abajo */
   #contactosMenu .dropdown-menu,
   #horariosMenu .dropdown-menu {
       position: static;
       float: none;
       width: auto;
       margin-top: 0;
       background-color: transparent;
       border: 0;
       box-shadow: none;
   }
   
   #contactosMenu,
   #horariosMenu {
        margin-bottom: 80px;
   }
   
   /* --- Estilos para Banners de Productos Más Vendidos --- */
   #masVendidosBannerContainer {
     gap: 20px; /* Espacio entre banners */
   }
   
   /* Layout para el slide del producto en dos columnas */
   .product-slide-layout {
     display: flex;
     align-items: center;
     justify-content: space-between;
     height: 70vh;
     padding: 30px;
     background: linear-gradient(to right, transparent);
     border-radius: 15px;
     overflow: hidden;
   }
   
   .product-info {
     flex-basis: 50%;
     padding-right: 30px;
     text-align: left; 
     color: #333;
   }
   
   .product-info h3 {
     font-size: 1.5rem;
     font-weight: bold;
     margin-bottom: 15px;
   }
   
   .product-info .price {
     font-size: 1.8rem;
     font-weight: 500;
     margin-bottom: 20px;
     color: #f1f6f8;
   }
   
   .product-info .disponibilidad {
     margin-bottom: 25px;
   }
   
   .badge-disponible,
   .badge-agotado {
     display: inline-block;
     padding: 6px 15px;
     font-size: 14px;
     font-weight: bold;
     border-radius: 20px;
     color: #fff;
     text-transform: uppercase;
   }
   
   .badge-disponible {
     background-color: #4A86AF; /* Verde */
   }
   
   .badge-agotado {
     background-color: #dc3545; /* Rojo */
   }
   
   .product-info .read_more {/* cambiar color de ver producto */
     padding: 12px 30px;
     background: transparent;
     color: #f5ebeb !important;
     border-radius: 30px;
     text-decoration: none;
     font-weight: bold;
     transition: all 0.3s ease;
     border: 2px solid transparent;
   }
   
   .product-info .read_more:hover {
     background: transparent;
     color: #4A86AF !important;
   }
   
   .product-image {
     flex-basis: 50%;
     text-align: center;
   }
   
   .product-image img {
     max-width: 100%;
     max-height: 55vh;
     object-fit: contain;
     border-radius: 10px;
   }
   
   /* Responsive - Diseño vertical en móviles: imagen arriba, información abajo */
   @media (max-width: 767px) {
     .product-slide-layout {
       flex-direction: column; /* Cambiar a vertical */
       height: auto; /* Altura automática */
       padding: 15px;
     }
   
     .product-info {
       flex-basis: auto; /* Ancho completo */
       width: 100%;
       padding-right: 0; /* Sin padding lateral */
       text-align: center; /* Centrar la información */
       order: 3; /* Aparecer primero (arriba) */
       margin-bottom: 10px; /* Espacio entre información e imagen */
     }
   
     .product-image {
       flex-basis: auto; /* Ancho completo */
       width: 100%;
       text-align: center;
       order: 2; /* Aparecer segundo (abajo) */
     }
   
     .product-image img {
       max-height: 45vh; /* Altura generosa para la imagen */
       width: auto;
       max-width: 100%;
     }
   
     .product-info h3 {
       font-size: 1.3rem; /* Tamaño más grande ahora que tiene más espacio */
       margin-bottom: 10px;
     }
   
     .product-info .price {
       font-size: 1.1rem; /* Tamaño más grande */
       margin-bottom: 15px;
     }
   
     .product-info .disponibilidad {
       margin-bottom: 20px;
     }
   
     .badge-disponible,
     .badge-agotado {
       font-size: 12px; /* Etiquetas un poco más grandes */
       padding: 6px 12px;
     }
   
     .product-info .read_more {
       padding: 10px 20px; /* Botón más grande */
       font-size: 16px;
     }
   }
   
   @media (max-width: 767px) {
     #masVendidosBannerContainer {
       flex-direction: column;
     }
     .product-banner {
       height: 300px;
       width: 100%;
     }
   }
   
   .bg_inner_all .titlepage {
        padding: 40px 0;
   }
   
   .bg_inner_all {
        background-color: #ffbc00;
   }
   
   .inner_page .about {
        padding-bottom: 0;
   }
   .about-video {
        width: 100%;
        max-width: 10cm;
        height: auto;
        aspect-ratio: 2/1; /* 10cm x 5cm ratio for modern browsers */
        object-fit: cover;
        display: block;
        border-radius: 10px; /* optional */
      }
      
      /* Responsive: reduce size on small screens */
      @media (max-width: 767.98px) {
        .about-video {
          max-width: 95vw;
          height: 180px; /* or adjust as needed for your design */
          aspect-ratio: unset;
        }
      }
      .btn-calcular {
        background-color: #6394B5 !important; /* verde */
        color: white !important;
        border: none;
      }
      .btn-limpiar {
        background-color: #6AA9B0 !important; /* rojo */
        color: white !important;
        border: none;
      }
   
      /* Contenedor principal de productos */
      .productos-container {
        position: relative;
        z-index: 1;
        overflow: visible !important;
      }
      
      /* Tarjeta de producto */
      .producto-card {
        position: relative;
        z-index: 1;
        overflow: visible !important;
      }
      
      /* Contenedor de la imagen */
      .img-container {
        position: relative;
        z-index: 1;
        overflow: visible !important;
        perspective: 1000px;
      }
      
      /* Imagen del producto */
      .img-producto-calc {
        transition: transform 0.3s cubic-bezier(.4,2,.6,1);
        cursor: pointer;
        position: relative;
        z-index: 1;
        max-width: 80%;
        max-height: 160px;
        object-fit: contain;
        transform-origin: center center;
        will-change: transform;
      }
      
      .img-producto-calc:hover,
      .img-producto-calc:active {
        transform: scale(2.5);
        z-index: 1000;
        position: relative;
        max-width: none;
      }
      
      /* Asegurar que los elementos padre no recorten el hover */
      #resultado-calc,
      #resultado-calc > div,
      #resultado-calc > div > div,
      .producto-card,
      .img-container {
        overflow: visible !important;
      }
      /* Estilos para móviles */
   @media (max-width: 767.98px) { 
        .hero-section {
          background: transparent;  /* pantalla negra en inicio de codigo */
        }
        
        .rectangle-container {
          background: rgba(255, 255, 255, 0.15) !important;
          backdrop-filter: blur(8px) !important;
          border: 2px solid rgba(255, 255, 255, 0.4) !important;
        }
      }
      
      /* Estilos para desktop - ocultar video de fondo */
      @media (min-width: 768px) {
        .mobile-video-bg {
          display: none !important;
        }
      }
       /* Ajustes para el menú */
       .navbar-collapse {
        display: flex !important;
        flex-grow: 1;
     }
     
     .navbar-collapse > .d-flex {
        width: 100%;
        align-items: center;
     }
     
     /* Menú principal */
      .main-menu {
         display: flex;
         align-items: center;
         justify-content: center;
         margin-right: auto;
      }
     
     /* Menú de categorías */
     .categories-menu {
        display: flex;
        align-items: center;
        margin-right: 15px;
     }
     
     /* Separador del menú */
     .nav-divider {
        width: 1px;
        height: 30px;
        background-color: rgba(255, 255, 255, 0.3);
        margin: 0 15px;
        flex-shrink: 0;
     }
     
     /* Ajustes generales de navegación */
     .navbar-nav {
        display: flex;
        flex-direction: row;
        align-items: center;
        padding: 0;
        margin: 0;
     }
     
     .navigation.navbar .navbar-nav .nav-item {
        margin: 0 3px;
     }
 
     /* Ajuste para móviles */
     @media (max-width: 991.98px) {
        .navbar-collapse {
           padding: 10px 15px;
           background: #1a1a1a;
           box-shadow: 0 5px 10px rgba(0,0,0,0.1);
           max-height: 80vh;
           overflow-y: auto;
           transition: all 0.3s ease-in-out;
        }
        
        .navbar-nav {
           flex-direction: column;
           width: 100%;
        }
        
        .main-menu, .categories-menu {
           width: 100%;
           margin: 0;
        }
        
        .nav-item {
           width: 100%;
           margin: 3px 0;
        }
        
        .nav-link {
           padding: 10px 15px;
           border-radius: 4px;
           transition: background-color 0.2s;
        }
        
        .nav-link:hover {
           background-color: rgba(255,255,255,0.1);
        }
        
        .nav-divider {
           width: 100%;
           height: 1px;
           background-color: rgba(255,255,255,0.2);
           margin: 8px 0;
        }
        
        .search-container {
           margin: 10px 0;
           width: 100%;
        }
        
        /* Asegurar que el menú colapsado no sea visible */
        .navbar-collapse:not(.show) {
           display: none !important;
        }
        
        /* Estilo para el botón del menú */
        .navbar-toggler {
           border: 1px solid rgba(255,255,255,0.2);
           padding: 0.5rem 0.75rem;
        }
        
        .navbar-toggler:focus {
           box-shadow: none;
           outline: none;
        }
     }
     
     /* Expandable Search Box */
     .search-container {
        position: relative;
        display: flex;
        align-items: center;
        justify-content: flex-end;
     }
     
     /* Menu animation */
     #navbarsExample04 {
        transition: transform 0.3s ease;
     }
     
     #navbarsExample04.search-active {
        transform: translateX(-80px);
     }
     
     @media (max-width: 991.98px) {
        #navbarsExample04.search-active {
           transform: none;
        }
     }
   
     .search-icon {
        background: none;
        border: none;
        color: #fff;
        font-size: 20px;
        cursor: pointer;
        padding: 5px 10px;
        transition: all 0.3s ease;
        z-index: 1001;
        position: relative;
     }
   
     .search-box {
        width: 0;
        overflow: hidden;
        transition: width 0.3s ease, opacity 0.3s ease;
        position: absolute;
        left: 100%;
        top: 50%;
        transform: translateY(-50%);
        z-index: 1000;
        opacity: 0;
        margin-left: 10px;
     }
   
     .search-box.active {
        width: 220px;
        opacity: 1;
     }
   
     .search-box .form-control {
        width: 100%;
        padding: 8px 15px;
        border-radius: 20px;
        border: 1px solid #ddd;
        background: rgba(255, 255, 255, 0.9);
        transition: all 0.3s ease;
     }
     
     /* Search suggestions */
     .search-suggestions {
        position: absolute;
        top: 100%;
        left: 0;
        right: 0;
        background: white;
        border: 1px solid #ddd;
        border-top: none;
        border-radius: 0 0 10px 10px;
        max-height: 200px;
        overflow-y: auto;
        z-index: 1001;
        display: none;
     }
     
     .search-suggestions.show {
        display: block;
     }
     
     .suggestion-item {
        padding: 10px 15px;
        cursor: pointer;
        border-bottom: 1px solid #f0f0f0;
        transition: background-color 0.2s;
        color: #333;
        font-size: 14px;
     }
     
     .suggestion-item:hover,
     .suggestion-item.highlighted {
        background-color: #f8f9fa;
     }
     
     .suggestion-item:last-child {
        border-bottom: none;
     }
     
     .suggestion-category {
        font-size: 12px;
        color: #666;
        font-weight: normal;
     }
   
     /* Adjust for mobile */
     @media (max-width: 767.98px) {
        .search-container {
           position: fixed !important;
           bottom: 20px !important;
           left: 20px !important;
           right: auto !important;
           margin: 0 !important;
           width: auto !important;
           z-index: 1050 !important;
           justify-content: flex-start !important;
        }
        
        .search-box.active {
           width: 180px;
        }
        
        .search-box {
           right: auto;
           left: 100%;
           margin-left: 10px;
        }
        
        .search-icon {
           padding: 8px 12px;
           background: rgba(0, 0, 0, 0.7);
           border-radius: 50%;
           box-shadow: 0 2px 10px rgba(0, 0, 0, 0.3);
        }
        
        .search-icon:hover {
           background: rgba(0, 0, 0, 0.9);
        }
     }
       /* Reset de fuentes */
       body,
       button,
       input,
       select,
       textarea {
          font-family: 'AllRoundGothicW01-Demi', Arial, sans-serif !important;
       }
   
       /* Estilos para el carrito en móviles */
       @media (max-width: 768px) {
          .cart-mobile-container {
             position: absolute;
             top: 15px;
             left: 15px;
             z-index: 1000;
          }
   
          .cart-icon {
             background: rgba(0, 0, 0, 0.6);
             padding: 10px;
             border-radius: 50%;
             width: 40px;
             height: 40px;
             display: flex;
             align-items: center;
             justify-content: center;
             position: relative;
          }
   
          /* Ocultar el carrito en el menú en móviles */
          .desktop-cart {
             display: none !important;
          }
       }
   
       /* Mostrar el carrito en escritorio */
       @media (min-width: 769px) {
          .mobile-cart {
             display: none !important;
          }
       }

/*--------------------------------------------------------------------- 
Carousel Styles - Sincronizado con carousel-styles.css
---------------------------------------------------------------------*/

/* Carousel Responsive Styles */
@media (max-width: 768.98px) {
    /* Navegación del carrusel */
    .owl-nav {
        position: absolute;
        right: 0;
        top: 50%;
        transform: translateY(-50%);
        display: flex !important;
        flex-direction: column;
        gap: 10px;
        z-index: 10;
        margin: 0;
        padding: 0 10px;
        width: auto;
        height: auto;
        left: auto;
        justify-content: center;
    }
    
    .owl-prev,
    .owl-next {
        width: 35px !important;
        height: 35px !important;
        font-size: 16px !important;
        margin: 5px 0 !important;
    }
    
    .owl-prev {
        margin-bottom: 15px !important;
    }
    
    .owl-next {
        margin-top: 15px !important;
    }
    
    /* Estilos de carrusel igual que Los Más Vendidos */
    .owl-carousel .owl-item {
        padding: 0 5px;
    }
    
    .owl-carousel .owl-stage {
        padding: 10px 0;
    }
    
    .owl-carousel .owl-item {
        min-width: 280px !important;
        margin-right: 10px;
    }
    
    .owl-carousel .product-card {
        width: 100%;
        margin: 0 auto;
        max-width: 280px;
    }
    
    .owl-carousel {
        padding: 0 15px;
    }
    
    .owl-carousel .owl-stage-outer {
        padding: 10px 0 30px;
    }
    
    /* Imágenes del mismo tamaño que Los Más Vendidos */
    .owl-carousel .item .product-card img,
    .carousel-product-image {
        width: 125% !important;
        max-width: 125% !important;
    }
    
    /* Hover effect igual que Los Más Vendidos */
    .owl-carousel .item .product-card:hover img,
    .owl-carousel .item .product-card:hover .carousel-product-image {
        transform: scale(1.3);
    }
}

/* Animaciones para carrusel */
@keyframes fadeIn {
    from {
        opacity: 0;
        transform: translateY(20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.owl-carousel .item {
    animation: fadeIn 0.5s ease-out;
}