/* ===== RESET ===== */
* { margin: 0; padding: 0; box-sizing: border-box; }
html, body { width: 100%; }
body { font-family: 'Inter', Arial, sans-serif; background:#fff; color:#000; overflow-x: hidden; }
header { margin: 0; }

/* ===== NAVBAR (compartido) ===== */
.header-principal,
.header-secundario {
  position:fixed; top:0; left:0; right:0; z-index:1000; background:#000;
}
.navbar {
  display:flex; align-items:center; background:#000; padding:4px 20px;
  position:relative; z-index:10; width:100%; box-sizing:border-box;
}

/* Logo */
.logo { flex:0 0 auto; }
.logo img { height:40px; width:auto; display:block; transition: height .2s ease, filter .2s ease; }
.logo a:hover img { filter: brightness(.9); }

/* Menú centrado (desktop) */
.menu-wrapper {
  position:absolute; left:50%; transform:translateX(-50%);
  display:flex; justify-content:center;
}
.menu { list-style:none; display:flex; gap:30px; }
.menu li { position:relative; }
.menu a { color:#fff; text-decoration:none; padding:6px 10px; display:block; transition: color .2s; }
.menu a:hover { color:#0ea5e9; }

/* Submenús (desktop: hover) */
.submenu {
  display:none; position:absolute; top:100%; left:0;
  background:#222; list-style:none; width:max-content; padding:4px 0; white-space:nowrap;
  border-radius:8px; box-shadow:0 8px 20px rgba(0,0,0,.2);
}
.menu li:hover .submenu,
.right-menu li:hover .submenu { display:block; }
.submenu a { padding:8px 12px; }

/* Lado derecho */
.right-side { margin-left:auto; display:flex; align-items:center; gap:18px; }
.right-menu { list-style:none; display:flex; gap:24px; }
.right-menu > li { position:relative; }
.right-menu a { color:#fff; text-decoration:none; padding:6px 10px; display:block; transition: color .2s; }
.right-menu a:hover { color:#0ea5e9; }

/* Íconos redes (desktop) */
.social-icons { display:flex; align-items:center; gap:15px; }
.social-icons img { width:20px; height:20px; filter:brightness(0) invert(1); transition: transform .2s; }
.social-icons img:hover { transform: scale(1.1); }

/* Header principal/ secundario y shrink */
.header-principal { padding:4px 20px; }
.header-principal .logo img { height:52px; }
.header-principal .navbar { transition: padding .2s ease; }
.header-secundario { padding:2px 0; }
.header-secundario .logo img { height:40px; }
.header-principal.shrink .navbar { padding:2px 20px; }
.header-principal.shrink .logo img { height:36px; }

/* Compensación de header fijo */
body.has-sticky { padding-top: var(--header-h, 72px); }

/* Evita margen colapsado del primer hijo bajo body.has-sticky */
body.has-sticky > *:first-child { margin-top: 0 !important; }

/* Evita que el primer bloque “empuje” hacia arriba (colapso de márgenes) */
body.has-sticky > *:first-child { margin-top: 0 !important; }

/* Por si acaso tu slider tenía margen superior en alguna variante */
.slider { margin-top: 0 !important; }

/* El slider debe empezar pegado al header */
.slider { margin-top: 0 !important; }

/* ===== SLIDER ===== */
.slider {
  width:100vw; height:650px; position:relative; left:50%; right:50%;
  margin-left:-50vw; margin-right:-50vw; overflow:hidden;
}
.slide { position:absolute; inset:0; opacity:0; transition: opacity 1s ease-in-out; }
.slide img { width:100%; height:100%; object-fit:cover; display:block; }
.slide.active { opacity:1; z-index:1; }

/* ===== Animación de aparición para el grid de categorías ===== */
/* Estado estable después de la entrada */
.grid-menu.in-view .menu-item {
  opacity: 1;
  transform: none;
}
.grid-menu .menu-item {
  opacity: 0;
  transform: translateY(40px);
}

.grid-menu.in-view .menu-item:nth-child(1) {
  animation: slide-in-left 0.7s ease-out 0.05s;
}
.grid-menu.in-view .menu-item:nth-child(2) {
  animation: slide-in-up 0.7s ease-out 0.15s;
}
.grid-menu.in-view .menu-item:nth-child(3) {
  animation: slide-in-right 0.7s ease-out 0.25s;
}

@keyframes slide-in-left {
  from { transform: translateX(-200px); opacity: 0; }
  to { transform: translateX(0); opacity: 1; }
}
@keyframes slide-in-up {
  from { transform: translateY(200px); opacity: 0; }
  to { transform: translateY(0); opacity: 1; }
}
@keyframes slide-in-right {
  from { transform: translateX(200px); opacity: 0; }
  to { transform: translateX(0); opacity: 1; }
}


/* ===== CATEGORÍAS ===== */
.cat { padding:60px 20px; max-width:1200px; margin:0 auto; color:#555; }
.cat-header { text-align:center; max-width:900px; margin:0 auto 30px; }
.cat-header h2 { font-size:34px; letter-spacing:2px; color:#777; margin-bottom:10px; }
.cat-header p { line-height:1.7; font-size:16px; color:#6f6f6f; }

.cat-grid { display:grid; grid-template-columns: repeat(2, 1fr); gap:40px; align-items:start; margin-top:20px; }
.model { text-align:center; transition: transform .2s ease, filter .2s ease; }
.model img { width:100%; height:auto; max-height:340px; object-fit:contain; filter: drop-shadow(0 12px 24px rgba(0,0,0,.15)); }
.model:hover { transform: translateY(-4px) scale(1.02); filter: brightness(0.95); }
.model h3 { margin:18px 0 8px; font-size:24px; color:#888; letter-spacing:.5px; }
.model p { max-width:520px; margin:0 auto 14px; color:#7a7a7a; line-height:1.6; }
/* Centrar tarjetas cuando el grid es de una sola columna */
.cat-grid.single {
  grid-template-columns: 1fr;   /* asegura una columna */
  justify-items: center;        /* centra el/los hijos en el eje horizontal */
}

.cat-grid.single .model {
  max-width: 620px;             /* limita ancho para que no se vea “gigante” */
  width: 100%;
}

/* Botones modernos */
.cta {
  display:inline-block;
  font-weight:700;
  text-decoration:none;
  padding:12px 28px;
  border-radius:9999px;  /* pill completo */
  background: linear-gradient(135deg, #000000, #d6d6d6);
  color:#fff;
  box-shadow:0 6px 14px rgba(0,0,0,0.25);
  transition: all 0.25s ease;
  letter-spacing: .5px;
}

.cta:hover {
  transform: translateY(-3px) scale(1.03);
  background: linear-gradient(135deg, #d6d6d6, #000000);
  box-shadow:0 10px 20px rgba(0,0,0,0.35);
}
/* ===== PARALLAX (index) ===== */

/* ===== PARALLAX (todas las secciones: imagen o video) ===== */

/* Secciones parallax con imagen (ya lo usas con .parallax-sep) */
.parallax-sep {
  position: relative;
  width: 100%;
  height: clamp(450px, 32vh, 280px);  /* altura reducida y responsiva */
  background-size: cover;
  background-position: center;
  background-attachment: fixed;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  text-align: center;
  overflow: hidden;
}
.parallax-sep::before {
  content:"";
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.4);
}
.parallax-sep .parallax-overlay {
  position: relative;
  z-index: 1;
  padding: 20px;
}

/* Secciones parallax con VIDEO (ej. bicicletas-montana) */
.video-sep {
  position: relative;
  width: 100%;
  height: clamp(450px, 32vh, 450px);  /* misma altura que las de imagen */
  overflow: hidden;
}
.video-sep .video-bg {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}
.video-sep .video-overlay {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  color: #fff;
  padding: 16px;
  background: rgba(0,0,0,.25);
}

/* Ajustes responsivos */
@media (max-width: 900px) {
  .parallax-sep,
  .video-sep {
    height: clamp(200px, 32vh, 380px);
    background-attachment: scroll; /* evita saltos en móviles */
  }
}

.parallax {
  position:relative; min-height:480px; background-image:url('../assets/parallax-bg.jpg');
  background-size:cover; background-position:center; background-attachment:fixed;
  display:flex; justify-content:center; align-items:center; text-align:center; color:#fff; overflow:hidden;
}
.parallax::before { content:""; position:absolute; inset:0; background: rgba(0,0,0,.45); }
.parallax-content { position:relative; z-index:1; padding:20px; }
.parallax h2 { font-size:32px; margin-bottom:10px; }
.parallax p { font-size:18px; }
@media (max-width: 900px) { .parallax { background-attachment:scroll; min-height:300px; } }

/* ===== LISTADO PRODUCTOS ===== */
.productos { padding:40px 20px; text-align:center; }
.grid-productos { display:grid; grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); gap:40px; margin-top:30px; padding-bottom:20px; }

/* === GRID FAMILIA SPARK RC (centrado y 3→1 columnas) === */
.grid-productos.grid-familia {
  /* layout */
  grid-template-columns: repeat(3, minmax(360px, 1fr));

  /* centrar el grid dentro de la página */
  max-width: 1100px;
  margin: 40px auto 40px;  /* auto centra; mismo patrón que .family-header */
  padding: 0 20px;

  /* por si alguna tarjeta no ocupa todo el track, centramos su contenido */
  justify-content: center;
  justify-items: center;
}

@media (max-width: 900px) {
  .grid-productos.grid-familia {
    grid-template-columns: 1fr;  /* móvil: 1 por fila */
    max-width: 680px;            /* para que no se vea “gigante” */
  }
}

.producto { display:block; background:#fff; border-radius:10px; box-shadow:0 4px 12px rgba(0,0,0,.1); overflow:hidden; text-align:center; padding:20px; text-decoration:none; color:inherit; transition: transform .2s ease, box-shadow .2s ease; }
.producto img {
  width: 100%;
  height: 200px;            /* mantiene todas las tarjetas con el mismo alto */
  object-fit: contain;      /* asegura que la bici quepa completa */
  object-position: center;  /* centra la imagen dentro del recuadro */
  background-color: #fff;   /* relleno blanco en caso de que sobre espacio */
}
.producto h3 { margin:15px 0 8px; font-size:18px; color:#222; }
.producto p { color:#666; }
.producto .precio { font-weight:700; color:#e60000; margin-top:10px; }
.producto:hover { transform: translateY(-4px); box-shadow:0 8px 20px rgba(0,0,0,.15); }


/* ===== BREADCRUMB ===== */
.breadcrumb { max-width:1200px; margin:16px auto 0; padding:0 20px; font-size:14px; color:#666; }
.breadcrumb a { color:#0ea5e9; text-decoration:none; }
.breadcrumb a:hover { text-decoration:underline; }
.header-secundario + .breadcrumb,
.header-principal + .breadcrumb { margin-top: calc(var(--header-h, 72px) + 8px); }

/* ===== DETALLE MODELO ===== */

/* === ESPECIFICACIONES (detalle) usando specs-*** === */
.specs-detalle { max-width:1100px; margin:40px auto; padding:0 20px; }
.specs-detalle h2 { text-align:center; margin-bottom:16px; color:#333; }

/* dos columnas en desktop, pila en móvil */
.specs-grid { display:grid; grid-template-columns: 1fr 1fr; gap:24px; }
@media (max-width: 900px){
  .specs-grid { grid-template-columns: 1fr; }
}

/* tabla visual (equivalente a .ficha-table) */
.specs-table { width:100%; border-collapse:collapse; background:#fff; border-radius:10px; overflow:hidden; }
.specs-table th, .specs-table td { padding:12px 14px; border-bottom:1px solid #eee; text-align:left; }
.specs-table th { width:35%; color:#444; background:#fafafa; }
.specs-note { margin-top:10px; font-size:13px; color:#777; text-align:center; }

.modelo-hero { text-align:center; padding:24px 20px 10px; }
.modelo-hero h1 { font-size:34px; color:#222; }
.modelo-hero p { color:#666; }
.modelo-hero .precio { margin-top:8px; font-weight:700; color:#e60000; font-size: 25px; }

/* Tamaño consistente para la imagen principal del detalle */
.modelo-imagen {
  /* Caja “estándar” de altura para la foto */
  height: clamp(360px, 52vh, 520px);
  max-width: 1100px;        /* igual que el resto del layout */
  margin: 20px auto 40px;   /* centrado (repite tu margen) */
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 0 20px;          /* respiro lateral en pantallas estrechas */
}

.modelo-imagen img {
  max-height: 100%;         /* que no supere la caja */
  width: auto;              /* conserva proporción */
  max-width: 100%;          /* no desborda horizontalmente */
  object-fit: contain;      /* se ve completa, sin recortes */
  display: block;
}

.modelo-contenido { display:grid; grid-template-columns:1fr 1fr; gap:40px; max-width:1100px; margin:30px auto; padding:0 20px; }
.modelo-ficha h2, .modelo-descripcion h2 { font-size:22px; margin-bottom:10px; color:#333; }
.ficha-table { width:100%; border-collapse:collapse; background:#fff; border-radius:10px; overflow:hidden; }
.ficha-table th, .ficha-table td { padding:12px 14px; border-bottom:1px solid #eee; text-align:left; }
.ficha-table th { width:35%; color:#444; background:#fafafa; }
.modelo-descripcion p { color:#555; line-height:1.7; }

.modelo-contenido.solo-descripcion { grid-template-columns:1fr; max-width:800px; }
.modelo-descripcion { text-align:center; }

/* CTA */
.modelo-cta { margin-top:20px; display:flex; justify-content:center; align-items:center; gap:16px; flex-wrap:wrap; text-align:center; }
.modelo-cta a {
  display:inline-flex; align-items:center; justify-content:center;
  padding:12px 22px; border-radius:30px; font-weight:700; font-size:16px;
  text-decoration:none; transition: transform .25s ease, box-shadow .25s ease, background .25s ease;
  box-shadow:0 4px 10px rgba(0,0,0,.15); letter-spacing:.5px;
}
.btn-whatsapp { background: linear-gradient(135deg, #25D366, #20b958); color:#fff; }
.btn-whatsapp:hover { background: linear-gradient(135deg, #20b958, #1a9e4b); transform: translateY(-3px) scale(1.03); box-shadow: 0 6px 14px rgba(32,185,88,0.35); }
.btn-whatsapp .icono-btn { width:20px; height:20px; display:inline-block; margin-right:8px; object-fit:contain; }
.btn-sec { background: linear-gradient(135deg, #111, #333); color:#fff; }
.btn-sec:hover { background: linear-gradient(135deg, #000, #222); transform: translateY(-3px) scale(1.03); box-shadow: 0 6px 14px rgba(0,0,0,0.35); }
.modelo-cta a:active { transform: scale(0.97); }

/* ===== RELACIONADOS ===== */
.relacionados { max-width:1100px; margin:40px auto 60px; padding:0 20px; }
.relacionados h2 { text-align:center; margin-bottom:16px; color:#333; }
.grid-relacionados { display:grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap:24px; }
.grid-relacionados .producto { display:block; background:#fff; border-radius:10px; box-shadow:0 4px 12px rgba(0,0,0,.1); overflow:hidden; text-align:center; padding:16px; text-decoration:none; color:inherit; transition: transform .2s, box-shadow .2s; }
.grid-relacionados .producto img { width:100%; height:180px; object-fit:cover; }
.grid-relacionados .producto h3 { margin:10px 0 4px; color:#222; }
.grid-relacionados .producto .precio { color:#e60000; font-weight:700; }
.grid-relacionados .producto:hover { transform: translateY(-4px); box-shadow:0 8px 20px rgba(0,0,0,.15); }

/* === RELACIONADOS: hasta 3 por fila, centrados si hay menos === */
.relacionados .grid-relacionados {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(400px, 1fr)); /* flexibles */
  max-width: 1500px;
  margin: 24px auto 48px;
  padding: 0 20px;
  gap: 48px;
  justify-content: center;   /* centra el conjunto si hay menos columnas */
  justify-items: center;     /* centra cada tarjeta dentro de su celda */
}

/* mismas proporciones que spark-rc.html */
.relacionados .grid-relacionados .producto img {
  width: 100%;
  height: 300px;
  object-fit: contain;
  object-position: center;
  background-color: #fff;
}

@media (max-width: 900px) {
  .relacionados .grid-relacionados {
    grid-template-columns: 1fr;   /* siempre 1 por fila en móvil */
    max-width: 680px;
    gap: 24px;
  }
}

/* cinturón de seguridad: si por alguna razón se cargan más de 3, ocúltalos */
.relacionados .grid-relacionados > *:nth-child(n+4) {
  display: none;
}


/* ===== INTERACCIÓN GLOBAL ===== */
a, button, [role="button"], input[type="submit"], input[type="button"], .clickable { cursor:pointer; transition: all .2s ease; }
a:hover, button:hover, [role="button"]:hover, input[type="submit"]:hover, input[type="button"]:hover, .clickable:hover { filter: brightness(.95); }
a:not(.cta):hover { color:#0ea5e9; }

/* ===== FOOTER ===== */
.main-footer { background:#000; color:#fff; text-align:center; padding:20px; }
.main-footer p { margin:6px 0; }
.main-footer a { color:#0ea5e9; text-decoration:none; font-weight:600; transition: color .2s; }
.main-footer a:hover { color:#38bdf8; }
.footer-social { margin:10px 0; display:flex; justify-content:center; gap:16px; }
.footer-social a img { width:22px; height:22px; filter:brightness(0) invert(1); transition: transform .2s, filter .2s; }
.footer-social a img:hover { transform: scale(1.15); filter: brightness(1) invert(0); }

/* ===== RESPONSIVE BASE ===== */
@media (max-width: 980px){
  .menu-wrapper { position: static; transform:none; margin:0 auto; }
  .navbar { justify-content: space-between; }
  .modelo-contenido { grid-template-columns: 1fr; }
}
@media (max-width: 900px) {
  .cat-grid { grid-template-columns:1fr; gap:28px; }
  .model img { max-height:300px; }
  .parallax { background-attachment:scroll; min-height:240px; }
}

/* ===== HAMBURGUESA (icono) ===== */
.hamburger {
  display:none; position:relative;
  width:42px; height:42px; border:0; background:transparent; cursor:pointer;
}
.hamburger::before,
.hamburger::after,
.hamburger span {
  content:""; position:absolute; left:10px; right:10px; height:2px; background:#fff;
  transition: transform .25s, opacity .2s;
}
.hamburger::before { top:14px; }
.hamburger span     { top:20px; }
.hamburger::after  { top:26px; }
body.nav-open .hamburger::before { transform:translateY(6px) rotate(45deg); }
body.nav-open .hamburger::after  { transform:translateY(-6px) rotate(-45deg); }
body.nav-open .hamburger span    { opacity:0; }

@media (max-width: 768px) {
  /* Mostrar el header disponible en móvil (principal o secundario) */
  .header-principal,
  .header-secundario {
    display: block !important;
    visibility: visible !important;
  }

  /* El resto de tus reglas móviles se quedan igual */
  .hamburger{ display:block; margin-left:12px; }
  .menu-wrapper, .right-side { display:none; }

  body.nav-open #navPanel,
  body.nav-open .menu-wrapper {
    display:block;
    position: fixed;
    top: calc(var(--header-h, 64px) + 8px);
    right: 12px;                 /* anclado a la derecha (tu preferencia) */
    width: min(50vw, 360px);
    max-height: 70vh;
    overflow: auto;
    background: rgba(10,10,10,.96);
    border: 1px solid #ffffff;
    border-radius: 16px;
    box-shadow: 0 16px 40px rgba(0,0,0,.55);
    padding: 10px;
    z-index: 1002;
  }

  /* Listado en columna + acordeón (tus reglas actuales) */
  .menu { flex-direction: column; align-items: stretch; gap: 6px; }
  .menu a { padding: 10px 12px; font-size: 15.5px; border-radius: 10px; }
  .menu li, .right-menu li { position: static; }
  .submenu {
    position: static; display: none; width: 100%;
    margin: 6px 0 0; padding: 6px 0;
    background: #0b0b0b;
    border: 1px solid #ffffff;
    border-radius: 10px; box-shadow: none;
  }
  .menu li.open > .submenu,
  .right-menu li.open > .submenu { display: block; }
}



/* === AJUSTES MÓVIL HEADER + PANEL A LA DERECHA === */
@media (max-width: 768px) {
  /* 1) Tamaño del logo en móvil + shrink al hacer scroll */
  .header-principal .logo img { height: 40px; }        /* tamaño base en móvil */
  .header-principal.shrink .logo img { height: 35px; }  /* al hacer scroll */

  /* Más compacto para que no tape la hamburguesa */
  .navbar { padding: 6px 12px; justify-content: space-between; }

  /* 2) Asegurar distribución: logo izq., hamburguesa der. */
  .logo { order: 1; }
  .hamburger {
    order: 2;
    margin-left: auto;           /* empuja a la derecha */
    z-index: 1003;               /* por encima del logo */
    width: 44px; height: 44px;   /* toque cómodo */
  }

  /* 3) Panel del menú anclado a la DERECHA (no a la izquierda) */
  body.nav-open .menu-wrapper {
    left: auto;                  /* anulamos el anclaje izquierdo */
    right: 12px;                 /* anclado a la derecha */
    top: calc(var(--header-h, 64px) + 8px);
    width: min(50vw, 360px);     /* mitad de la pantalla aprox. */
  }
}

@media (max-width: 768px) {
  .navbar { position: relative; }        /* contenedor de referencia */
  .hamburger{
    position: absolute;
    right: 2px;                          /* sepárala 6–8px del borde */
    top: 50%;
    transform: translateY(-50%);         /* centrada verticalmente */
    margin: 0;                           /* anula márgenes del layout */
  }
}
/* Submenú visible cuando el item está "open" (clic) */
.menu li.open > .submenu,
.right-menu li.open > .submenu {
  display: block;
}

/* MÓVIL: desactiva hover y usa solo .open para abrir/cerrar */
@media (max-width: 768px) {
  .menu li:hover > .submenu,
  .right-menu li:hover > .submenu {
    display: none !important;         /* evita que el hover lo deje abierto */
  }
  .menu li.open > .submenu,
  .right-menu li.open > .submenu {
    display: block !important;        /* abre/cierra con el mismo clic */
  }
}

/* Cuando entra en pantalla */
.grid-menu.in-view .menu-item {
  visibility: visible;       /* <-- se muestran al comenzar la animación */
}

/* === HOME • GRID-MENU (limpiar recuadro gris y aplicar card moderna) === */
.grid-menu{
  display:grid;
  grid-template-columns: repeat(3, minmax(280px, 1fr));
  gap: 28px;
  max-width: 1100px;
  margin: 40px auto 60px;
  padding: 0 20px;
  background: transparent;              /* sin fondo gris en la sección */
}

/* tarjeta */
.grid-menu .menu-item{
  position: relative;
  display: block;
  overflow: hidden;
  border-radius: 0px;
  background: #fff;                      /* ¡blanca! */
  box-shadow: 0 8px 24px rgba(0,0,0,.08);/* sombra compacta, sin “aura” enorme */
  border: 1px solid rgba(0,0,0,.06);
  text-align: center;
  transform: translateY(12px);           /* estado inicial animación */
  opacity: 0;                            /* estado inicial animación */
  transition: all 0.3s ease;
}

/* entrada (tu JS añade .in-view) */
.grid-menu .menu-item.in-view{
  transform: translateY(0);
  opacity: 1;
}

/* eliminar posibles fondos/sombras heredadas de wrappers viejos */
.grid-menu .menu-item::before,
.grid-menu .menu-item::after{
  content: none;                         /* por si había pseudo-elementos con blur gris */
}
.grid-menu .menu-item > *{
  background: transparent;               /* limpia fondos internos accidentales */
  box-shadow: none;                      /* evita doble sombra si existía */
}

/* imagen */
.grid-menu .menu-item img{
  width: 100%;
  height: clamp(180px, 22vw, 240px);
  object-fit: cover;                     /* usa contain si no quieres recorte */
  display: block;
  transition: transform .6s ease;
}

 /* === EFECTO HOVER: el cuadro completo crece === */
.grid-menu .menu-item:hover {
  transform: translateY(-6px) scale(1.06);      /* el cuadro entero se agranda */
  box-shadow: 0 14px 36px rgba(0, 0, 0, 0.18);  /* sombra más profunda */
  border-color: #0ea5e9;                        /* borde azul */
  background: #fdfdfd;                          /* leve contraste */
  animation: none;
  transition: all 0.3s ease;
}

/* la imagen se mantiene estática, ya no se escala sola */
.grid-menu .menu-item img {
  width: 100%;
  height: clamp(180px, 22vw, 240px);
  object-fit: cover;
  display: block;
  transition: transform .6s ease;
}

.grid-menu .menu-item:hover img {
  transform: none;  /* evita que solo la imagen crezca */
}

/* título */
.grid-menu .menu-item h2{
  font-size: clamp(18px, 2.2vw, 22px);
  font-weight: 700;
  color: #111;
  margin: 14px 12px 18px;
}

/* accesible para teclado */
.grid-menu .menu-item:focus-visible{
  outline: none;
  box-shadow: 0 0 0 3px rgba(0,176,255,.35), 0 14px 38px rgba(0,0,0,.12);
}

/* Texto de las opciones del grid: sin subrayado, negro y hover azul */
.grid-menu .menu-item{
  text-decoration: none;             /* quita subrayado del <a> (la tarjeta es un <a>) */
  color: #111;                       /* color de texto por defecto */
}

/* título negro por defecto */
.grid-menu .menu-item h2{
  color: #111;
  text-decoration: none;
}

/* al pasar el mouse: cambia a azul */
.grid-menu .menu-item:hover,
.grid-menu .menu-item:hover h2{
  color: #0ea5e9;
}

/* accesibilidad: en foco con teclado conserva el contorno pero sin subrayado */
.grid-menu .menu-item:focus-visible{
  text-decoration: none;
}

/* móvil: 1 por fila */
@media (max-width: 900px){
  .grid-menu{ grid-template-columns: 1fr; gap: 22px; max-width: 680px; }
}

/* =========================================
   LOCALIZA - PÁGINA DE TIENDAS BICIVIK
   (Estilos solo para localiza.html)
   ========================================= */

.page-localiza .localiza-main {
  padding: 40px 20px;
  max-width: 1100px;
  margin: 0 auto;
}

.page-localiza .localiza-main h1 {
  font-size: clamp(2.1rem, 3vw, 2.6rem);
  font-weight: 700;
  letter-spacing: 0.02em;
  margin-bottom: 0.75rem;
}

.page-localiza .localiza-main > p {
  font-size: 1rem;
  line-height: 1.6;
  max-width: 720px;
  color: #333333;
  margin-bottom: 1.75rem;
}

/* Tarjeta visual para el mapa */
.page-localiza .mapa-localiza {
  margin-top: 20px;
  border-radius: 18px;
  overflow: hidden;
  background: #000000;
  box-shadow: 0 18px 45px rgba(0, 0, 0, 0.18);
}

/* Mapa responsivo, solo en localiza */
.page-localiza .mapa-localiza iframe {
  display: block;
  width: 100%;
  max-width: 100%;
  height: min(480px, 65vh);
  border: 0;
}

/* Responsive solo para localiza */
@media (max-width: 768px) {
  .page-localiza .localiza-main {
    padding: 80px 16px 40px;
  }

  .page-localiza .localiza-main h1 {
    font-size: 2rem;
  }

  .page-localiza .localiza-main > p {
    font-size: 0.95rem;
  }
}

/* === LOCALIZA • SUCURSALES (tarjetas) === */

.page-localiza .sucursales-section {
  margin-top: 40px;
  padding-bottom: 40px;
}

.page-localiza .sucursales-header {
  text-align: center;
  max-width: 720px;
  margin: 0 auto 28px;
}

.page-localiza .sucursales-header h2 {
  font-size: clamp(1.7rem, 2.6vw, 2rem);
  color: #111;
  margin-bottom: 8px;
}

.page-localiza .sucursales-header p {
  color: #555;
  font-size: 0.98rem;
  line-height: 1.7;
}

/* Grid de tarjetas de sucursal */
.page-localiza .sucursales-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(260px, 1fr));
  gap: 24px;
}

/* Tarjeta individual */
.page-localiza .sucursal-card {
  background: #ffffff;
  border-radius: 12px;
  box-shadow: 0 8px 22px rgba(0, 0, 0, 0.08);
  border: 1px solid rgba(0, 0, 0, 0.04);
  padding: 18px 18px 20px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  transition: box-shadow 0.25s ease, transform 0.25s ease, border-color 0.25s ease;
}

/* Hover: elevación ligera, sin romper otras animaciones globales */
.page-localiza .sucursal-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 14px 34px rgba(0, 0, 0, 0.14);
  border-color: #0ea5e9;
}

/* Cabecera de la sucursal (nombre + tag zona) */
.page-localiza .sucursal-header {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 10px;
}

.page-localiza .sucursal-header h3 {
  font-size: 1.05rem;
  color: #111;
}

/* Texto dentro de la tarjeta */
.page-localiza .sucursal-direccion,
.page-localiza .sucursal-horario,
.page-localiza .sucursal-extra {
  font-size: 0.92rem;
  line-height: 1.6;
  color: #444;
  margin-bottom: 8px;
}

.page-localiza .sucursal-direccion {
  font-weight: 500;
}

.page-localiza .sucursal-horario strong {
  font-weight: 700;
}

/* Botón/Link a Google Maps */
.page-localiza .cta-mapa {
  margin-top: 10px;
  align-self: flex-start;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 9px 18px;
  border-radius: 999px;
  background: linear-gradient(135deg, #000000, #1f2933);
  color: #ffffff;
  font-size: 0.9rem;
  font-weight: 600;
  text-decoration: none;
  box-shadow: 0 6px 14px rgba(0, 0, 0, 0.25);
  transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
}

.page-localiza .cta-mapa:hover {
  transform: translateY(-2px);
  background: linear-gradient(135deg, #111827, #000000);
  box-shadow: 0 10px 22px rgba(0, 0, 0, 0.32);
}

/* Responsive: 1–2 columnas en móvil/tablet */
@media (max-width: 980px) {
  .page-localiza .sucursales-grid {
    grid-template-columns: repeat(2, minmax(240px, 1fr));
  }
}

@media (max-width: 700px) {
  .page-localiza .sucursales-grid {
    grid-template-columns: 1fr;
  }
}

.page-localiza .sucursal-direccion {
  cursor: pointer;
  color: #0ea5e9;
  font-weight: 600;
  transition: color 0.2s ease;
}

.page-localiza .sucursal-direccion:hover {
  color: #0284c7;
  text-decoration: underline;
}

/* ===== SLIDER RESPONSIVE MÓVIL PARA PROMOCIONES ===== */
@media (max-width: 768px) {
  .slider {
    height: auto;
    aspect-ratio: 16 / 9;
    min-height: 220px;
    max-height: 360px;
    background: #000;
  }

  .slide {
    background: #000;
  }

  .slide img {
    object-fit: contain;
    object-position: center center;
    background: #000;
  }
}