
    :root{
      --nav-h: 72px;
      --c-prim: rgb(14,64,75);     /* azul verdoso */
      --c-accent: rgb(138,177,48); /* verde */
      --c-warm: rgb(228,132,32);   /* naranja */
      --c-soft: rgb(250,241,232);  /* crema */
      --text-dark: #113039;
    }
    body{ font-family: System-ui, -apple-system, Segoe UI, Roboto, "Helvetica Neue", Arial, "Noto Sans", "Liberation Sans", sans-serif; color: var(--text-dark); scroll-behavior: smooth; }
    .btn-primary{ background: var(--c-prim); border-color: var(--c-prim);} 
    .btn-primary:hover{ background: #0c3a45; border-color: #0c3a45; }
    .btn-accent{ background: var(--c-accent); border-color: var(--c-accent); color:#fff; }
    .btn-accent:hover{ background:#88a82f; border-color:#88a82f; }

    .navbar{ box-shadow: 0 4px 14px rgba(0,0,0,.06); }
    .navbar-brand img{ height: 44px; }
    .nav-link{ font-weight: 600; }
    
    .hero{
      background: linear-gradient(180deg, var(--c-soft) 0%, #fff 100%);
      padding-top: 7rem; padding-bottom: 4rem;
    }
    .hero h1{ color: var(--c-prim); font-weight: 800; letter-spacing: .2px; }
    .hero p.lead{ font-size: 1.15rem; }

    .pill{ display:inline-block; padding:.35rem .75rem; border-radius: 999px; background: var(--c-warm); color:#fff; font-weight:700; letter-spacing:.3px; }

    .section-title{ color: var(--c-prim); font-weight:800; }
    .section-sub{ color: var(--c-prim); opacity:.75; }
    section[id] { scroll-margin-top: calc(var(--nav-h) + 8px); }


    .icon-badge{ flex:0 0 3rem; width:3rem; height:3rem; min-width:3rem; min-height:3rem; border-radius:50%; display:inline-flex; align-items:center; justify-content:center; line-height:1; background: var(--c-accent); color:#fff; }
    .icon-badge i{ font-size:1.25rem; line-height:1; }

    .program-item{ border-left: 4px solid var(--c-warm); padding-left: 1rem; margin-bottom:1.25rem; }

    .speaker-card{ border:0; box-shadow: 0 10px 30px rgba(0,0,0,.06); border-radius:1rem; overflow:hidden; }
    .speaker-tag{ font-size:.85rem; font-weight:700; color:#fff; background: var(--c-accent); padding:.2rem .5rem; border-radius:.5rem; }

    .bg-soft{ background: var(--c-soft); }
    .bg-prim{ background: var(--c-prim); }

    .sponsor-logo{ height: 56px; object-fit: contain; filter: grayscale(100%); opacity:.85; transition: .2s ease; }
    .sponsor-logo:hover{ filter: none; opacity:1; }

    footer{ background: #0f2d35; color:#dfe9ec; }
    footer a{ color:#cde7cd; }

    html { scroll-behavior: smooth; }

    .whatsapp-fab{ position:fixed; right:1rem; bottom:1rem; z-index:1030; }
    .whatsapp-fab.btn{ width:56px; height:56px; padding:0; border-radius:50%; display:inline-flex; align-items:center; justify-content:center; }
 
    /* ===== Programa: grid (<=3 días) y carrusel (>3 días) ===== */
.prog-grid .day-card{height:100%}
.prog-grid .day-card .card{height:100%}

/* Carrusel */
.prog-scroller-wrap{ position:relative; }
.prog-scroller{
  display:flex; gap:1rem; overflow-x:auto; padding-bottom:.25rem;
  scroll-snap-type:x mandatory;
}
.prog-scroller::-webkit-scrollbar{height:8px}
.prog-scroller::-webkit-scrollbar-thumb{background:#cfd8dc;border-radius:8px}

/* Cada tarjeta dentro del carrusel */
.prog-scroller .day-card{
  scroll-snap-align:start;
  flex:0 0 auto;
  min-width: clamp(260px, 32%, 360px);  /* ~3 por fila en desktop, 1-2 en móvil */
}

/* Flechas */
.prog-navbtn{
  position:absolute; top:50%; transform:translateY(-50%);
  width:40px; height:40px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  background:#fff; border:1px solid rgba(0,0,0,.1); box-shadow:0 2px 6px rgba(0,0,0,.08);
  z-index:2;
}
.prog-navbtn[disabled]{opacity:.45; cursor:not-allowed}
.prog-navbtn.prev{ left:-.5rem; }
.prog-navbtn.next{ right:-.5rem; }

/* En móvil mejor usar swipe; ocultamos flechas para no tapar contenido */
@media (max-width: 767.98px){
  .prog-navbtn{ display:none; }
}

/* === Programa (grid 1–3 días): igualar altura de cards === */
.prog-grid > [class^="col-"],
.prog-grid > [class*=" col-"]{ display:flex; }   /* hace flex a cada columna */
.prog-grid .day-card{ display:flex; width:100%; } /* wrapper estirable */
.prog-grid .day-card > .card,
.prog-grid .day-card > .bg-soft{
  display:flex; flex-direction:column; flex:1 1 auto; height:100%;
}

/* Conferencistas: imagen consistente */
.speaker-card .card-img-top{
  width:100%;
  aspect-ratio: 4 / 3;   /* recuadro estable */
  object-fit: cover;     /* crop visual */
}

/* ===== Conferencistas: carrusel (>3) ===== */
.spk-scroller-wrap{ position:relative; }
.spk-scroller{
  display:flex; gap:1rem; overflow-x:auto; padding-bottom:.25rem;
  scroll-snap-type:x mandatory;
}
.spk-scroller::-webkit-scrollbar{height:8px}
.spk-scroller::-webkit-scrollbar-thumb{background:#cfd8dc;border-radius:8px}

/* Cada tarjeta del carrusel: ancho fijo y snap */
.spk-card{
  flex:0 0 auto;
  width: clamp(260px, 30%, 360px);     /* fuerza un ancho útil (no ocupa todo el contenedor) */
  scroll-snap-align:start;
}

/* Reutilizamos el estilo de flechas del programa */
.spk-navbtn{ composes: prog-navbtn; }  /* si tu build no soporta 'composes', usa la clase prog-navbtn directamente */

/* Ocultar scrollbar en carouseles (Conferencistas y Programa) */
.spk-scroller,
.prog-scroller{
  -ms-overflow-style: none;  /* IE/Edge antiguo */
  scrollbar-width: none;     /* Firefox */
}
.spk-scroller::-webkit-scrollbar,
.prog-scroller::-webkit-scrollbar{
  width: 0;
  height: 0;                 /* Chrome/Safari/Edge */
}

/* Flechas del carrusel: visibles también en móvil (más pequeñas) */
@media (max-width: 767.98px){
  .prog-navbtn{                /* usamos la misma clase que ya tienes */
    display:flex;              /* sobrescribe cualquier display:none previo */
    width:36px; height:36px;
    opacity:.9;
  }
  .prog-navbtn.prev{ left:.25rem; }
  .prog-navbtn.next{ right:.25rem; }
}

/* Hint de swipe (Conferencistas y Programa) */
.spk-hint, .prog-hint{
  position:absolute; left:50%; bottom:.6rem; transform:translateX(-50%);
  background:rgba(0,0,0,.55); color:#fff; padding:.35rem .6rem;
  border-radius:999px; font-size:.85rem; line-height:1; 
  display:flex; align-items:center; gap:.35rem;
  pointer-events:none; z-index:3; transition:opacity .3s ease, visibility .3s ease;
}
.spk-hint.hide, .prog-hint.hide{ opacity:0; visibility:hidden; }

/* ===== Patrocinadores: marquee continuo ===== */
.sponsors-marquee{
  position: relative;
  overflow: hidden;
  /* desvanecido en bordes (Safari usa -webkit-mask) */
  -webkit-mask-image: linear-gradient(to right, transparent 0, #000 48px, #000 calc(100% - 48px), transparent 100%);
          mask-image: linear-gradient(to right, transparent 0, #000 48px, #000 calc(100% - 48px), transparent 100%);
}
.sponsors-track{
  display: flex; align-items: center; gap: 3rem;
  width: max-content;               /* ancho según contenido */
  animation: sponsors-scroll var(--marquee-speed, 28s) linear infinite;
}
.sponsors-marquee:hover .sponsors-track{ animation-play-state: paused; } /* pausa al hover en desktop */
@keyframes sponsors-scroll{
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); } /* moveremos 2× el contenido, así 50% = 1 ciclo */
}

/* Responsive tweaks */
@media (max-width: 991.98px){
  .sponsors-track{ gap: 2rem; }
  .sponsor-logo{ height: 44px; }  /* ya tienes 56px por defecto */
}
@media (max-width: 575.98px){
  .sponsors-track{ gap: 1.25rem; }
  .sponsor-logo{ height: 40px; }
}

/* Accesibilidad: si el usuario pide menos movimiento, detenemos la animación */
@media (prefers-reduced-motion: reduce){
  .sponsors-track{ animation: none; }
}







