.s2-menu-navbar {
            position: fixed;
            top: 0;
            width: 100%;
            z-index: 999;
            transition: background-color 0.4s ease, backdrop-filter 0.4s ease;
            background-color: rgba(0, 0, 0, 0.3);
            backdrop-filter: blur(6px);
            -webkit-backdrop-filter: blur(6px);
            padding: 10px 30px;
            border-bottom: 1px solid #FFF;
        }
        h5 {
          font-size: 18px;         
        }
        .bg-gradient-fast-blue-purple {
            background-image: linear-gradient(to right top, #73b90b, #73b90b, #73b90b, #1f640e, #1f640e);
        }

        .text-gradient-light-purple-light-orange {background: linear-gradient(to right, #73b90b, #73b90b, #73b90b, #1f640e, #1f640e); -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  }

        .s2-menu-nav .nav-link {
          color: white !important;
          font-weight: 500;
          text-transform: uppercase;
          margin-left: 20px;
          font-size: 18px;
        }

        .navbar .navbar-nav .nav-link {
          padding: 25px 0;
          font-weight: 500;
          font-size: 18px;
          margin: 0 10px;
          word-break: normal;
          color: #fff !important  ;
      }

        /* .s2-menu-nav .nav-link.active, */
       
        .carouseltext {
            color: #1f640e;
            font-size: 22px;
            font-weight: bold;
            /* background: #fff;  */
            display: flex;
            gap: 0 100px;
            overflow-x: hidden;
        }
        .carouseltext span{
            color: #1f640e;
            text-transform: uppercase;
            font-size: 22px;
            font-weight: bold;
            /* background: #fff; */
        display: inline-block;
        animation: scrollInfinite 20s linear infinite;
        white-space: nowrap;
        padding: 17px 0px
        }

        @keyframes scrollInfinite {
            0% {
                transform: translateX(100%);
            }
            100% {
                transform: translateX(-100%);
            }
        }

      :root{
        --fab-gold: #73b90b;   /* tono dorado del botón */
        --fab-gold-darker:#1f640e;  /* hover */
        --fab-outer:#fff;        /* anillo exterior */
        --fab-shadow: 0 8px 24px rgba(0,0,0,.18);
      }

      /* Contenedor principal */
      .fab-wrap{
        position: fixed;
        inset: auto 18px 18px auto; /* bottom-right */
        z-index: 1056; /* por encima del offcanvas/modal backdrop de Bootstrap */
        display: grid;
        gap: 12px;
        align-items: end;
        justify-items: end;
      }

      /* Overlay que oscurece el fondo cuando está abierto */
      .fab-overlay{
        position: fixed;
        inset: 0;
        background: rgba(0,0,0,.45);
        opacity: 0;
        pointer-events: none;
        transition: opacity .25s ease;
      }
      .fab-wrap.open ~ .fab-overlay{ /* hermano siguiente en el DOM */
        opacity: 1;
        pointer-events: auto;
        backdrop-filter: blur(2px);
      }

      /* Botón base (círculo) */
      .fab-btn{
        width: 64px;
        height: 64px;
        border: 0;
        border-radius: 50%;
        background: radial-gradient(closest-side, var(--fab-gold) 75%, var(--fab-outer) 76%);
        box-shadow: var(--fab-shadow);
        display: grid; place-items:center;
        cursor: pointer;
        transition: transform .18s ease, filter .18s ease;
      }
      .fab-btn:hover{ filter: brightness(1.03); }
      .fab-btn:active{ transform: scale(.98); }

      .fab-icon{ width: 28px; height: 28px; fill: #fff; }

      /* Botón de cierre (X grande) */
      .fab-close{
        width: 72px; height: 72px;
        background: radial-gradient(closest-side, #d9d9d9 75%, #ececec 76%);
      }
      .fab-close svg{ width: 30px; height: 30px; }

      /* Botones del menú (items) */
      .fab-item{
        width: 56px; height: 56px;
        border-radius: 50%;
        border: none;
        background: var(--fab-gold);
        box-shadow: var(--fab-shadow);
        display: grid; place-items: center;
        opacity: 0; transform: translateY(8px) scale(.96);
        pointer-events: none;
        transition: transform .25s cubic-bezier(.2,.7,.2,1), opacity .25s ease;
      }
      .fab-item:hover{ background: var(--fab-gold-darker); }

      /* Stagger al abrir */
      .fab-wrap.open .fab-item{
        opacity: 1; transform: translateY(0) scale(1);
        pointer-events: auto;
      }
      .fab-wrap.open .fab-item:nth-child(1){ transition-delay: 40ms; }
      .fab-wrap.open .fab-item:nth-child(2){ transition-delay: 90ms; }
      .fab-wrap.open .fab-item:nth-child(3){ transition-delay: 140ms; }

      /* Rotación del botón principal cuando se abre (cambia a X si usas la misma pieza) */
      .fab-main{ position: relative; }
      .fab-main .icon-open{ transition: transform .25s ease, opacity .2s ease; }
      .fab-main .icon-close{ position:absolute; inset:0; display:grid; place-items:center; opacity:0; transform: rotate(-90deg) scale(.6); }
      .fab-wrap.open .fab-main .icon-open{ opacity:0; transform: rotate(90deg) scale(.6); }
      .fab-wrap.open .fab-main .icon-close{ opacity:1; transform: rotate(0) scale(1); }

      /* Tooltips sutiles opcionales */
      .fab-label{
        position:absolute; right: 72px; /* a la izquierda del círculo */
        background: rgba(0,0,0,.72); color:#fff; font-size:.825rem;
        padding: .35rem .6rem; border-radius: .5rem; white-space: nowrap;
        opacity: 0; transform: translateX(6px);
        transition: opacity .2s ease, transform .2s ease;
        pointer-events: none;
        bottom: 15%;
      }
      .fab-item-wrap{ position: relative; }
      .fab-item-wrap:hover .fab-label{ opacity: 1; transform: translateX(0); }

      /* Soporte modo reducido (accesibilidad) */
      @media (prefers-reduced-motion: reduce){
        .fab-item, .fab-btn, .fab-overlay{ transition: none !important; }
      }

      .register-section {
      width: 100%;
      height: 180px; /* alto del banner */
      background: #1f640e; /* rojo intenso */
      display: flex;
      justify-content: center;
      align-items: center;
      cursor: pointer;
      overflow: hidden;
      position: relative;
      transition: background 0.3s ease;
    }
    .register-section:hover {
      background: #73b90b; /* rojo más oscuro al hover */
     
    }
    .register-text {
      font-size: 5rem; /* tamaño del texto */
      font-weight: 900;
      color: #fff;
      text-transform: uppercase;
      letter-spacing: 5px;
      display: flex;
      align-items: center;
      gap: 20px;
      transition: transform 0.4s ease;
    }
    .register-text:hover { color:#fff;}

    .register-section:hover .register-text {
      transform: scale(1.05); /* zoom del texto */
    }
    .register-text .arrow {
      font-size: 4.5rem;
      display: inline-block;
      transition: transform 0.4s ease;
    }
    .register-section:hover .arrow {
      transform: translateX(10px); /* mueve la flecha a la derecha */
    }

    /* MARQUEE */

    /* Contenedor de dos columnas del carrusel: ahora ocupa 100% de la altura disponible */
.dual-vert-marquee{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  padding: 10px;
  position: relative;
  height: 210vh;
  /* <— clave */
  isolation: isolate;
}

/* Desvanecido arriba/abajo (opcional) */
.dual-vert-marquee::before,
.dual-vert-marquee::after{
  content:"";
  position:absolute;
  left:0; right:0;
  /* height:40px; */
  pointer-events:none;
  z-index:2;
}
.dual-vert-marquee::before{
  top:0;
  background:linear-gradient(to bottom, rgba(255,255,255,1), rgba(255,255,255,0));
}
.dual-vert-marquee::after{
  bottom:0;
  background:linear-gradient(to top, rgba(255,255,255,1), rgba(255,255,255,0));
}

/* Cada columna del carrusel recorta a la altura completa */
.marquee-col{
  overflow: hidden;
  border-radius: 8px;
  /* height: 100%;           */
  /* <— clave */
}

/* Pista duplicada para bucle infinito */
.marquee-track{
  display: grid;
  grid-auto-rows: min-content;
  justify-items: center;
  animation: scroll-up var(--marquee-speed, 24s) linear infinite;
}
.marquee-reverse .marquee-track{
  animation-name: scroll-down;
}

/* Pausa al hover */
.marquee-col:hover .marquee-track{
  animation-play-state: paused;
}

/* Ítems */
.marquee-track img{
  width: 100%;
  max-width: 260px;
  /* height: auto; */
  display: block;
  padding: 10px;
  box-sizing: border-box;
  border-radius: 10px;
  background: #fff;
  box-shadow: 0 2px 10px rgba(0,0,0,.06);
}

/* Animaciones */
@keyframes scroll-up{
  0%   { transform: translateY(0); }
  100% { transform: translateY(-100%); }
}
@keyframes scroll-down{
  0%   { transform: translateY(-100%); }
  100% { transform: translateY(0); }
}


/* .row.align-items-stretch > [class*="col-"]{
  display: flex;
}
.row.align-items-stretch > [class*="col-"] > *{  
  width: 100%;
} */

/* Responsivo: cuando se apilan (<= lg), la altura 100% ya no tiene referencia,
   así que damos un mínimo para que el carrusel no colapse */
@media (max-width: 991.98px){
  .dual-vert-marquee{
    min-height: 420px;  /* ajusta a gusto, o usa 45vh */
  }
}
@media (max-width: 575.98px){
  .dual-vert-marquee{
    grid-template-columns: 1fr;
    min-height: 360px;
  }
}

/* Accesibilidad: reduce animaciones si el usuario lo pide */
@media (prefers-reduced-motion: reduce){
  .marquee-track{
    animation: none !important;
  }
}