/* =============================================================
   estacionamientos-para-bicicletas.css
   Estilos específicos de la página; depende de _shared.css.
   Todo bajo el wrapper .np-page para no contaminar global.
   ============================================================= */

/* -------- Hero --------
   El hero se expande al ras del viewport (top:0). El header fijo queda
   sobre fondo oscuro del hero (no sobre fondo claro), evitando el
   "halo gris" en la parte superior de la página. */
.np-hero {
  min-height: 100vh;
  background-color: var(--np-color-dark);
  color: var(--np-color-white);
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: calc(var(--np-header-height) + var(--np-space-6)) var(--np-space-4) var(--np-space-6);
}
.np-hero h1 {
  font-size: var(--np-fs-2xl);
  letter-spacing: var(--np-ls-md);
  font-weight: 900;
  margin-bottom: var(--np-space-3);
  max-width: 850px;
}
.np-hero__lead {
  font-family: var(--np-font-text);
  font-size: var(--np-fs-md);
  line-height: var(--np-lh-base);
  max-width: 680px;
  margin-bottom: var(--np-space-5);
  text-transform: none;
  letter-spacing: 0;
  color: rgba(255, 255, 255, 0.85);
}
.np-hero__index-label {
  font-family: var(--np-font-ui);
  font-weight: 600;
  letter-spacing: var(--np-ls-md);
  font-size: var(--np-fs-sm);
  text-transform: uppercase;
  color: var(--np-color-primary);
  margin-bottom: var(--np-space-3);
}
/* Hero index como chips horizontales */
.np-hero__index {
  display: flex;
  flex-wrap: wrap;
  gap: var(--np-space-2);
}
.np-hero__index a {
  font-family: var(--np-font-ui);
  font-weight: 600;
  font-size: var(--np-fs-xs);
  letter-spacing: var(--np-ls-sm);
  text-transform: uppercase;
  text-decoration: none;
  color: var(--np-color-white);
  background-color: rgba(255, 111, 0, 0.12);
  border: 1px solid rgba(255, 111, 0, 0.6);
  padding: 8px 14px;
  border-radius: 999px;
  transition: background-color 200ms ease, color 200ms ease, border-color 200ms ease;
}
.np-hero__index a:hover,
.np-hero__index a:focus-visible {
  background-color: var(--np-color-primary);
  color: var(--np-color-dark);
  border-color: var(--np-color-primary);
}
@media (min-width: 768px) {
  .np-hero h1    { font-size: var(--np-fs-hero); letter-spacing: var(--np-ls-md); }
  .np-hero__lead { font-size: var(--np-fs-lg); }
}

/* -------- Breadcrumbs -------- */
.np-breadcrumbs {
  background-color: var(--np-color-light);
  padding: var(--np-space-3) var(--np-space-4);
  border-bottom: 1px solid rgba(33, 33, 33, 0.08);
}
.np-breadcrumbs ol {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--np-space-2);
  list-style: none;
  padding: 0;
  margin: 0;
  max-width: var(--np-container-max);
  margin-inline: auto;
  font-family: var(--np-font-ui);
  font-size: var(--np-fs-xs);
  text-transform: uppercase;
  letter-spacing: var(--np-ls-sm);
}
.np-breadcrumbs li + li::before {
  content: "›";
  margin-right: var(--np-space-2);
  color: var(--np-color-dark);
  opacity: 0.5;
}
.np-breadcrumbs a {
  color: var(--np-color-dark);
  text-decoration: none;
}
.np-breadcrumbs a:hover { color: var(--np-color-primary); }
.np-breadcrumbs [aria-current="page"] {
  color: var(--np-color-accent);
  font-weight: 700;
}

/* -------- Sections base --------
   Títulos de sección centrados, tamaño moderado (no compite con h1),
   con línea de acento naranja debajo. Lead centrado, max-width legible. */
.np-section {
  padding: var(--np-space-7) var(--np-space-4);
}
.np-section__title {
  font-family: var(--np-font-ui);
  font-weight: 700;
  font-size: var(--np-fs-xl);
  letter-spacing: var(--np-ls-md);
  text-transform: uppercase;
  text-align: center;
  max-width: 820px;
  margin: 0 auto var(--np-space-3) auto;
}
.np-section__title::after {
  content: "";
  display: block;
  width: 56px;
  height: 4px;
  background-color: var(--np-color-primary);
  margin: var(--np-space-3) auto 0 auto;
  border-radius: 2px;
}
.np-section__lead {
  font-family: var(--np-font-text);
  font-size: var(--np-fs-base);
  line-height: var(--np-lh-base);
  text-align: center;
  max-width: 720px;
  margin: 0 auto var(--np-space-5) auto;
  text-transform: none;
  letter-spacing: 0;
  color: rgba(33, 33, 33, 0.78);
}
@media (min-width: 768px) {
  .np-section__title { font-size: var(--np-fs-2xl); }
  .np-section__lead  { font-size: var(--np-fs-md); }
}

/* -------- Intro descriptiva -------- */
.np-intro {
  background-color: var(--np-color-white);
}
.np-intro p {
  max-width: 720px;
  margin: 0 auto var(--np-space-3) auto;
  line-height: 1.7;
  font-size: var(--np-fs-base);
}
@media (min-width: 768px) {
  .np-intro p { font-size: var(--np-fs-md); }
}

/* -------- Grid de productos -------- */
.np-products-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: var(--np-space-4);
  max-width: var(--np-container-max);
  margin: 0 auto;
}
.np-product-card {
  background-color: var(--np-color-white);
  border-radius: var(--np-radius-lg);
  box-shadow: var(--np-shadow-md);
  padding: var(--np-space-3);
  display: flex;
  flex-direction: column;
  font-family: var(--np-font-ui);
  transition: transform 250ms ease, box-shadow 250ms ease;
}
.np-product-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--np-shadow-lg);
}
.np-product-card__media {
  background-color: var(--np-color-light);
  border-radius: var(--np-radius-md);
  display: flex;
  justify-content: center;
  align-items: center;
  padding: var(--np-space-3);
  margin-bottom: var(--np-space-3);
  overflow: hidden;
}
.np-product-card__media img {
  max-width: 100%;
  height: auto;
  aspect-ratio: 1 / 1;
  object-fit: contain;
  transition: transform 350ms ease;
}
.np-product-card:hover .np-product-card__media img {
  transform: scale(1.05);
}
.np-product-card__name {
  font-weight: 900;
  font-size: var(--np-fs-md);
  letter-spacing: var(--np-ls-sm);
  text-transform: uppercase;
  margin-bottom: var(--np-space-2);
  line-height: var(--np-lh-tight);
}
.np-product-card__specs {
  list-style: none;
  padding: 0;
  margin: 0;
  font-family: var(--np-font-text);
  font-size: var(--np-fs-sm);
  line-height: 1.6;
}
.np-product-card__specs li {
  display: flex;
  justify-content: space-between;
  gap: var(--np-space-2);
  border-bottom: 1px solid rgba(33, 33, 33, 0.08);
  padding: 6px 0;
}
.np-product-card__specs li:last-child { border-bottom: 0; }
.np-product-card__specs .np-spec-label {
  color: var(--np-color-dark);
  opacity: 0.6;
  text-transform: uppercase;
  font-size: var(--np-fs-xs);
  letter-spacing: var(--np-ls-sm);
  font-family: var(--np-font-ui);
  font-weight: 500;
}
.np-product-card__specs .np-spec-value {
  text-align: right;
  font-weight: 600;
}
.np-product-card__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: var(--np-space-3);
}
.np-tag {
  display: inline-block;
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: var(--np-ls-sm);
  text-transform: uppercase;
}
.np-tag--metal      { background: var(--np-color-neutral-bg); color: var(--np-color-neutral-fg); }
.np-tag--inox       { background: #cfe6f5;                     color: #1c5a86; }
.np-tag--individual { background: var(--np-color-warm-bg);     color: var(--np-color-warm-fg); }
.np-tag--multi      { background: var(--np-color-success-bg);  color: var(--np-color-success-fg); }

/* -------- Características / Ventajas -------- */
.np-features {
  background-color: var(--np-color-white);
}
.np-features__list {
  list-style: none;
  padding: 0;
  margin: 0 auto;
  max-width: var(--np-container-max);
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: var(--np-space-4);
  font-family: var(--np-font-text);
}
.np-features__list li {
  background-color: var(--np-color-light);
  border-radius: var(--np-radius-md);
  padding: var(--np-space-4);
  border-left: 4px solid var(--np-color-primary);
  font-size: var(--np-fs-base);
  line-height: var(--np-lh-base);
  transition: transform 200ms ease, box-shadow 200ms ease;
}
.np-features__list li:hover {
  transform: translateY(-2px);
  box-shadow: var(--np-shadow-sm);
}
.np-features__list strong {
  font-family: var(--np-font-ui);
  display: block;
  font-weight: 700;
  font-size: var(--np-fs-md);
  letter-spacing: var(--np-ls-sm);
  text-transform: uppercase;
  margin-bottom: var(--np-space-2);
  color: var(--np-color-dark);
}

/* -------- Aplicaciones -------- */
.np-applications__grid {
  list-style: none;
  padding: 0;
  margin: 0 auto;
  max-width: var(--np-container-max);
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  grid-auto-rows: 1fr; /* todas las filas misma altura */
  gap: var(--np-space-3);
  text-align: center;
}
/* En pantallas grandes, fijar a 4 columnas (8 items → 2 filas de 4) */
@media (min-width: 768px) {
  .np-applications__grid { grid-template-columns: repeat(4, 1fr); }
}
.np-applications__grid li {
  background-color: var(--np-color-white);
  border-radius: var(--np-radius-md);
  padding: var(--np-space-4) var(--np-space-3);
  font-family: var(--np-font-ui);
  font-weight: 500;
  font-size: var(--np-fs-sm);
  letter-spacing: var(--np-ls-sm);
  text-transform: uppercase;
  box-shadow: var(--np-shadow-sm);
  transition: transform 200ms ease, box-shadow 200ms ease, color 200ms ease;
  /* Centrado vertical y horizontal, altura mínima uniforme */
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 90px;
}
.np-applications__grid li:hover {
  transform: translateY(-2px);
  box-shadow: var(--np-shadow-md);
  color: var(--np-color-primary);
}

/* -------- Categorías relacionadas (fondo naranja, cards blancas) -------- */
.np-catrel {
  background-color: var(--np-color-primary-hover);
  color: var(--np-color-dark);
}
.np-catrel .np-section__title {
  color: var(--np-color-dark);
}
.np-catrel__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: var(--np-space-4);
  max-width: var(--np-container-max);
  margin: 0 auto;
}
.np-catrel__card {
  position: relative;
  display: flex;
  flex-direction: column;
  background-color: var(--np-color-white);
  border-radius: var(--np-radius-lg);
  padding: 0 0 var(--np-space-3) 0;
  text-decoration: none;
  color: var(--np-color-dark);
  box-shadow: var(--np-shadow-md);
  transition: transform 250ms ease, box-shadow 250ms ease;
  overflow: hidden;
  font-family: var(--np-font-ui);
}
.np-catrel__card::before {
  content: "";
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 4px;
  background-color: var(--np-color-primary);
  transition: width 250ms ease;
  z-index: 1;
}
.np-catrel__card:hover,
.np-catrel__card:focus-visible {
  transform: translateY(-4px);
  box-shadow: var(--np-shadow-lg);
}
.np-catrel__card:hover::before,
.np-catrel__card:focus-visible::before {
  width: 8px;
}
.np-catrel__media {
  width: 100%;
  aspect-ratio: 4 / 3;
  background-color: var(--np-color-light);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--np-space-3);
  overflow: hidden;
  margin-bottom: var(--np-space-3);
}
.np-catrel__media img {
  max-width: 80%;
  max-height: 100%;
  width: auto;
  height: auto;
  object-fit: contain;
  transition: transform 350ms ease;
}
.np-catrel__card:hover .np-catrel__media img,
.np-catrel__card:focus-visible .np-catrel__media img {
  transform: scale(1.06);
}
.np-catrel__title {
  font-weight: 900;
  font-size: var(--np-fs-md);
  letter-spacing: var(--np-ls-sm);
  text-transform: uppercase;
  margin-bottom: var(--np-space-2);
  padding: 0 var(--np-space-4);
}
.np-catrel__desc {
  font-family: var(--np-font-text);
  font-size: var(--np-fs-sm);
  line-height: var(--np-lh-base);
  margin-bottom: var(--np-space-3);
  color: var(--np-color-dark);
  opacity: 0.75;
  flex-grow: 1;
  padding: 0 var(--np-space-4);
}
.np-catrel__arrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--np-font-ui);
  font-weight: 700;
  font-size: var(--np-fs-xs);
  letter-spacing: var(--np-ls-sm);
  text-transform: uppercase;
  color: var(--np-color-accent);
  transition: gap 200ms ease, color 200ms ease;
  margin-top: auto;
  padding: 0 var(--np-space-4);
  width: max-content;
}
.np-catrel__arrow::after {
  content: "→";
  font-size: 1rem;
  line-height: 1;
  transition: transform 200ms ease;
}
.np-catrel__card:hover .np-catrel__arrow {
  gap: 14px;
  color: var(--np-color-primary);
}
.np-catrel__card:hover .np-catrel__arrow::after {
  transform: translateX(2px);
}

/* -------- Responsive tweaks (mobile-first overrides) -------- */

/* Tablet portrait y phone grande (≤767px) */
@media (max-width: 767px) {
  .np-hero h1            { font-size: var(--np-fs-xl); letter-spacing: var(--np-ls-sm); }
  .np-section__title     { font-size: var(--np-fs-lg); letter-spacing: var(--np-ls-sm); }
}

/* Phone estándar (≤480px) */
@media (max-width: 480px) {
  .np-hero               { padding: calc(var(--np-header-height) + var(--np-space-5)) var(--np-space-3) var(--np-space-5); }
  .np-hero h1            { font-size: var(--np-fs-lg); letter-spacing: 1px; }
  .np-section            { padding: var(--np-space-6) var(--np-space-3); }
  .np-section__title     { font-size: var(--np-fs-md); letter-spacing: 1px; }
  .np-product-card__name { font-size: var(--np-fs-base); }
  .np-hero__index a      { font-size: 0.6rem; padding: 6px 12px; }
  .np-products-grid      { grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); }
  .np-catrel__grid       { grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); }
}

/* Phone portrait estándar (≤420px) — cubre iPhone SE, 12 mini, regular phones */
@media (max-width: 420px) {
  /* h1 se mantiene con el tamaño del breakpoint anterior (1.2rem). Solo achicamos h2. */
  /* !important porque la regla @min-width:768 puede pisar en algunos entornos
     de preview/embed que reportan viewport ≥ 768 aunque la pantalla sea chica. */
  .np-page .np-section__title { font-size: 1.1rem !important; letter-spacing: 0; font-weight: 700; }
  .np-section            { padding: var(--np-space-5) var(--np-space-3); }
  .np-products-grid      { grid-template-columns: 1fr; }
  .np-catrel__grid       { grid-template-columns: 1fr; }
  .np-applications__grid { grid-template-columns: repeat(2, 1fr); }
  .np-breadcrumbs ol     { font-size: 0.6rem; gap: 6px; }
}

/* Phone muy chico (≤340px) — Galaxy Fold cerrado y similares */
@media (max-width: 340px) {
  .np-section__title     { font-size: var(--np-fs-sm); }
  .np-product-card__name { font-size: var(--np-fs-sm); }
}
